1 # This awk program contains the type mapping tables - and the treatments
3 # Copyright (C) CEA, EDF
4 # Author : Nicolas Crouzet (CEA)
10 # file name generation
14 class_i=class_name"_i"
15 print "\t// generated part" > idl_file
16 printf " // generated part\n" > hxx_file
17 printf "//\n// generated part\n//\n" > cxx_file
18 print "Functions parsing (for debug)" > "parse_result"
21 # type mapping from c++ component to idl
23 idl_arg_type["int"]="in long"
24 idl_arg_type["bool"]="in boolean"
25 idl_arg_type["double"]="in double"
26 idl_arg_type["float"]="in float"
27 idl_arg_type["long"]="in long"
28 idl_arg_type["short"]="in short"
29 idl_arg_type["unsigned"]="in unsigned long"
30 idl_arg_type["const char*"]="in string"
31 idl_arg_type["const std::string&"]="in string"
32 idl_arg_type["int&"]="out long"
33 idl_arg_type["bool&"]="out boolean"
34 idl_arg_type["double&"]="out double"
35 idl_arg_type["float&"]="out float"
36 idl_arg_type["long&"]="out long"
37 idl_arg_type["short&"]="out short"
38 idl_arg_type["unsigned&"]="out unsigned long"
39 idl_arg_type["std::string&"]="out string"
40 idl_arg_type["const MEDMEM::MESH&"]="in SALOME_MED::MESH"
41 idl_arg_type["const MEDMEM::MESH*"]="in SALOME_MED::MESH"
42 idl_arg_type["const MEDMEM::SUPPORT&"]="in SALOME_MED::SUPPORT"
43 idl_arg_type["const MEDMEM::SUPPORT*"]="in SALOME_MED::SUPPORT"
44 idl_arg_type["const MEDMEM::FIELD<double>*"]="in SALOME_MED::FIELDDOUBLE"
45 idl_arg_type["const MEDMEM::FIELD<double>&"]="in SALOME_MED::FIELDDOUBLE"
46 idl_arg_type["MEDMEM::FIELD<double>*&"]="out SALOME_MED::FIELDDOUBLE"
47 idl_arg_type["const std::vector<double>&"]="in SALOME::vectorOfDouble"
48 idl_arg_type["const std::vector<std::vector<double> >&"]="in SALOME::Matrix"
49 idl_arg_type["std::vector<double>*&"]="out SALOME::vectorOfDouble"
50 idl_arg_type["const MEDMEM::FIELD<int>*"]="in SALOME_MED::FIELDINT"
51 idl_arg_type["const MEDMEM::FIELD<int>&"]="in SALOME_MED::FIELDINT"
52 idl_arg_type["MEDMEM::FIELD<int>*&"]="out SALOME_MED::FIELDINT"
53 idl_arg_type["const std::vector<int>&"]="in SALOME::vectorOfLong"
54 idl_arg_type["std::vector<int>*&"]="out SALOME::vectorOfLong"
57 # mapping for returned types
59 idl_rtn_type["void"]="void"
60 idl_rtn_type["int"]="long"
61 idl_rtn_type["bool"]="boolean"
62 idl_rtn_type["double"]="double"
63 idl_rtn_type["float"]="float"
64 idl_rtn_type["long"]="long"
65 idl_rtn_type["short"]="short"
66 idl_rtn_type["unsigned"]="unsigned long"
67 idl_rtn_type["const char*"]="string"
68 idl_rtn_type["char*"]="string"
69 idl_rtn_type["std::string"]="string"
70 idl_rtn_type["const MEDMEM::MESH&"]="SALOME_MED::MESH"
71 idl_rtn_type["MEDMEM::MESH&"]="SALOME_MED::MESH"
72 idl_rtn_type["MEDMEM::MESH*"]="SALOME_MED::MESH"
73 idl_rtn_type["const MEDMEM::MESH*"]="SALOME_MED::MESH"
74 idl_rtn_type["MEDMEM::SUPPORT*"]="SALOME_MED::SUPPORT"
75 idl_rtn_type["const MEDMEM::FIELD<double>*"]="SALOME_MED::FIELDDOUBLE"
76 idl_rtn_type["MEDMEM::FIELD<double>*"]="SALOME_MED::FIELDDOUBLE"
77 idl_rtn_type["MEDMEM::FIELD<double>&"]="SALOME_MED::FIELDDOUBLE"
78 idl_rtn_type["const MEDMEM::FIELD<double>&"]="SALOME_MED::FIELDDOUBLE"
79 idl_rtn_type["std::vector<double>*"]="SALOME::vectorOfDouble"
80 idl_rtn_type["std::vector<std::vector<double> >*"]="SALOME::Matrix"
81 idl_rtn_type["const MEDMEM::FIELD<int>*"]="SALOME_MED::FIELDINT"
82 idl_rtn_type["MEDMEM::FIELD<int>*"]="SALOME_MED::FIELDINT"
83 idl_rtn_type["MEDMEM::FIELD<int>&"]="SALOME_MED::FIELDINT"
84 idl_rtn_type["const MEDMEM::FIELD<int>&"]="SALOME_MED::FIELDINT"
85 idl_rtn_type["std::vector<int>*"]="SALOME::vectorOfLong"
86 idl_rtn_type["std::vector<std::string>"]="StrSeq"
89 # Corba mapping table (for argument's types and returned types)
91 idl_impl_hxx["in long"]="CORBA::Long"
92 idl_impl_hxx["in boolean"]="CORBA::Boolean"
93 idl_impl_hxx["in double"]="CORBA::Double"
94 idl_impl_hxx["in float"]="CORBA::Float"
95 idl_impl_hxx["in short"]="CORBA::Short"
96 idl_impl_hxx["in unsigned long"]="CORBA::ULong"
97 idl_impl_hxx["in string"]="const char*"
98 idl_impl_hxx["out long"]="CORBA::Long_out"
99 idl_impl_hxx["out boolean"]="CORBA::Boolean_out"
100 idl_impl_hxx["out double"]="CORBA::Double_out"
101 idl_impl_hxx["out float"]="CORBA::Float_out"
102 idl_impl_hxx["out short"]="CORBA::Short_out"
103 idl_impl_hxx["out unsigned long"]="CORBA::ULong_out"
104 idl_impl_hxx["out string"]="CORBA::String_out"
105 idl_impl_hxx["in SALOME_MED::MESH"]="SALOME_MED::MESH_ptr"
106 idl_impl_hxx["in SALOME_MED::SUPPORT"]="SALOME_MED::SUPPORT_ptr"
107 idl_impl_hxx["in SALOME_MED::FIELDDOUBLE"]="SALOME_MED::FIELDDOUBLE_ptr"
108 idl_impl_hxx["out SALOME_MED::FIELDDOUBLE"]="SALOME_MED::FIELDDOUBLE_out"
109 idl_impl_hxx["in SALOME::vectorOfDouble"]="const SALOME::vectorOfDouble&"
110 idl_impl_hxx["out SALOME::vectorOfDouble"]="SALOME::vectorOfDouble_out"
111 idl_impl_hxx["in SALOME::Matrix"]="SALOME::Matrix_ptr"
112 idl_impl_hxx["in SALOME_MED::FIELDINT"]="SALOME_MED::FIELDINT_ptr"
113 idl_impl_hxx["out SALOME_MED::FIELDINT"]="SALOME_MED::FIELDINT_out"
114 idl_impl_hxx["in SALOME::vectorOfLong"]="const SALOME::vectorOfLong&"
115 idl_impl_hxx["out SALOME::vectorOfLong"]="SALOME::vectorOfLong_out"
116 idl_impl_hxx["void"]="void"
117 idl_impl_hxx["long"]="CORBA::Long"
118 idl_impl_hxx["boolean"]="CORBA::Boolean"
119 idl_impl_hxx["double"]="CORBA::Double"
120 idl_impl_hxx["unsigned long"]="CORBA::ULong"
121 idl_impl_hxx["string"]="char*"
122 idl_impl_hxx["SALOME_MED::MESH"]="SALOME_MED::MESH_ptr"
123 idl_impl_hxx["SALOME_MED::SUPPORT"]="SALOME_MED::SUPPORT_ptr"
124 idl_impl_hxx["SALOME_MED::FIELDDOUBLE"]="SALOME_MED::FIELDDOUBLE_ptr"
125 idl_impl_hxx["SALOME::vectorOfDouble"]="SALOME::vectorOfDouble*"
126 idl_impl_hxx["SALOME::Matrix"]="SALOME::Matrix_ptr"
127 idl_impl_hxx["SALOME_MED::FIELDINT"]="SALOME_MED::FIELDINT_ptr"
128 idl_impl_hxx["SALOME::vectorOfLong"]="SALOME::vectorOfLong*"
129 idl_impl_hxx["StrSeq"]=class_name"_ORB::StrSeq*"
132 # table for c++ code generation : argument's processing
134 cpp_impl_a["int"]="\tint _%s(%s);\n"
135 cpp_impl_a["bool"]="\tbool _%s(%s);\n"
136 cpp_impl_a["double"]="\tdouble _%s(%s);\n"
137 cpp_impl_a["float"]="\tfloat _%s(%s);\n"
138 cpp_impl_a["long"]="\tlong _%s(%s);\n"
139 cpp_impl_a["short"]="\tshort _%s(%s);\n"
140 cpp_impl_a["unsigned"]="\tunsigned _%s(%s);\n"
141 cpp_impl_a["const char*"]="\tconst char* _%s(%s);\n"
142 cpp_impl_a["const std::string&"]="\tconst std::string _%s(%s);\n"
143 cpp_impl_a["int&"]="\tint _%s;\n"
144 cpp_impl_a["bool&"]="\tbool _%s;\n"
145 cpp_impl_a["double&"]="\tdouble _%s;\n"
146 cpp_impl_a["float&"]="\tfloat _%s;\n"
147 cpp_impl_a["long&"]="\tlong _%s;\n"
148 cpp_impl_a["short&"]="\tshort _%s;\n"
149 cpp_impl_a["unsigned&"]="\tunsigned _%s;\n"
150 cpp_impl_a["std::string&"]="\tstd::string _%s;\n"
151 cpp_impl_a["const MEDMEM::MESH&"]="\tMEDMEM::MESHClient* _%s = new MEDMEM::MESHClient(%s);\n\t _%s->fillCopy();\n" # MESHClient cannot be created on the stack (private constructor), so we create it on the heap and dereference it later (in treatment 4)
152 cpp_impl_a["const MEDMEM::MESH*"]="\tMEDMEM::MESHClient* _%s = new MEDMEM::MESHClient(%s);\n\t _%s->fillCopy();\n"
153 cpp_impl_a["const MEDMEM::SUPPORT&"]="\tMEDMEM::SUPPORTClient* _%s = new MEDMEM::SUPPORTClient(%s);\n" # SUPPORTClient cannot be created on the stack (protected destructor), so we create it on the heap and dereference it later (in treatment 4)
154 cpp_impl_a["const MEDMEM::SUPPORT*"]="\tMEDMEM::SUPPORTClient* _%s = new MEDMEM::SUPPORTClient(%s);\n"
155 cpp_impl_a["MEDMEM::FIELD<double>*&"]="\tMEDMEM::FIELD<double>* _%s;\n"
156 cpp_impl_a["const MEDMEM::FIELD<double>*"]="\tstd::auto_ptr<MEDMEM::FIELD<double> > _%s ( new MEDMEM::FIELDClient<double,MEDMEM::FullInterlace>(%s) );\n"
157 cpp_impl_a["const MEDMEM::FIELD<double>&"]="\tMEDMEM::FIELDClient<double,MEDMEM::FullInterlace> _%s(%s);\n"
158 cpp_impl_a["const std::vector<double>&"]="\tlong _%s_size=%s.length();\n\tconst double *_%s_value = &%s[0];\n"\
159 "\tstd::vector<double> _%s(_%s_value,_%s_value+_%s_size);\n"
160 # cpp_impl_a["const std::vector<double>&"]="\tlong _%s_size;\n\tdouble *_%s_value = ReceiverFactory::getValue(%s,_%s_size);\n"\
161 # "\tstd::vector<double> _%s(_%s_value,_%s_value+_%s_size);\n\tdelete [] _%s_value;"
162 cpp_impl_a["std::vector<double>*&"]="\tstd::vector<double>* _%s;\n"
163 cpp_impl_a["const std::vector<std::vector<double> >&"]="\tMatrixClient _%s_client;\n\tint _%s_nbRow;\n\tint _%s_nbCol;\n"\
164 "\tdouble* _%s_tab = _%s_client.getValue(%s,_%s_nbCol,_%s_nbRow);\n\tstd::vector<std::vector<double> > _%s(_%s_nbRow);\n"\
165 "\tfor (int i=0; i!=_%s_nbRow; ++i)\n\t{\n\t _%s[i].resize(_%s_nbCol);\n"\
166 "\t std::copy(_%s_tab+_%s_nbCol*i,_%s_tab+_%s_nbCol*(i+1), _%s[i].begin());\n\t}\n\tdelete [] _%s_tab;\n"
167 cpp_impl_a["MEDMEM::FIELD<int>*&"]="\tMEDMEM::FIELD<int>* _%s;\n"
168 cpp_impl_a["const MEDMEM::FIELD<int>*"]="\tstd::auto_ptr<MEDMEM::FIELD<int> > _%s ( new MEDMEM::FIELDClient<int>(%s) );\n"
169 cpp_impl_a["const MEDMEM::FIELD<int>&"]="\tMEDMEM::FIELDClient<int> _%s(%s);\n"
170 cpp_impl_a["const std::vector<int>&"]="\tlong _%s_size=%s.length();\n"\
171 "\tstd::vector<int> _%s(_%s_size);\n"\
172 "\tfor (int i=0; i!=_%s_size; ++i)\n\t _%s[i]=%s[i];"
173 # cpp_impl_a["const std::vector<int>&"]="\tlong _%s_size;\n\tint *_%s_value = ReceiverFactory::getValue(%s,_%s_size);\n"\
174 # "\tstd::vector<int> _%s(_%s_value,_%s_value+_%s_size);\n\tdelete [] _%s_value;"
175 cpp_impl_a["std::vector<int>*&"]="\tstd::vector<int>* _%s;\n"
179 # table for c++ code generation : returned value processing
181 cpp_impl_b["void"]=""
182 cpp_impl_b["int"]="\tCORBA::Long _rtn_ior(_rtn_cpp);\n"
183 cpp_impl_b["bool"]="\tCORBA::Boolean _rtn_ior(_rtn_cpp);\n"
184 cpp_impl_b["double"]="\tCORBA::Double _rtn_ior(_rtn_cpp);\n"
185 cpp_impl_b["float"]="\tCORBA::Float _rtn_ior(_rtn_cpp);\n"
186 cpp_impl_b["long"]="\tCORBA::Long _rtn_ior(_rtn_cpp);\n"
187 cpp_impl_b["short"]="\tCORBA::Short _rtn_ior(_rtn_cpp);\n"
188 cpp_impl_b["unsigned"]="\tCORBA::ULong _rtn_ior(_rtn_cpp);\n"
189 cpp_impl_b["const char*"]="\tchar* _rtn_ior = CORBA::string_dup(_rtn_cpp);\n"
190 cpp_impl_b["char*"]="\tchar* _rtn_ior(_rtn_cpp);\n"
191 cpp_impl_b["std::string"]="\tchar* _rtn_ior=CORBA::string_dup(_rtn_cpp.c_str());\n"
192 "\tstd::copy(_rtn_cpp.begin(),_rtn_cpp.end(),_rtn_ior);\n"
193 cpp_impl_b["const MEDMEM::MESH&"]=\
194 "\tMEDMEM::MESH_i * _rtn_mesh_i = new MEDMEM::MESH_i(const_cast<MEDMEM::MESH*>(&_rtn_cpp));\n"\
195 "\tSALOME_MED::MESH_ptr _rtn_ior = _rtn_mesh_i->_this();\n"
196 cpp_impl_b["MEDMEM::MESH&"]=\
197 "\tMEDMEM::MESH_i * _rtn_mesh_i = new MEDMEM::MESH_i(&_rtn_cpp);\n"\
198 "\tSALOME_MED::MESH_ptr _rtn_ior = _rtn_mesh_i->_this();\n"
199 cpp_impl_b["MEDMEM::MESH*"]=\
200 "\tMEDMEM::MESH_i * _rtn_mesh_i = new MEDMEM::MESH_i(_rtn_cpp);\n"\
201 "\tSALOME_MED::MESH_ptr _rtn_ior = _rtn_mesh_i->_this();\n"
202 cpp_impl_b["const MEDMEM::MESH*"]=\
203 "\tMEDMEM::MESH_i * _rtn_mesh_i = new MEDMEM::MESH_i(const_cast<MEDMEM::MESH*>(_rtn_cpp));\n"\
204 "\tSALOME_MED::MESH_ptr _rtn_ior = _rtn_mesh_i->_this();\n"
205 cpp_impl_b["MEDMEM::SUPPORT*"]=\
206 "\tMEDMEM::SUPPORT_i * _rtn_support_i = new MEDMEM::SUPPORT_i(_rtn_cpp);\n"\
207 "\tSALOME_MED::SUPPORT_ptr _rtn_ior = _rtn_support_i->_this();\n"
208 cpp_impl_b["const MEDMEM::FIELD<double>*"]=\
209 "\tMEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace> * _rtn_field_i = new MEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace>(const_cast<MEDMEM::FIELD<double>*>(_rtn_cpp),false);\n"\
210 "\tSALOME_MED::FIELDDOUBLE_ptr _rtn_ior = _rtn_field_i->_this();\n"
211 cpp_impl_b["MEDMEM::FIELD<double>*"]=\
212 "\tMEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace> * _rtn_field_i = new MEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace>(_rtn_cpp,true);\n"\
213 "\tSALOME_MED::FIELDDOUBLE_ptr _rtn_ior = _rtn_field_i->_this();\n"
214 cpp_impl_b["MEDMEM::FIELD<double>&"]=\
215 "\tMEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace> * _rtn_field_i = new MEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace>(&_rtn_cpp,false);\n"\
216 "\tSALOME_MED::FIELDDOUBLE_ptr _rtn_ior = _rtn_field_i->_this();\n"
217 cpp_impl_b["const MEDMEM::FIELD<double>&"]=\
218 "\tMEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace> * _rtn_field_i = new MEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace>(const_cast<MEDMEM::FIELD<double>*>(&_rtn_cpp),false);\n"\
219 "\tSALOME_MED::FIELDDOUBLE_ptr _rtn_ior = _rtn_field_i->_this();\n"
220 cpp_impl_b["std::vector<double>*"]=\
221 "\tSALOME::vectorOfDouble * _rtn_ior = new SALOME::vectorOfDouble;\n"\
222 "\tint _rtn_cpp_length=(*_rtn_cpp).size();\n"\
223 "\t_rtn_ior->length(_rtn_cpp_length);\n"\
224 "\tfor (int i=0; i<_rtn_cpp_length; ++i)\n\t (*_rtn_ior)[i] = (*_rtn_cpp)[i];\n"
225 # cpp_impl_b["std::vector<double>*"]=\
226 # "\tSALOME::SenderDouble_ptr _rtn_ior = SenderFactory::buildSender(*this,&(*_rtn_cpp)[0],(*_rtn_cpp).size(),true);\n"
227 cpp_impl_b["std::vector<std::vector<double> >*"]=\
228 "\tint _rtn_cpp_i=(*_rtn_cpp).size();\n\tint _rtn_cpp_j=(*_rtn_cpp)[0].size();\n"\
229 "\tdouble* _rtn_tab = new double[_rtn_cpp_i*_rtn_cpp_j];\n"\
230 "\tfor (int i=0; i!=_rtn_cpp_i; ++i)\n\t std::copy((*_rtn_cpp)[i].begin(),(*_rtn_cpp)[i].end(),_rtn_tab+i*_rtn_cpp_j);\n"\
231 "\tSALOME_Matrix_i* _rtn_matrix_i = new SALOME_Matrix_i(*this,_rtn_tab,_rtn_cpp_i,_rtn_cpp_j,true);\n"\
232 "\tSALOME::Matrix_ptr _rtn_ior = _rtn_matrix_i->_this();\n\tdelete _rtn_cpp;\n"
233 cpp_impl_b["const MEDMEM::FIELD<int>*"]=\
234 "\tMEDMEM::FIELDINT_i * _rtn_field_i = new MEDMEM::FIELDINT_i(const_cast<MEDMEM::FIELD<int>*>(_rtn_cpp),false);\n"\
235 "\tSALOME_MED::FIELDINT_ptr _rtn_ior = _rtn_field_i->_this();\n"
236 cpp_impl_b["MEDMEM::FIELD<int>*"]=\
237 "\tMEDMEM::FIELDINT_i * _rtn_field_i = new MEDMEM::FIELDINT_i(_rtn_cpp,true);\n"\
238 "\tSALOME_MED::FIELDINT_ptr _rtn_ior = _rtn_field_i->_this();\n"
239 cpp_impl_b["MEDMEM::FIELD<int>&"]=\
240 "\tMEDMEM::FIELDINT_i * _rtn_field_i = new MEDMEM::FIELDINT_i(&_rtn_cpp,false);\n"\
241 "\tSALOME_MED::FIELDINT_ptr _rtn_ior = _rtn_field_i->_this();\n"
242 cpp_impl_b["const MEDMEM::FIELD<int>&"]=\
243 "\tMEDMEM::FIELDINT_i * _rtn_field_i = new MEDMEM::FIELDINT_i(const_cast<MEDMEM::FIELD<int>*>(&_rtn_cpp),false);\n"\
244 "\tSALOME_MED::FIELDINT_ptr _rtn_ior = _rtn_field_i->_this();\n"
245 cpp_impl_b["std::vector<int>*"]=\
246 "\tSALOME::vectorOfLong * _rtn_ior = new SALOME::vectorOfLong;\n"\
247 "\tint _rtn_cpp_length=(*_rtn_cpp).size();\n"\
248 "\t_rtn_ior->length(_rtn_cpp_length);\n"\
249 "\tfor (int i=0; i<_rtn_cpp_length; ++i)\n\t (*_rtn_ior)[i] = (*_rtn_cpp)[i];\n"
250 cpp_impl_b["std::vector<std::string>"]=\
251 "\t"class_name"_ORB::StrSeq*_rtn_ior = new "class_name"_ORB::StrSeq;\n"\
252 "\tint _rtn_cpp_length=_rtn_cpp.size();\n"\
253 "\t_rtn_ior->length(_rtn_cpp_length);\n"\
254 "\tfor (int i=0; i<_rtn_cpp_length; ++i)\n"\
255 "\t (*_rtn_ior)[i] = _rtn_cpp[i].c_str();\n"
257 # cpp_impl_b["std::vector<int>*"]=\
258 # "\tSALOME::SenderInt_ptr _rtn_ior = SenderFactory::buildSender(*this,&(*_rtn_cpp)[0],(*_rtn_cpp).size(),true);\n"
262 # table for c++ code generation : out parameters processing and removeRef for reference counted objects
264 cpp_impl_c["MEDMEM::FIELD<double>*&"]=\
265 "\tMEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace> * %s_ior = new MEDMEM::FIELDTEMPLATE_I<double,MEDMEM::FullInterlace>(_%s, true);\n"\
266 "\t%s = %s_ior->_this();\n"
267 cpp_impl_c["MEDMEM::FIELD<int>*&"]=\
268 "\tMEDMEM::FIELDINT_i * %s_ior = new MEDMEM::FIELDINT_i(_%s, true);\n"\
269 "\t%s = %s_ior->_this();\n"
270 cpp_impl_c["std::vector<double>*&"]=\
271 "\t%s = new SALOME::vectorOfDouble;\n"\
272 "\t%s->length((*_%s).size());\n"\
273 "\tfor (int i=0; i<(*_%s).size(); ++i)\n\t (*%s)[i] = (*_%s)[i];\n"
274 # "\t%s = SenderFactory::buildSender(*this,&(*_%s)[0],(*_%s).size(),true);\n"
275 cpp_impl_c["std::vector<int>*&"]=\
276 "\t%s = new SALOME::vectorOfLong;\n"\
277 "\t%s->length((*_%s).size());\n"\
278 "\tfor (int i=0; i<(*_%s).size(); ++i)\n\t (*%s)[i] = (*_%s)[i];\n"
279 # "\t%s = SenderFactory::buildSender(*this,&(*_%s)[0],(*_%s).size(),true);\n"
280 cpp_impl_c["std::string&"]="\t%s = CORBA::string_dup(_%s.c_str());\n"
281 cpp_impl_c["int&"]="\t%s = _%s;\n"
282 cpp_impl_c["bool&"]="\t%s = _%s;\n"
283 cpp_impl_c["double&"]="\t%s = _%s;\n"
284 cpp_impl_c["float&"]="\t%s = _%s;\n"
285 cpp_impl_c["long&"]="\t%s = _%s;\n"
286 cpp_impl_c["short&"]="\t%s = _%s;\n"
287 cpp_impl_c["unsigned&"]="\t%s = _%s;\n"
288 cpp_impl_c["const MEDMEM::MESH&"]="\t_%s->removeReference();\n"
289 cpp_impl_c["const MEDMEM::MESH*"]="\t_%s->removeReference();\n"
290 cpp_impl_c["const MEDMEM::SUPPORT&"]="\t_%s->removeReference();\n"
291 cpp_impl_c["const MEDMEM::SUPPORT*"]="\t_%s->removeReference();\n"
294 # record sep is ");\n" whith blanks all around, and optional "(" at the beginning
295 RS="[(]?[ \t]*[)][ \t]*(const)?[ \t]*[;][ \t]*[\n]"
296 FS="[ \t]*[(,][ \t]*" # field sep is either "(" or "," surrounded by blanks
299 # --------------------- treatment 1 ----------------------------------
301 # extract from fields types, function name, and argument's names
304 print "Function : ",$0 >> "parse_result" # print for debug
305 for (i=1; i<=NF; i++) {
306 print "\t-> ",i," : ",$i >> "parse_result"
309 error_message="\t The non compatible types are : "
310 # check if returned type ($1) is one of the accepted types (idl_rtn_type)
311 for (cpptype in idl_rtn_type) {
312 if ( substr($1,1,length(cpptype)) == cpptype ) {
313 # if compatible, store returned type and function name
315 name[1]=substr($1,length(cpptype)+1)
316 sub("^[ \t]*","",name[1]) # get rid of leading blanks
324 error_message=error_message sprintf("\n\t\t-> %s (return type)",tab[1])
326 # for each argument ($i), check if it is compatible (belongs to idl_arg_type)
327 for (i=2; i<=NF; i++) {
329 split($i,tab,"=") # get rid of default value
331 sub("/[ \t]*&[ \t]*/", "&", item) # supress spaces around * and $
332 sub("/[ \t]**[ \t]*/", "*", item)
333 for (cpptype in idl_arg_type) {
335 s0 = substr(item,1,l) # to discriminate between int and int&, ...
337 if (length(item) > l)
338 s1 = substr(item, l+1, 1)
340 if ( (s0 == cpptype) && (s1 == " ") ) {
341 # if compatible, store argument type and name
343 name[i]=substr(item,length(cpptype)+1)
344 sub("^[ \t]*","",name[i]) # get rid of leading blanks
345 if ( length(name[i]) == 0 ) # automatic name if argument's name wasn't precised
346 name[i]=sprintf("_arg%d",i-1)
351 ok*=ok2 # ok=0 if one of the type is not compatible
353 error_message=error_message "\n\t\t-> "item
357 # print compatibility
358 if ( $0 !~ class_name ) { # constructor are not considered, but we don't print it
359 if ( ok == 0){ # if one of the c++ type is not compatible
360 printf " [KO] : %s",$0
363 printf " [OK] : %s",$0
366 printf "(" # if there is no argument, parenthesis was suppressed, so we add it for printing
369 if ( ok == 0){ #print the error message
370 printf "%s\n\n",error_message
373 if ( ok == 0) # pass to the next function if one of the c++ type is not compatible
377 # --------------------- treatment 2 ----------------------------------
379 # generate the Corba interface (idl file)
382 printf "\t%s %s(", idl_rtn_type[type[1]],name[1] >> idl_file # return type and name of function
383 if ( NF >= 2 ){ # if there is arguments, print them
384 for (i=2; i<=NF-1; i++)
385 printf "%s %s,",idl_arg_type[type[i]],name[i] >> idl_file
386 printf "%s %s", idl_arg_type[type[NF]],name[NF] >> idl_file
388 printf ") raises (SALOME::SALOME_Exception);\n" >> idl_file
391 # --------------------- treatment 3 ----------------------------------
393 # generate the C++ implementation of component (hxx file)
396 printf " %s %s(",idl_impl_hxx[idl_rtn_type[type[1]]],name[1] >> hxx_file
397 if ( NF >= 2 ){ # if there is arguments, print them
398 for (i=2; i<=NF-1; i++)
399 printf "%s %s,",idl_impl_hxx[idl_arg_type[type[i]]],name[i] >> hxx_file
400 printf "%s %s", idl_impl_hxx[idl_arg_type[type[NF]]],name[NF] >> hxx_file
402 printf ") throw (SALOME::SALOME_Exception);\n" >> hxx_file
405 # --------------------- treatment 4 ----------------------------------
407 # generate the C++ implementation of component (cxx file)
410 # a) generate the function declaration + macro declarations
411 func_name=class_name"_i::"name[1]
412 printf "%s %s(",idl_impl_hxx[idl_rtn_type[type[1]]],func_name >> cxx_file
413 if ( NF >= 2 ){ # if there is arguments, print them
414 for (i=2; i<=NF-1; i++)
415 printf "%s %s,",idl_impl_hxx[idl_arg_type[type[i]]],name[i] >> cxx_file
416 printf "%s %s", idl_impl_hxx[idl_arg_type[type[NF]]],name[NF] >> cxx_file
418 printf ") throw (SALOME::SALOME_Exception)\n{\n beginService(\"%s\");\n BEGIN_OF(\"%s\");\n try\n {\n",func_name,func_name >> cxx_file
420 # b) generate the argument processing part
422 printf "//\tArguments processing\n" >> cxx_file
423 for (i=2; i<=NF; i++)
424 printf cpp_impl_a[type[i]],name[i],name[i],name[i],name[i],name[i],name[i],name[i],name[i],name[i],\
425 name[i],name[i],name[i],name[i],name[i],name[i],name[i],name[i],name[i],name[i] >> cxx_file
428 # c) generate the call to the c++ component
429 if ( type[1] == "void" ) # if return type is void, the call syntax is different.
430 printf "//\tCall cpp component\n\tcppCompo_->%s(",name[1] >> cxx_file
432 printf "//\tCall cpp component\n\t%s _rtn_cpp = cppCompo_->%s(",type[1],name[1] >> cxx_file
433 if ( NF >= 2 ){ # if there is arguments, print them
434 for (i=2; i<=NF; i++) {
435 # special treatment for some arguments
438 if ( cpp_impl_a[type[i]] ~ "auto_ptr" )
439 post=".get()" # for auto_ptr argument, retrieve the raw pointer behind
440 if ( type[i] == "const MEDMEM::MESH&" || type[i] == "const MEDMEM::SUPPORT&" )
441 pre="*" # we cannot create MESHClient on the stack (private constructor), so we create it on the heap and dereference it
443 post=post"," # separator between arguments
444 printf " %s_%s%s",pre,name[i],post >> cxx_file
448 # d) generate the post_processing of returned and out parameters
449 printf ");\n//\tPost-processing & return\n" >> cxx_file
450 for (i=2; i<=NF; i++)
451 printf cpp_impl_c[type[i]],name[i],name[i],name[i],name[i],name[i],name[i] >> cxx_file # process for out parameters
452 printf cpp_impl_b[type[1]] >> cxx_file # process for returned value
453 printf "\tendService(\"%s\");\n\tEND_OF(\"%s\");\n",func_name,func_name >> cxx_file
454 if ( type[1] != "void" )
455 printf "\treturn _rtn_ior;\n" >> cxx_file
456 printf " }\n catch (std::exception& ex)\n {\n THROW_SALOME_CORBA_EXCEPTION( ex.what(), SALOME::INTERNAL_ERROR );\n }\n" >> cxx_file
457 printf "}\n\n" >> cxx_file
462 # CNC peut être mis dans le template directement printf "\nprivate:\n std::auto_ptr<%s> cppImpl_;\n",class_name >> hxx_file