gen_js_dts.cpp 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. /**
  2. * Tencent is pleased to support the open source community by making Tars available.
  3. *
  4. * Copyright (C) 2016THL A29 Limited, a Tencent company. All rights reserved.
  5. *
  6. * Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
  7. * in compliance with the License. You may obtain a copy of the License at
  8. *
  9. * https://opensource.org/licenses/BSD-3-Clause
  10. *
  11. * Unless required by applicable law or agreed to in writing, software distributed
  12. * under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
  13. * CONDITIONS OF ANY KIND, either express or implied. See the License for the
  14. * specific language governing permissions and limitations under the License.
  15. */
  16. #include "code_generator.h"
  17. string CodeGenerator::generateDTS(const EnumPtr &pPtr, const string &sNamespace)
  18. {
  19. ostringstream s;
  20. INC_TAB;
  21. s << TAB << (_bEnumReverseMappings ? "enum " : "const enum ") << pPtr->getId() << " {" << endl;
  22. INC_TAB;
  23. int nenum = -1;
  24. bool bDependent = false;
  25. vector<TypeIdPtr>& member = pPtr->getAllMemberPtr();
  26. for (size_t i = 0; i < member.size(); i++)
  27. {
  28. bDependent |= isDependent(sNamespace, member[i]->getId());
  29. if (member[i]->hasDefault())
  30. {
  31. nenum = TC_Common::strto<int>(member[i]->def());
  32. }
  33. else
  34. {
  35. nenum++;
  36. }
  37. s << TAB << member[i]->getId() << " = " << TC_Common::tostr(nenum) << ((i < member.size() - 1) ? "," : "") << endl;
  38. }
  39. DEL_TAB;
  40. s << TAB << "}" << endl;
  41. DEL_TAB;
  42. if (!_bMinimalMembers || _bEntry || bDependent || isDependent(sNamespace, pPtr->getId())) {
  43. return s.str();
  44. } else {
  45. return "";
  46. }
  47. }
  48. string CodeGenerator::generateDTS(const ConstPtr &pPtr, const string &sNamespace, bool &bNeedStream)
  49. {
  50. if (_bMinimalMembers && !_bEntry && !isDependent(sNamespace, pPtr->getTypeIdPtr()->getId()))
  51. {
  52. return "";
  53. }
  54. ostringstream s;
  55. if (_bStringBinaryEncoding && GET_CONST_GRAMMAR_PTR(pPtr)->t == CONST_GRAMMAR(STRING))
  56. {
  57. bNeedStream = true;
  58. }
  59. INC_TAB;
  60. s << TAB << "const " << pPtr->getTypeIdPtr()->getId() << ":"
  61. << getTsType(pPtr->getTypeIdPtr()->getTypePtr()) << ";"
  62. << endl;
  63. DEL_TAB;
  64. return s.str();
  65. }
  66. string CodeGenerator::generateDTS(const StructPtr &pPtr, const string &sNamespace)
  67. {
  68. if (_bMinimalMembers && !_bEntry && !isDependent(sNamespace, pPtr->getId()))
  69. {
  70. return "";
  71. }
  72. vector<TypeIdPtr> &member = pPtr->getAllMemberPtr();
  73. INC_TAB;
  74. ostringstream s;
  75. s << TAB << "class " << pPtr->getId() << " {" << endl;
  76. INC_TAB;
  77. for (size_t i = 0; i < member.size(); i++)
  78. {
  79. s << TAB << (member[i]->getId()) << ": " << getTsType(member[i]->getTypePtr()) << ";" << endl;
  80. }
  81. if (member.size() > 0)
  82. {
  83. s << endl;
  84. }
  85. /*
  86. * Size Optimize:
  87. * Remove <mutil_map> support.
  88. * Remove toBinBuffer, readFromObject, toObject, new, create members.
  89. */
  90. if (_iOptimizeLevel != Os)
  91. {
  92. s << TAB << "toObject(): " << pPtr->getId() << ".Object;" << endl;
  93. s << TAB << "readFromObject(json: " << pPtr->getId() << ".Object): " << pPtr->getId() << ";" << endl;
  94. s << TAB << "toBinBuffer(): " << IDL_NAMESPACE_STR << "Stream.BinBuffer;" << endl;
  95. s << TAB << "static new(): " << pPtr->getId() << ";" << endl;
  96. s << TAB << "static create(is: " << IDL_NAMESPACE_STR << "Stream." << IDL_TYPE << "InputStream): " << pPtr->getId() << ";" << endl;
  97. }
  98. DEL_TAB;
  99. s << TAB << "}" << endl << endl;
  100. s << TAB << "namespace " << pPtr->getId() << " {" << endl;
  101. INC_TAB;
  102. s << TAB << "interface Object {" << endl;
  103. INC_TAB;
  104. for (size_t i = 0; i < member.size(); i++)
  105. {
  106. const string &sType = getTsType(member[i]->getTypePtr(), false);
  107. s << TAB << (member[i]->getId()) << (member[i]->isRequire() ? ": " : "?: ") << (!sType.empty() ? sType : "never") << ";" << endl;
  108. }
  109. DEL_TAB;
  110. s << TAB << "}" << endl;
  111. DEL_TAB;
  112. s << TAB << "}" << endl;
  113. DEL_TAB;
  114. return s.str();
  115. }
  116. string CodeGenerator::generateDTS(const NamespacePtr &pPtr, bool &bNeedStream)
  117. {
  118. // struct
  119. ostringstream sstr;
  120. vector<StructPtr> ss(pPtr->getAllStructPtr());
  121. for (size_t last = 0; last != ss.size() && ss.size() != 0;)
  122. {
  123. last = ss.size();
  124. for (vector<StructPtr>::iterator iter=ss.begin(); iter!=ss.end();)
  125. {
  126. string str = generateDTS(*iter, pPtr->getId());
  127. if (!str.empty())
  128. {
  129. sstr << str << endl;
  130. iter = ss.erase(iter);
  131. }
  132. else
  133. {
  134. iter++;
  135. }
  136. }
  137. }
  138. // const
  139. ostringstream cstr;
  140. vector<ConstPtr> &cs = pPtr->getAllConstPtr();
  141. for (size_t i = 0; i < cs.size(); i++)
  142. {
  143. cstr << generateDTS(cs[i], pPtr->getId(), bNeedStream);
  144. }
  145. // enum
  146. ostringstream estr;
  147. vector<EnumPtr> &es = pPtr->getAllEnumPtr();
  148. for (size_t i = 0; i < es.size(); i++)
  149. {
  150. estr << generateDTS(es[i], pPtr->getId());
  151. }
  152. ostringstream kstr;
  153. if (!estr.str().empty()) kstr << estr.str() << endl;
  154. if (!cstr.str().empty()) kstr << cstr.str() << endl;
  155. if (!sstr.str().empty())
  156. {
  157. bNeedStream = true;
  158. kstr << sstr.str();
  159. }
  160. return kstr.str();
  161. }
  162. string CodeGenerator::generateDTS(const NamespacePtr &pPtr, const string &sContent)
  163. {
  164. ostringstream str;
  165. if (!sContent.empty())
  166. {
  167. str << "export namespace " << pPtr->getId() << " {" << endl;
  168. str << sContent;
  169. str << "}" << endl << endl;
  170. }
  171. return str.str();
  172. }
  173. void CodeGenerator::generateDTS(const ContextPtr &pPtr)
  174. {
  175. vector<NamespacePtr> namespaces = pPtr->getNamespaces();
  176. // generate encoders and decoders
  177. ostringstream estr;
  178. bool bNeedStream = false;
  179. for (size_t i = 0; i < namespaces.size(); i++)
  180. {
  181. estr << generateDTS(namespaces[i], generateDTS(namespaces[i], bNeedStream));
  182. }
  183. if (estr.str().empty())
  184. {
  185. return;
  186. }
  187. // generate module imports
  188. ostringstream ostr;
  189. if (bNeedStream)
  190. {
  191. ostr << "import * as " << IDL_NAMESPACE_STR << "Stream from \"" << _sStreamPath << "\";" << endl;
  192. }
  193. for (map<string, ImportFile>::iterator it = _mapFiles.begin(); it != _mapFiles.end(); it++)
  194. {
  195. if (it->second.sModule.empty()) continue;
  196. if (estr.str().find(it->second.sModule + ".") == string::npos) continue;
  197. ostr << "import * as " << it->second.sModule << " from \"" << TC_File::excludeFileExt(it->second.sFile) << "\";" << endl;
  198. }
  199. // concat generated code
  200. ostringstream sstr;
  201. sstr << printHeaderRemark("Structure");
  202. sstr << DISABLE_TSLINT << endl;
  203. sstr << DISABLE_ESLINT << endl;
  204. sstr << endl;
  205. sstr << ostr.str() << endl;
  206. sstr << estr.str() << endl;
  207. string sFileName = TC_File::excludeFileExt(_sToPath + TC_File::extractFileName(pPtr->getFileName())) + IDL_TYPE + ".d.ts";
  208. TC_File::makeDirRecursive(_sToPath);
  209. makeUTF8File(sFileName, sstr.str());
  210. }