ASClassBinder.cpp 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294
  1. //
  2. // Copyright (c) 2008-2020 the Urho3D project.
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to deal
  6. // in the Software without restriction, including without limitation the rights
  7. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. // copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  20. // THE SOFTWARE.
  21. //
  22. #include "ASResult.h"
  23. #include "ASUtils.h"
  24. #include "Tuning.h"
  25. #include "Utils.h"
  26. #include "XmlAnalyzer.h"
  27. #include "XmlSourceData.h"
  28. #include <cassert>
  29. #include <iostream>
  30. #include <regex>
  31. #include <fstream>
  32. #include <vector>
  33. namespace ASBindingGenerator
  34. {
  35. static string _outputBasePath;
  36. static shared_ptr<ASGeneratedFile_Members> _result_Members_A;
  37. static shared_ptr<ASGeneratedFile_Members> _result_Members_B;
  38. static shared_ptr<ASGeneratedFile_Members> _result_Members_Constraint;
  39. static shared_ptr<ASGeneratedFile_Members> _result_Members_Ca_Cm;
  40. static shared_ptr<ASGeneratedFile_Members> _result_Members_Cn_Cz;
  41. static shared_ptr<ASGeneratedFile_Members> _result_Members_D;
  42. static shared_ptr<ASGeneratedFile_Members> _result_Members_E;
  43. static shared_ptr<ASGeneratedFile_Members> _result_Members_F;
  44. static shared_ptr<ASGeneratedFile_Members> _result_Members_G;
  45. static shared_ptr<ASGeneratedFile_Members> _result_Members_H;
  46. static shared_ptr<ASGeneratedFile_Members> _result_Members_I;
  47. static shared_ptr<ASGeneratedFile_Members> _result_Members_J;
  48. static shared_ptr<ASGeneratedFile_Members> _result_Members_K;
  49. static shared_ptr<ASGeneratedFile_Members> _result_Members_L;
  50. static shared_ptr<ASGeneratedFile_Members> _result_Members_M;
  51. static shared_ptr<ASGeneratedFile_Members> _result_Members_N;
  52. static shared_ptr<ASGeneratedFile_Members> _result_Members_O;
  53. static shared_ptr<ASGeneratedFile_Members> _result_Members_P;
  54. static shared_ptr<ASGeneratedFile_Members> _result_Members_Q;
  55. static shared_ptr<ASGeneratedFile_Members> _result_Members_R;
  56. static shared_ptr<ASGeneratedFile_Members> _result_Members_Sa_Sm;
  57. static shared_ptr<ASGeneratedFile_Members> _result_Members_Sn_Sz;
  58. static shared_ptr<ASGeneratedFile_Members> _result_Members_Ta_Tm;
  59. static shared_ptr<ASGeneratedFile_Members> _result_Members_Tn_Tz;
  60. static shared_ptr<ASGeneratedFile_Members> _result_Members_U;
  61. static shared_ptr<ASGeneratedFile_Members> _result_Members_V;
  62. static shared_ptr<ASGeneratedFile_Members> _result_Members_W;
  63. static shared_ptr<ASGeneratedFile_Members> _result_Members_X;
  64. static shared_ptr<ASGeneratedFile_Members> _result_Members_Y;
  65. static shared_ptr<ASGeneratedFile_Members> _result_Members_Z;
  66. static shared_ptr<ASGeneratedFile_Members> _result_Members_Other;
  67. static shared_ptr<ASGeneratedFile_Templates> _result_Templates;
  68. static shared_ptr<ASGeneratedFile_Members> GetGeneratedFile(const string& className)
  69. {
  70. if (StartsWith(className, "A"))
  71. return _result_Members_A;
  72. if (StartsWith(className, "B"))
  73. return _result_Members_B;
  74. if (StartsWith(className, "Constraint"))
  75. return _result_Members_Constraint;
  76. if (StartsWith(className, "C"))
  77. {
  78. if (className.length() < 2)
  79. return _result_Members_Ca_Cm;
  80. char secondChar = className[1];
  81. if (secondChar >= 'n')
  82. return _result_Members_Cn_Cz;
  83. return _result_Members_Ca_Cm;
  84. }
  85. if (StartsWith(className, "D"))
  86. return _result_Members_D;
  87. if (StartsWith(className, "E"))
  88. return _result_Members_E;
  89. if (StartsWith(className, "F"))
  90. return _result_Members_F;
  91. if (StartsWith(className, "G"))
  92. return _result_Members_G;
  93. if (StartsWith(className, "H"))
  94. return _result_Members_H;
  95. if (StartsWith(className, "I"))
  96. return _result_Members_I;
  97. if (StartsWith(className, "J"))
  98. return _result_Members_J;
  99. if (StartsWith(className, "K"))
  100. return _result_Members_K;
  101. if (StartsWith(className, "L"))
  102. return _result_Members_L;
  103. if (StartsWith(className, "M"))
  104. return _result_Members_M;
  105. if (StartsWith(className, "N"))
  106. return _result_Members_N;
  107. if (StartsWith(className, "O"))
  108. return _result_Members_O;
  109. if (StartsWith(className, "P"))
  110. return _result_Members_P;
  111. if (StartsWith(className, "Q"))
  112. return _result_Members_Q;
  113. if (StartsWith(className, "R"))
  114. return _result_Members_R;
  115. if (StartsWith(className, "S"))
  116. {
  117. if (className.length() < 2)
  118. return _result_Members_Sa_Sm;
  119. char secondChar = className[1];
  120. if (secondChar >= 'n')
  121. return _result_Members_Sn_Sz;
  122. return _result_Members_Sa_Sm;
  123. }
  124. if (StartsWith(className, "T"))
  125. {
  126. if (className.length() < 2)
  127. return _result_Members_Ta_Tm;
  128. char secondChar = className[1];
  129. if (secondChar >= 'n')
  130. return _result_Members_Tn_Tz;
  131. return _result_Members_Ta_Tm;
  132. }
  133. if (StartsWith(className, "U"))
  134. return _result_Members_U;
  135. if (StartsWith(className, "V"))
  136. return _result_Members_V;
  137. if (StartsWith(className, "W"))
  138. return _result_Members_W;
  139. if (StartsWith(className, "X"))
  140. return _result_Members_X;
  141. if (StartsWith(className, "Y"))
  142. return _result_Members_Y;
  143. if (StartsWith(className, "Z"))
  144. return _result_Members_Z;
  145. if (StartsWith(className, "W"))
  146. return _result_Members_W;
  147. return _result_Members_Other;
  148. }
  149. //static void RegisterStaticFunction(const ClassStaticFunctionAnalyzer& functionAnalyzer, shared_ptr<ASGeneratedFile_Members> result)
  150. static void RegisterStaticFunction(const ClassStaticFunctionAnalyzer& functionAnalyzer, ASGeneratedFile_Base* result)
  151. {
  152. result->reg_ << " // " << functionAnalyzer.GetLocation() << "\n";
  153. vector<ParamAnalyzer> params = functionAnalyzer.GetParams();
  154. vector<shared_ptr<FuncParamConv> > convertedParams;
  155. string outGlue;
  156. bool needWrapper = false;
  157. for (const ParamAnalyzer& param : params)
  158. {
  159. shared_ptr<FuncParamConv> conv = CppFunctionParamToAS(param);
  160. if (!conv->success_)
  161. {
  162. result->reg_ << " // " << conv->errorMessage_ << "\n";
  163. return;
  164. }
  165. if (conv->NeedWrapper())
  166. needWrapper = true;
  167. convertedParams.push_back(conv);
  168. }
  169. shared_ptr<FuncReturnTypeConv> convertedReturn = CppFunctionReturnTypeToAS(functionAnalyzer.GetReturnType());
  170. if (!convertedReturn->success_)
  171. {
  172. result->reg_ << " // " << GetLastErrorMessage() << "\n";
  173. return;
  174. }
  175. if (convertedReturn->needWrapper_)
  176. needWrapper = true;
  177. string declParams;
  178. for (shared_ptr<FuncParamConv> conv : convertedParams)
  179. {
  180. if (declParams.length() > 0)
  181. declParams += ", ";
  182. declParams += conv->asDecl_;
  183. }
  184. string asFunctionName = functionAnalyzer.GetName();
  185. string className = functionAnalyzer.GetClassName();
  186. if (needWrapper)
  187. result->glue_ << GenerateWrapper(functionAnalyzer, convertedParams, convertedReturn);
  188. string decl = convertedReturn->asReturnType_ + " " + asFunctionName + "(" + declParams + ")";
  189. result->reg_ << " engine->SetDefaultNamespace(\"" << className << "\");\n";
  190. result->reg_ << " engine->RegisterGlobalFunction(\"" << decl << "\", ";
  191. if (needWrapper)
  192. result->reg_ << "asFUNCTION(" << GenerateWrapperName(functionAnalyzer) << "), asCALL_CDECL);\n";
  193. else
  194. result->reg_ << Generate_asFUNCTIONPR(functionAnalyzer) << ", asCALL_CDECL);\n";
  195. result->reg_ << " engine->SetDefaultNamespace(\"\");\n";
  196. }
  197. static void RegisterRefCountedConstructor(const ClassFunctionAnalyzer& functionAnalyzer, bool templateVersion)
  198. {
  199. string className = functionAnalyzer.GetClassName();
  200. string wrapperName = GenerateWrapperName(functionAnalyzer, templateVersion);
  201. string header = functionAnalyzer.GetClass().GetHeaderFile();
  202. string insideDefine = InsideDefine(header);
  203. string args = ExtractCleanedFunctionArgsstring(functionAnalyzer.GetMemberdef());
  204. //shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(functionAnalyzer.GetClass().GetClassName());
  205. ASGeneratedFile_Base* result = templateVersion ? (ASGeneratedFile_Base*)_result_Templates.get() : (ASGeneratedFile_Base*)GetGeneratedFile(functionAnalyzer.GetClass().GetClassName()).get();
  206. bool firstContext = StartsWith(args, "Context *context");
  207. if (firstContext)
  208. {
  209. args = CutStart(args, "Context *context");
  210. args = CutStart(args, ", ");
  211. }
  212. else if (args.find("Context") != string::npos)
  213. {
  214. result->reg_ <<
  215. " // " << functionAnalyzer.GetLocation() << "\n"
  216. " // Error: context can be only first\n";
  217. return;
  218. }
  219. string cppParamsNames = functionAnalyzer.JoinParamsNames(firstContext);
  220. if (firstContext)
  221. {
  222. if (cppParamsNames.length() > 0)
  223. cppParamsNames = ", " + cppParamsNames;
  224. cppParamsNames = "GetScriptContext()" + cppParamsNames;
  225. }
  226. string decl = "";
  227. vector<ParamAnalyzer> params = functionAnalyzer.GetParams();
  228. for (unsigned i = 0; i < params.size(); i++)
  229. {
  230. ParamAnalyzer param = params[i];
  231. if (i == 0 && firstContext)
  232. {
  233. assert(param.GetType().ToString() == "Context*");
  234. continue;
  235. }
  236. if (decl.length() > 0)
  237. decl += ", ";
  238. bool outSuccess;
  239. decl += CppTypeToAS(param.GetType(), false, outSuccess);
  240. string defval = param.GetDefval();
  241. if (!defval.empty())
  242. {
  243. defval = CppValueToAS(defval);
  244. defval = ReplaceAll(defval, "\"", "\\\"");
  245. decl += /*" " + param.GetDeclname() +*/ " = " + defval;
  246. }
  247. if (!outSuccess)
  248. {
  249. result->reg_ <<
  250. " // " << functionAnalyzer.GetLocation() << "\n"
  251. " // " << GetLastErrorMessage() << "\n";
  252. return;
  253. }
  254. }
  255. decl = className + "@+ f(" + decl + ")";
  256. if (templateVersion)
  257. {
  258. result->reg_ <<
  259. " // " << functionAnalyzer.GetLocation() << "\n"
  260. " {\n"
  261. " String declFactory(String(className) + \"@ f()\");\n"
  262. " engine->RegisterObjectBehaviour(className, "
  263. "asBEHAVE_FACTORY, "
  264. "declFactory.CString(), "
  265. "asFUNCTION(" << wrapperName << "), "
  266. "asCALL_CDECL);\n"
  267. " }\n";
  268. }
  269. else
  270. {
  271. result->reg_ <<
  272. " // " << functionAnalyzer.GetLocation() << "\n"
  273. " engine->RegisterObjectBehaviour("
  274. "\"" << className << "\", "
  275. "asBEHAVE_FACTORY, "
  276. "\"" << decl << "\", "
  277. "asFUNCTION(" << wrapperName << "), "
  278. "asCALL_CDECL);\n";
  279. }
  280. if (!insideDefine.empty())
  281. result->glue_ << "#ifdef " << insideDefine << "\n";
  282. result->glue_ <<
  283. "// " << functionAnalyzer.GetLocation() << "\n"
  284. "static " << className << "* " << wrapperName << "(" << args << ")\n"
  285. "{\n"
  286. " return new " << className << "(" << cppParamsNames << ");\n"
  287. "}\n";
  288. if (!insideDefine.empty())
  289. result->glue_ << "#endif\n";
  290. result->glue_ << "\n";
  291. }
  292. static void RegisterValueConstructor(const ClassFunctionAnalyzer& functionAnalyzer, bool templateVersion)
  293. {
  294. string header = functionAnalyzer.GetClass().GetHeaderFile();
  295. string insideDefine = InsideDefine(header);
  296. string className = functionAnalyzer.GetClassName();
  297. string wrapperName = GenerateWrapperName(functionAnalyzer, templateVersion);
  298. string args = ExtractCleanedFunctionArgsstring(functionAnalyzer.GetMemberdef());
  299. shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(className);
  300. bool isDefaultConstructor = args.empty();
  301. if (isDefaultConstructor)
  302. return;
  303. stringstream& reg = result->reg_;
  304. stringstream& glue = result->glue_;
  305. string decl = "";
  306. vector<ParamAnalyzer> params = functionAnalyzer.GetParams();
  307. for (ParamAnalyzer param : params)
  308. {
  309. if (decl.length() > 0)
  310. decl += ", ";
  311. bool outSuccess;
  312. decl += CppTypeToAS(param.GetType(), false, outSuccess);
  313. string defval = param.GetDefval();
  314. if (!defval.empty())
  315. {
  316. defval = CppValueToAS(defval);
  317. defval = ReplaceAll(defval, "\"", "\\\"");
  318. decl += /*" " + param.GetDeclname() +*/ " = " + defval;
  319. }
  320. if (!outSuccess)
  321. {
  322. if (isDefaultConstructor && !insideDefine.empty())
  323. reg << "#ifdef " << insideDefine << "\n";
  324. reg <<
  325. " // " << functionAnalyzer.GetLocation() << "\n"
  326. " // " << GetLastErrorMessage() << "\n";
  327. if (isDefaultConstructor && !insideDefine.empty())
  328. reg << "#endif\n";
  329. return;
  330. }
  331. }
  332. decl = "void f(" + decl + ")";
  333. if (isDefaultConstructor && !insideDefine.empty())
  334. reg << "#ifdef " << insideDefine << "\n";
  335. reg <<
  336. " // " << functionAnalyzer.GetLocation() << "\n"
  337. " engine->RegisterObjectBehaviour("
  338. "\"" << className << "\", "
  339. "asBEHAVE_CONSTRUCT, "
  340. "\"" << decl << "\", "
  341. "asFUNCTION(" << wrapperName << "), "
  342. "asCALL_CDECL_OBJFIRST);\n";
  343. if (isDefaultConstructor && !insideDefine.empty())
  344. reg << "#endif\n";
  345. if (isDefaultConstructor && !insideDefine.empty())
  346. glue << "#ifdef " << insideDefine << "\n";
  347. glue <<
  348. "// " << functionAnalyzer.GetLocation() << "\n"
  349. "static void " << wrapperName << "(" << className << "* ptr";
  350. if (args.length() > 0)
  351. glue << ", " << args;
  352. glue << ")\n"
  353. "{\n"
  354. " new(ptr) " << className << "(" << functionAnalyzer.JoinParamsNames() << ");\n"
  355. "}\n";
  356. if (isDefaultConstructor && !insideDefine.empty())
  357. glue << "#endif\n";
  358. glue << "\n";
  359. if (isDefaultConstructor)
  360. Result::AddHeader(header);
  361. }
  362. static void TryRegisterImplicitlyDeclaredAssignOperator(const ClassAnalyzer& classAnalyzer)
  363. {
  364. string className = classAnalyzer.GetClassName();
  365. shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(className);
  366. result->reg_ <<
  367. " // " << className << "& " << className << "::operator=(const " << className << "&) | Possible implicitly-declared\n"
  368. " RegisterImplicitlyDeclaredAssignOperatorIfPossible<" << className << ">(engine, \"" << className << "\");\n";
  369. }
  370. // Some required methods can not be bound automatically when processing class because implicitly-declared
  371. static void RegisterImplicitlyDeclaredMethods(const ClassAnalyzer& classAnalyzer)
  372. {
  373. if (!classAnalyzer.ContainsFunction("operator="))
  374. TryRegisterImplicitlyDeclaredAssignOperator(classAnalyzer);
  375. // No need register impicitly declared copy constructor when registered opAssign operator
  376. }
  377. static void RegisterComparisonOperator(const ClassAnalyzer& classAnalyzer)
  378. {
  379. string className = classAnalyzer.GetClassName();
  380. string wrapperName = className + "_Comparison";
  381. string operatorLessLocation = classAnalyzer.GetFunction("operator<")->GetLocation();
  382. string operatorGreaterLocation = classAnalyzer.GetFunction("operator>")->GetLocation();
  383. shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(className);
  384. result->glue_ <<
  385. "// " << operatorLessLocation << "\n"
  386. "// " << operatorGreaterLocation << "\n"
  387. "static int " << wrapperName << "(const " << className << "& lhs, const " << className << "& rhs)\n"
  388. "{\n"
  389. " if (lhs < rhs)\n"
  390. " return -1;\n\n"
  391. " if (lhs > rhs)\n"
  392. " return 1;\n\n"
  393. " return 0;\n"
  394. "}\n\n";
  395. result->reg_ <<
  396. " // " << operatorLessLocation << "\n"
  397. " // " << operatorGreaterLocation << "\n"
  398. " engine->RegisterObjectMethod(\"" << className << "\", \"int opCmp(const " << className << "&in) const\", asFUNCTION(" << wrapperName << "), asCALL_CDECL_OBJFIRST);\n";
  399. }
  400. static void RegisterAddReleaseRef(const ClassFunctionAnalyzer& functionAnalyzer, bool templateVersion)
  401. {
  402. string className = functionAnalyzer.GetClassName();
  403. //shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(className);
  404. ASGeneratedFile_Base* result = templateVersion ? (ASGeneratedFile_Base*)_result_Templates.get() : (ASGeneratedFile_Base*)GetGeneratedFile(functionAnalyzer.GetClass().GetClassName()).get();
  405. string functionName = functionAnalyzer.GetName();
  406. string behaviour = (functionName == "AddRef") ? "asBEHAVE_ADDREF" : "asBEHAVE_RELEASE";
  407. string methodpr = Generate_asMETHODPR(functionAnalyzer, templateVersion);
  408. result->reg_ << " // " << functionAnalyzer.GetLocation() << "\n";
  409. if (templateVersion)
  410. result->reg_ << " engine->RegisterObjectBehaviour(className, " << behaviour << ", \"void f()\", " << methodpr << ", asCALL_THISCALL);\n";
  411. else
  412. result->reg_ << " engine->RegisterObjectBehaviour(\"" << className << "\", " << behaviour << ", \"void f()\", " << methodpr << ", asCALL_THISCALL);\n";
  413. }
  414. static void RegisterFakeAddReleaseRef(const ClassAnalyzer& classAnalyzer)
  415. {
  416. string className = classAnalyzer.GetClassName();
  417. shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(className);
  418. result->reg_ <<
  419. " engine->RegisterObjectBehaviour(\"" << className << "\", asBEHAVE_ADDREF, \"void f()\", asFUNCTION(FakeAddRef), asCALL_CDECL_OBJLAST);\n"
  420. " engine->RegisterObjectBehaviour(\"" << className << "\", asBEHAVE_RELEASE, \"void f()\", asFUNCTION(FakeReleaseRef), asCALL_CDECL_OBJLAST);\n";
  421. }
  422. // https://www.angelcode.com/angelscript/sdk/docs/manual/doc_script_class_ops.html
  423. string CppMethodNameToAS(const ClassFunctionAnalyzer& functionAnalyzer, bool& outSuccess)
  424. {
  425. string name = functionAnalyzer.GetName();
  426. if (name == "operator=")
  427. {
  428. outSuccess = true;
  429. return "opAssign";
  430. }
  431. if (name == "operator+")
  432. {
  433. outSuccess = true;
  434. return "opAdd";
  435. }
  436. if (name == "operator-")
  437. {
  438. outSuccess = true;
  439. if (!functionAnalyzer.GetParams().size()) // If no params
  440. return "opNeg"; // then unary minus
  441. else
  442. return "opSub";
  443. }
  444. if (name == "operator*")
  445. {
  446. outSuccess = true;
  447. return "opMul";
  448. }
  449. if (name == "operator/")
  450. {
  451. outSuccess = true;
  452. return "opDiv";
  453. }
  454. if (name == "operator+=")
  455. {
  456. outSuccess = true;
  457. return "opAddAssign";
  458. }
  459. if (name == "operator-=")
  460. {
  461. outSuccess = true;
  462. return "opSubAssign";
  463. }
  464. if (name == "operator*=")
  465. {
  466. outSuccess = true;
  467. return "opMulAssign";
  468. }
  469. if (name == "operator/=")
  470. {
  471. outSuccess = true;
  472. return "opDivAssign";
  473. }
  474. if (name == "operator==")
  475. {
  476. outSuccess = true;
  477. return "opEquals";
  478. }
  479. if (name == "operator[]")
  480. {
  481. outSuccess = true;
  482. return "opIndex";
  483. }
  484. // Conversion to another type operator
  485. if (StartsWith(name, "operator "))
  486. {
  487. outSuccess = true;
  488. if (functionAnalyzer.IsExplicit())
  489. return "opConv";
  490. else
  491. return "opImplConv";
  492. }
  493. if (name == "operator!=")
  494. {
  495. outSuccess = false;
  496. SetLastErrorMessage("Only operator== is needed");
  497. return "IGNORED";
  498. }
  499. if (name == "operator<")
  500. {
  501. outSuccess = false;
  502. SetLastErrorMessage("Registerd as opCmp separately");
  503. return "IGNORED";
  504. }
  505. if (name == "operator>")
  506. {
  507. outSuccess = false;
  508. SetLastErrorMessage("Registerd as opCmp separately");
  509. return "IGNORED";
  510. }
  511. outSuccess = true;
  512. return name;
  513. }
  514. // Iterate over overrided funcions
  515. static bool HaveMark(const ClassFunctionAnalyzer& functionAnalyzer, const string& mark)
  516. {
  517. if (Contains(functionAnalyzer.GetComment(), mark))
  518. return true;
  519. shared_ptr<ClassFunctionAnalyzer> reimplements = functionAnalyzer.Reimplements();
  520. if (!reimplements)
  521. return false;
  522. return HaveMark(*reimplements, mark);
  523. }
  524. // Can return BIND_AS_ALIAS_xxxx or BIND_AS_PROPERTY
  525. // Return "" if no this marks
  526. static string GetPropertyMark(ClassFunctionAnalyzer function)
  527. {
  528. string comment = function.GetComment();
  529. smatch match;
  530. regex_match(comment, match, regex(".*\\b(BIND_AS_ALIAS_.+?)\\b.*"));
  531. if (match.size() == 2)
  532. return match[1].str();
  533. regex_match(comment, match, regex(".*\\bBIND_AS_PROPERTY\\b.*"));
  534. if (match.size() == 1)
  535. return "BIND_AS_PROPERTY";
  536. shared_ptr<ClassFunctionAnalyzer> reimplements = function.Reimplements();
  537. if (!reimplements)
  538. return "";
  539. return GetPropertyMark(*reimplements);
  540. }
  541. // https://www.angelcode.com/angelscript/sdk/docs/manual/doc_reg_objprop.html
  542. static string CppMethodNameToASProperty(const ClassFunctionAnalyzer& functionAnalyzer, bool& outSuccess)
  543. {
  544. string name = functionAnalyzer.GetName();
  545. if (StartsWith(name, "Is") || StartsWith(name, "Get"))
  546. {
  547. outSuccess = true;
  548. string result = CutStart(name, "Is");
  549. result = CutStart(result, "Get");
  550. result = "get_" + FirstCharToLower(result);
  551. return result;
  552. }
  553. if (StartsWith(name, "Set"))
  554. {
  555. outSuccess = true;
  556. string result = CutStart(name, "Set");
  557. result = "set_" + FirstCharToLower(result);
  558. return result;
  559. }
  560. if (functionAnalyzer.CanBeGetProperty())
  561. {
  562. outSuccess = true;
  563. string result = name;
  564. result = "get_" + FirstCharToLower(result);
  565. return result;
  566. }
  567. if (functionAnalyzer.CanBeSetProperty())
  568. {
  569. outSuccess = true;
  570. string result = name;
  571. result = "set_" + FirstCharToLower(result);
  572. return result;
  573. }
  574. outSuccess = false;
  575. SetLastErrorMessage("ERROR: Can not be property");
  576. return "ERROR";
  577. }
  578. static void RegisterMethod(const ClassFunctionAnalyzer& functionAnalyzer, bool templateVersion)
  579. {
  580. if (functionAnalyzer.IsDefine()) // URHO3D_OBJECT
  581. return;
  582. if (!functionAnalyzer.IsPublic())
  583. return;
  584. if (functionAnalyzer.IsParentDestructor())
  585. return;
  586. if (functionAnalyzer.IsParentConstructor())
  587. return;
  588. //shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(functionAnalyzer.GetClass().GetClassName());
  589. ASGeneratedFile_Base* result = templateVersion ? (ASGeneratedFile_Base*)_result_Templates.get() : (ASGeneratedFile_Base*)GetGeneratedFile(functionAnalyzer.GetClass().GetClassName()).get();
  590. if (HaveMark(functionAnalyzer, "NO_BIND"))
  591. {
  592. result->reg_ << " // " << functionAnalyzer.GetLocation() << "\n";
  593. result->reg_ << " // Not registered because have @nobind mark\n";
  594. return;
  595. }
  596. if (HaveMark(functionAnalyzer, "MANUAL_BIND"))
  597. {
  598. result->reg_ << " // " << functionAnalyzer.GetLocation() << "\n";
  599. result->reg_ << " // Not registered because have @manualbind mark\n";
  600. return;
  601. }
  602. if (functionAnalyzer.IsTemplate())
  603. {
  604. result->reg_ << " // " << functionAnalyzer.GetLocation() << "\n";
  605. result->reg_ << " // Not registered because template\n";
  606. return;
  607. }
  608. if (functionAnalyzer.IsStatic())
  609. {
  610. ClassStaticFunctionAnalyzer classStaticFunctionAnalyzer(functionAnalyzer.GetClass(), functionAnalyzer.GetMemberdef());
  611. RegisterStaticFunction(classStaticFunctionAnalyzer, result);
  612. return;
  613. }
  614. if (functionAnalyzer.IsDeleted())
  615. return;
  616. /*if (function.IsPureVirtual()) // Register pure virtual function but not register constructor for this class
  617. return;*/
  618. // Do not register destructor for refcounted because object is deleted by himself
  619. if (functionAnalyzer.IsThisDestructor()
  620. && (functionAnalyzer.GetClass().IsRefCounted() || Contains(functionAnalyzer.GetClass().GetComment(), "FAKE_REF")))
  621. {
  622. return;
  623. }
  624. string functionName = functionAnalyzer.GetName();
  625. if (functionName == "operator!=")
  626. return;
  627. // Already registered as sigle function opCmp
  628. if (functionName == "operator<" || functionName == "operator>")
  629. return;
  630. if (functionName == "AddRef" || functionName == "ReleaseRef")
  631. {
  632. RegisterAddReleaseRef(functionAnalyzer, templateVersion);
  633. return;
  634. }
  635. if (functionAnalyzer.IsThisConstructor())
  636. {
  637. if (functionAnalyzer.GetClass().IsRefCounted() || Contains(functionAnalyzer.GetClass().GetComment(), "FAKE_REF"))
  638. {
  639. // Do not register construnctor for abstract class
  640. if (functionAnalyzer.GetClass().IsAbstract())
  641. return;
  642. RegisterRefCountedConstructor(functionAnalyzer, templateVersion);
  643. }
  644. else
  645. {
  646. RegisterValueConstructor(functionAnalyzer, templateVersion);
  647. }
  648. return;
  649. }
  650. if (functionAnalyzer.IsThisDestructor())
  651. return;
  652. result->reg_ << " // " << functionAnalyzer.GetLocation() << "\n";
  653. vector<ParamAnalyzer> params = functionAnalyzer.GetParams();
  654. vector<shared_ptr<FuncParamConv> > convertedParams;
  655. bool needWrapper = false;
  656. for (const ParamAnalyzer& param : params)
  657. {
  658. shared_ptr<FuncParamConv> conv = CppFunctionParamToAS(param);
  659. if (!conv->success_)
  660. {
  661. result->reg_ << " // " << conv->errorMessage_ << "\n";
  662. return;
  663. }
  664. if (conv->NeedWrapper())
  665. needWrapper = true;
  666. convertedParams.push_back(conv);
  667. }
  668. shared_ptr<FuncReturnTypeConv> retConv = CppFunctionReturnTypeToAS(functionAnalyzer.GetReturnType());
  669. if (!retConv->success_)
  670. {
  671. result->reg_ << " // " << retConv->errorMessage_ << "\n";
  672. return;
  673. }
  674. if (retConv->needWrapper_)
  675. needWrapper = true;
  676. string declParams = "";
  677. for (shared_ptr<FuncParamConv> conv : convertedParams)
  678. {
  679. if (declParams.length() > 0)
  680. declParams += ", ";
  681. declParams += conv->asDecl_;
  682. }
  683. string asReturnType = retConv->asReturnType_;
  684. string asFunctionName = functionAnalyzer.GetName();
  685. if (functionAnalyzer.IsConsversionOperator())
  686. asReturnType = CutStart(asFunctionName, "operator ");
  687. bool outSuccess;
  688. asFunctionName = CppMethodNameToAS(functionAnalyzer, outSuccess);
  689. if (!outSuccess)
  690. {
  691. result->reg_ << " // " << GetLastErrorMessage() << "\n";
  692. return;
  693. }
  694. if (needWrapper)
  695. result->glue_ << GenerateWrapper(functionAnalyzer, templateVersion, convertedParams, retConv);
  696. string decl = asReturnType + " " + asFunctionName + "(" + declParams + ")";
  697. if (functionAnalyzer.IsConst())
  698. decl += " const";
  699. if (templateVersion)
  700. result->reg_ << " engine->RegisterObjectMethod(className, \"" << decl << "\", ";
  701. else
  702. result->reg_ << " engine->RegisterObjectMethod(\"" << functionAnalyzer.GetClassName() << "\", \"" << decl << "\", ";
  703. if (needWrapper)
  704. result->reg_ << "asFUNCTION(" << GenerateWrapperName(functionAnalyzer, templateVersion) << "), asCALL_CDECL_OBJFIRST);\n";
  705. else
  706. result->reg_ << Generate_asMETHODPR(functionAnalyzer, templateVersion) << ", asCALL_THISCALL);\n";
  707. // Also register as property if needed
  708. string propertyMark = GetPropertyMark(functionAnalyzer);
  709. if (!propertyMark.empty())
  710. {
  711. if (StartsWith(propertyMark, "BIND_AS_ALIAS_"))
  712. {
  713. asFunctionName = CutStart(propertyMark, "BIND_AS_ALIAS_");
  714. }
  715. else
  716. {
  717. asFunctionName = CppMethodNameToASProperty(functionAnalyzer, outSuccess);
  718. if (!outSuccess)
  719. {
  720. result->reg_ << " // " << GetLastErrorMessage() << "\n";
  721. return;
  722. }
  723. }
  724. decl = asReturnType + " " + asFunctionName + "(" + declParams + ")";
  725. if (functionAnalyzer.IsConst())
  726. decl += " const";
  727. if (templateVersion)
  728. result->reg_ << " engine->RegisterObjectMethod(className, \"" << decl << "\", ";
  729. else
  730. result->reg_ << " engine->RegisterObjectMethod(\"" << functionAnalyzer.GetClassName() << "\", \"" << decl << "\", ";
  731. if (needWrapper)
  732. result->reg_ << "asFUNCTION(" << GenerateWrapperName(functionAnalyzer, templateVersion) << "), asCALL_CDECL_OBJFIRST);\n";
  733. else
  734. result->reg_ << Generate_asMETHODPR(functionAnalyzer, templateVersion) << ", asCALL_THISCALL);\n";
  735. }
  736. }
  737. static void RegisterClassVarAsProperty(ClassVariableAnalyzer& variable)
  738. {
  739. if (!variable.IsPublic())
  740. return;
  741. shared_ptr<ASGeneratedFile_Members> result = GetGeneratedFile(variable.GetClassName());
  742. if (Contains(variable.GetComment(), "NO_BIND"))
  743. {
  744. result->reg_ << " // " << variable.GetLocation() << "\n";
  745. result->reg_ << " // Not registered because have @nobind mark\n";
  746. return;
  747. }
  748. if (Contains(variable.GetComment(), "MANUAL_BIND"))
  749. {
  750. result->reg_ << " // " << variable.GetLocation() << "\n";
  751. result->reg_ << " // Not registered because have @manualbind mark\n";
  752. return;
  753. }
  754. if (variable.IsStatic())
  755. {
  756. result->reg_ << " // " << variable.GetLocation() << "\n";
  757. bool outSuccess;
  758. string asType = CppTypeToAS(variable.GetType(), false, outSuccess);
  759. if (variable.GetType().IsConst())
  760. asType = "const " + asType;
  761. asType = ReplaceAll(asType, "struct ", "");
  762. if (!outSuccess)
  763. {
  764. result->reg_ << " // " << GetLastErrorMessage() << "\n";
  765. return;
  766. }
  767. string className = variable.GetClassName();
  768. result->reg_ <<
  769. " engine->SetDefaultNamespace(\"" << className << "\");\n";
  770. result->reg_ <<
  771. " engine->RegisterGlobalProperty("
  772. "\"" << asType << " " << variable.GetName() << "\", "
  773. "(void*)&" << className << "::" << variable.GetName() << ");\n";
  774. result->reg_ << " engine->SetDefaultNamespace(\"\");\n";
  775. }
  776. else
  777. {
  778. result->reg_ << " // " << variable.GetLocation() << "\n";
  779. if (variable.IsArray())
  780. {
  781. result->reg_ << " // Not registered because array\n";
  782. return;
  783. }
  784. if (variable.GetType().IsPointer())
  785. {
  786. result->reg_ << " // " << variable.GetType().ToString() << " can not be registered\n";
  787. return;
  788. }
  789. bool outSuccess;
  790. string propType = CppTypeToAS(variable.GetType(), false, outSuccess);
  791. if (!outSuccess)
  792. {
  793. result->reg_ << " // " << GetLastErrorMessage() << "\n";
  794. return;
  795. }
  796. string varName = variable.GetName();
  797. assert(!varName.empty());
  798. string propName = CutEnd(varName, "_");
  799. string className = variable.GetClassName();
  800. result->reg_ <<
  801. " engine->RegisterObjectProperty("
  802. "\"" << className << "\", "
  803. "\"" << propType << " " << propName << "\", "
  804. "offsetof(" << className << ", " << varName << "));\n";
  805. }
  806. }
  807. static void RegisterObjectMembers(const ClassAnalyzer& classAnalyzer, bool templateVersion)
  808. {
  809. string header = classAnalyzer.GetHeaderFile();
  810. ASGeneratedFile_Base* result = templateVersion ? (ASGeneratedFile_Base*)_result_Templates.get() : (ASGeneratedFile_Base*)GetGeneratedFile(classAnalyzer.GetClassName()).get();
  811. Result::AddHeader(header);
  812. string insideDefine = InsideDefine(header);
  813. if (!insideDefine.empty())
  814. result->reg_ << "#ifdef " << insideDefine << "\n";
  815. vector<ClassVariableAnalyzer> variables = classAnalyzer.GetVariables();
  816. for (ClassVariableAnalyzer variable : variables)
  817. RegisterClassVarAsProperty(variable);
  818. vector<ClassFunctionAnalyzer> functions = classAnalyzer.GetFunctions();
  819. for (ClassFunctionAnalyzer function : functions)
  820. RegisterMethod(function, templateVersion);
  821. RegisterImplicitlyDeclaredMethods(classAnalyzer);
  822. // 2 operators is replaced by single function opCmp
  823. if (classAnalyzer.ContainsFunction("operator>") || classAnalyzer.ContainsFunction("operator>"))
  824. RegisterComparisonOperator(classAnalyzer);
  825. if (Contains(classAnalyzer.GetComment(), "FAKE_REF"))
  826. RegisterFakeAddReleaseRef(classAnalyzer);
  827. vector<ClassAnalyzer> classList = classAnalyzer.GetAllBaseClasses();
  828. classList.push_back(classAnalyzer); // Also add current class to list
  829. string className = classAnalyzer.GetClassName();
  830. for (ClassAnalyzer& cl : classList)
  831. {
  832. string clName = cl.GetClassName();
  833. result->reg_ << "#ifdef REGISTER_MANUAL_PART_" << clName << "\n";
  834. if (templateVersion)
  835. result->reg_ << " REGISTER_MANUAL_PART_" << clName << "(T, className)\n";
  836. else
  837. result->reg_ << " REGISTER_MANUAL_PART_" << clName << "(" << className << ", \"" << className << "\")\n";
  838. result->reg_ << "#endif\n";
  839. }
  840. if (classAnalyzer.IsRefCounted() || Contains(classAnalyzer.GetComment(), "FAKE_REF"))
  841. {
  842. vector<ClassAnalyzer> baseClasses = classAnalyzer.GetAllBaseClasses();
  843. for (ClassAnalyzer baseClass : baseClasses)
  844. {
  845. if (baseClass.IsRefCounted() || Contains(baseClass.GetComment(), "FAKE_REF"))
  846. {
  847. string baseClassName = baseClass.GetClassName();
  848. if (templateVersion)
  849. result->reg_ << " RegisterSubclass<" << baseClassName << ", T>(engine, \"" << baseClassName << "\", className);\n";
  850. else
  851. result->reg_ << " RegisterSubclass<" << baseClassName << ", " << className << ">(engine, \"" << baseClassName << "\", \"" << className << "\");\n";
  852. }
  853. }
  854. // In template also add current class
  855. if (templateVersion)
  856. result->reg_ << " RegisterSubclass<" << className << ", T>(engine, \"" << className << "\", className);\n";
  857. }
  858. /*if (!analyzer.IsRefCounted()) // Executed also for FAKE_REF
  859. // TODO refcounted <=> value conversion if refcounted is chield value
  860. {
  861. vector<ClassAnalyzer> baseClasses = analyzer.GetAllBaseClasses();
  862. for (ClassAnalyzer baseClass : baseClasses)
  863. {
  864. if (!baseClass.IsRefCounted()) // Executed also for FAKE_REF
  865. {
  866. ASResult::reg_ << " RegisterSubclassValue<" << baseClass.GetClassName()
  867. << ", " << analyzer.GetClassName() << ">(engine, "
  868. << "\"" << baseClass.GetClassName() << "\", "
  869. << "\"" << analyzer.GetClassName() << "\");\n";
  870. }
  871. }
  872. }
  873. */
  874. if (!insideDefine.empty())
  875. result->reg_ << "#endif\n";
  876. if (!templateVersion)
  877. result->reg_ << "\n";
  878. }
  879. // Only template version
  880. static void RegisterObjectType(const ClassAnalyzer& classAnalyzer/*, bool templateVersion*/)
  881. {
  882. string header = classAnalyzer.GetHeaderFile();
  883. ASGeneratedFile_Base* result = (ASGeneratedFile_Base*)_result_Templates.get();
  884. Result::AddHeader(header);
  885. string insideDefine = InsideDefine(header);
  886. if (!insideDefine.empty())
  887. result->reg_ << "#ifdef " << insideDefine << "\n";
  888. result->reg_ << " // " + classAnalyzer.GetLocation() + "\n";
  889. string className = classAnalyzer.GetClassName();
  890. if (classAnalyzer.IsRefCounted() || Contains(classAnalyzer.GetComment(), "FAKE_REF"))
  891. {
  892. //if (templateVersion)
  893. result->reg_ << " engine->RegisterObjectType(className, 0, asOBJ_REF);\n";
  894. //else
  895. // result->reg_ << " engine->RegisterObjectType(\"" << className << "\", 0, asOBJ_REF);\n";
  896. }
  897. else // Value type
  898. {
  899. // TODO templateversion
  900. /* string flags = "asOBJ_VALUE | asGetTypeTraits<" + className + ">()";
  901. if (classAnalyzer.IsPod())
  902. {
  903. flags += " | asOBJ_POD";
  904. if (classAnalyzer.AllFloats())
  905. flags += " | asOBJ_APP_CLASS_ALLFLOATS";
  906. else if (classAnalyzer.AllInts())
  907. flags += " | asOBJ_APP_CLASS_ALLINTS";
  908. }
  909. result->reg_ << " engine->RegisterObjectType(\"" << className << "\", sizeof(" << className << "), " << flags << ");\n";*/
  910. }
  911. if (!insideDefine.empty())
  912. result->reg_ << "#endif\n";
  913. }
  914. static void ProcessClass(const ClassAnalyzer& classAnalyzer, bool templateVersion)
  915. {
  916. if (classAnalyzer.IsInternal())
  917. return;
  918. if (classAnalyzer.IsAbstract() && !(classAnalyzer.IsRefCounted() || Contains(classAnalyzer.GetComment(), "FAKE_REF")))
  919. return;
  920. if (Contains(classAnalyzer.GetComment(), "NO_BIND"))
  921. {
  922. //_result_Classes->reg_ << " // " << classAnalyzer.GetLocation() << "\n";
  923. //_result_Classes->reg_ << " // Not registered because have @nobind mark\n";
  924. return;
  925. }
  926. if (Contains(classAnalyzer.GetComment(), "MANUAL_BIND"))
  927. {
  928. //_result_Classes->reg_ << " // " << classAnalyzer.GetLocation() << "\n";
  929. //_result_Classes->reg_ << " // Not registered because have @manualbind mark\n";
  930. return;
  931. }
  932. string header = classAnalyzer.GetHeaderFile();
  933. if (IsIgnoredHeader(header))
  934. {
  935. Result::AddHeader(header);
  936. return;
  937. }
  938. if (classAnalyzer.IsTemplate())
  939. return;
  940. if (templateVersion)
  941. _result_Templates->reg_ << "template <class T> void Register" << classAnalyzer.GetClassName() << "(asIScriptEngine* engine, const char* className)\n{\n";
  942. if (templateVersion)
  943. RegisterObjectType(classAnalyzer);
  944. RegisterObjectMembers(classAnalyzer, templateVersion);
  945. if (templateVersion)
  946. _result_Templates->reg_ << "}\n\n";
  947. }
  948. void ProcessAllClasses(const string& outputBasePath)
  949. {
  950. _outputBasePath = outputBasePath;
  951. _result_Members_A = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_A.cpp", "ASRegisterGenerated_Members_A");
  952. _result_Members_B = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_B.cpp", "ASRegisterGenerated_Members_B");
  953. _result_Members_Constraint = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Constraint.cpp", "ASRegisterGenerated_Members_Constraint");
  954. _result_Members_Ca_Cm = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Ca_Cm.cpp", "ASRegisterGenerated_Members_Ca_Cm");
  955. _result_Members_Cn_Cz = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Cn_Cz.cpp", "ASRegisterGenerated_Members_Cn_Cz");
  956. _result_Members_D = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_D.cpp", "ASRegisterGenerated_Members_D");
  957. _result_Members_E = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_E.cpp", "ASRegisterGenerated_Members_E");
  958. _result_Members_F = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_F.cpp", "ASRegisterGenerated_Members_F");
  959. _result_Members_G = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_G.cpp", "ASRegisterGenerated_Members_G");
  960. _result_Members_H = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_H.cpp", "ASRegisterGenerated_Members_H");
  961. _result_Members_I = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_I.cpp", "ASRegisterGenerated_Members_I");
  962. _result_Members_J = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_J.cpp", "ASRegisterGenerated_Members_J");
  963. _result_Members_K = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_K.cpp", "ASRegisterGenerated_Members_K");
  964. _result_Members_L = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_L.cpp", "ASRegisterGenerated_Members_L");
  965. _result_Members_M = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_M.cpp", "ASRegisterGenerated_Members_M");
  966. _result_Members_N = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_N.cpp", "ASRegisterGenerated_Members_N");
  967. _result_Members_O = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_O.cpp", "ASRegisterGenerated_Members_O");
  968. _result_Members_P = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_P.cpp", "ASRegisterGenerated_Members_P");
  969. _result_Members_Q = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Q.cpp", "ASRegisterGenerated_Members_Q");
  970. _result_Members_R = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_R.cpp", "ASRegisterGenerated_Members_R");
  971. _result_Members_Sa_Sm = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Sa_Sm.cpp", "ASRegisterGenerated_Members_Sa_Sm");
  972. _result_Members_Sn_Sz = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Sn_Sz.cpp", "ASRegisterGenerated_Members_Sn_Sz");
  973. _result_Members_Ta_Tm = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Ta_Tm.cpp", "ASRegisterGenerated_Members_Ta_Tm");
  974. _result_Members_Tn_Tz = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Tn_Tz.cpp", "ASRegisterGenerated_Members_Tn_Tz");
  975. _result_Members_U = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_U.cpp", "ASRegisterGenerated_Members_U");
  976. _result_Members_V = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_V.cpp", "ASRegisterGenerated_Members_V");
  977. _result_Members_W = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_W.cpp", "ASRegisterGenerated_Members_W");
  978. _result_Members_X = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_X.cpp", "ASRegisterGenerated_Members_X");
  979. _result_Members_Y = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Y.cpp", "ASRegisterGenerated_Members_Y");
  980. _result_Members_Z = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Z.cpp", "ASRegisterGenerated_Members_Z");
  981. _result_Members_Other = make_shared<ASGeneratedFile_Members>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Members_Other.cpp", "ASRegisterGenerated_Members_Other");
  982. _result_Templates = make_shared<ASGeneratedFile_Templates>(_outputBasePath + "/Source/Urho3D/AngelScript/Generated_Templates.h");
  983. // Sorting keys to make class order compiler independent
  984. vector<string> classIDs;
  985. classIDs.reserve(SourceData::classesByID_.size());
  986. for (pair<const string, xml_node>& it : SourceData::classesByID_)
  987. classIDs.push_back(it.first);
  988. sort(classIDs.begin(), classIDs.end());
  989. for (string classID : classIDs)
  990. {
  991. xml_node compounddef = SourceData::classesByID_[classID];
  992. ClassAnalyzer analyzer(compounddef);
  993. ProcessClass(analyzer, false);
  994. // Generate also template version of bindings
  995. if (Contains(analyzer.GetComment(), "TEMPLATE_VERSION"))
  996. ProcessClass(analyzer, true);
  997. }
  998. _result_Members_A->Save();
  999. _result_Members_B->Save();
  1000. _result_Members_Constraint->Save();
  1001. _result_Members_Ca_Cm->Save();
  1002. _result_Members_Cn_Cz->Save();
  1003. _result_Members_D->Save();
  1004. _result_Members_E->Save();
  1005. _result_Members_F->Save();
  1006. _result_Members_G->Save();
  1007. _result_Members_H->Save();
  1008. _result_Members_I->Save();
  1009. _result_Members_J->Save();
  1010. _result_Members_K->Save();
  1011. _result_Members_L->Save();
  1012. _result_Members_M->Save();
  1013. _result_Members_N->Save();
  1014. _result_Members_O->Save();
  1015. _result_Members_P->Save();
  1016. _result_Members_Q->Save();
  1017. _result_Members_R->Save();
  1018. _result_Members_Sa_Sm->Save();
  1019. _result_Members_Sn_Sz->Save();
  1020. _result_Members_Ta_Tm->Save();
  1021. _result_Members_Tn_Tz->Save();
  1022. _result_Members_U->Save();
  1023. _result_Members_V->Save();
  1024. _result_Members_W->Save();
  1025. _result_Members_X->Save();
  1026. _result_Members_Y->Save();
  1027. _result_Members_Z->Save();
  1028. _result_Members_Other->Save();
  1029. _result_Templates->Save();
  1030. }
  1031. }