| 
									
										
										
										
											2023-11-02 10:53:16 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-23 16:01:26 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * The class represent a single parameter (argument) of function. This class | 
					
						
							|  |  |  |  * usually is the member of {@linkplain ExpFctDecl}.
 | 
					
						
							|  |  |  |  */
 | 
					
						
							| 
									
										
										
										
											2023-11-02 10:53:16 +08:00
										 |  |  | public class ExpFctParamDecl {
 | 
					
						
							| 
									
										
										
										
											2024-04-23 16:01:26 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * The type of this parameter.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							| 
									
										
										
										
											2023-11-02 10:53:16 +08:00
										 |  |  | 	public VariableType mVarType;
 | 
					
						
							| 
									
										
										
										
											2024-04-23 16:01:26 +08:00
										 |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * The name of this parameter.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							| 
									
										
										
										
											2023-11-02 10:53:16 +08:00
										 |  |  | 	public String mVarName;
 | 
					
						
							| 
									
										
										
										
											2024-04-23 16:01:26 +08:00
										 |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * True if this paramter is marked as input parameter, otherwise false.
 | 
					
						
							|  |  |  | 	 * <p>
 | 
					
						
							|  |  |  | 	 * Input parameter and output paramter is commonly used in C/C++ code. By using
 | 
					
						
							|  |  |  | 	 * this feature, each function can receive multiple arguments and return
 | 
					
						
							|  |  |  | 	 * multiple arguments without defining a struct to hold it.
 | 
					
						
							|  |  |  | 	 * <p>
 | 
					
						
							|  |  |  | 	 * The type of input parameter is itself. However, the type of output parameter
 | 
					
						
							|  |  |  | 	 * is the pointer of itself. So you may need get its pointer type when
 | 
					
						
							|  |  |  | 	 * processing output paramter, especially for the scenario that the target
 | 
					
						
							|  |  |  | 	 * language do not support explicit output parameter keyword.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							| 
									
										
										
										
											2023-11-02 12:40:50 +08:00
										 |  |  | 	public boolean mIsInput;
 | 
					
						
							| 
									
										
										
										
											2024-04-23 16:01:26 +08:00
										 |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * The description of this parameter.
 | 
					
						
							|  |  |  | 	 * <p>
 | 
					
						
							|  |  |  | 	 * This description is generated by this program. It will indicate the
 | 
					
						
							|  |  |  | 	 * underlying C++ type to tell end user how to treat this paramter because some
 | 
					
						
							|  |  |  | 	 * target languages' native calling style can not represent these detail.
 | 
					
						
							|  |  |  | 	 * <p>
 | 
					
						
							|  |  |  | 	 * In this program, this field must be written as a annotation of corresponding
 | 
					
						
							|  |  |  | 	 * function.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							| 
									
										
										
										
											2023-11-02 22:02:39 +08:00
										 |  |  | 	public String mVarDesc;
 | 
					
						
							| 
									
										
										
										
											2024-04-23 16:01:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-02 12:40:50 +08:00
										 |  |  | 	public ExpFctParamDecl() {
 | 
					
						
							|  |  |  | 		mVarType = new VariableType();
 | 
					
						
							|  |  |  | 		mVarName = "";
 | 
					
						
							| 
									
										
										
										
											2023-11-02 22:02:39 +08:00
										 |  |  | 		mVarDesc = "";
 | 
					
						
							| 
									
										
										
										
											2023-11-02 12:40:50 +08:00
										 |  |  | 		mIsInput = true;
 | 
					
						
							| 
									
										
										
										
											2023-11-02 10:53:16 +08:00
										 |  |  | 	}
 | 
					
						
							| 
									
										
										
										
											2024-04-23 16:01:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-02 10:53:16 +08:00
										 |  |  | }
 |