TarsCloud_TarsCpp/tools/tars2node/gen_js_dts.cpp
ruanshudong d2488da313 modify demo CMakeLists.txt
close TARS_SSL TARS_HTTP2 default
2020-03-18 17:09:27 +08:00

243 lines
7.0 KiB
C++

/**
* Tencent is pleased to support the open source community by making Tars available.
*
* Copyright (C) 2016THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* https://opensource.org/licenses/BSD-3-Clause
*
* Unless required by applicable law or agreed to in writing, software distributed
* under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*/
#include "code_generator.h"
string CodeGenerator::generateDTS(const EnumPtr &pPtr, const string &sNamespace)
{
ostringstream s;
INC_TAB;
s << TAB << (_bEnumReverseMappings ? "enum " : "const enum ") << pPtr->getId() << " {" << endl;
INC_TAB;
int nenum = -1;
bool bDependent = false;
vector<TypeIdPtr>& member = pPtr->getAllMemberPtr();
for (size_t i = 0; i < member.size(); i++)
{
bDependent |= isDependent(sNamespace, member[i]->getId());
if (member[i]->hasDefault())
{
nenum = TC_Common::strto<int>(member[i]->def());
}
else
{
nenum++;
}
s << TAB << member[i]->getId() << " = " << TC_Common::tostr(nenum) << ((i < member.size() - 1) ? "," : "") << endl;
}
DEL_TAB;
s << TAB << "}" << endl;
DEL_TAB;
if (!_bMinimalMembers || _bEntry || bDependent || isDependent(sNamespace, pPtr->getId())) {
return s.str();
} else {
return "";
}
}
string CodeGenerator::generateDTS(const ConstPtr &pPtr, const string &sNamespace, bool &bNeedStream)
{
if (_bMinimalMembers && !_bEntry && !isDependent(sNamespace, pPtr->getTypeIdPtr()->getId()))
{
return "";
}
ostringstream s;
if (_bStringBinaryEncoding && GET_CONST_GRAMMAR_PTR(pPtr)->t == CONST_GRAMMAR(STRING))
{
bNeedStream = true;
}
INC_TAB;
s << TAB << "const " << pPtr->getTypeIdPtr()->getId() << ":"
<< getTsType(pPtr->getTypeIdPtr()->getTypePtr()) << ";"
<< endl;
DEL_TAB;
return s.str();
}
string CodeGenerator::generateDTS(const StructPtr &pPtr, const string &sNamespace)
{
if (_bMinimalMembers && !_bEntry && !isDependent(sNamespace, pPtr->getId()))
{
return "";
}
vector<TypeIdPtr> &member = pPtr->getAllMemberPtr();
INC_TAB;
ostringstream s;
s << TAB << "class " << pPtr->getId() << " {" << endl;
INC_TAB;
for (size_t i = 0; i < member.size(); i++)
{
s << TAB << (member[i]->getId()) << ": " << getTsType(member[i]->getTypePtr()) << ";" << endl;
}
if (member.size() > 0)
{
s << endl;
}
/*
* Size Optimize:
* Remove <mutil_map> support.
* Remove toBinBuffer, readFromObject, toObject, new, create members.
*/
if (_iOptimizeLevel != Os)
{
s << TAB << "toObject(): " << pPtr->getId() << ".Object;" << endl;
s << TAB << "readFromObject(json: " << pPtr->getId() << ".Object): " << pPtr->getId() << ";" << endl;
s << TAB << "toBinBuffer(): " << IDL_NAMESPACE_STR << "Stream.BinBuffer;" << endl;
s << TAB << "static new(): " << pPtr->getId() << ";" << endl;
s << TAB << "static create(is: " << IDL_NAMESPACE_STR << "Stream." << IDL_TYPE << "InputStream): " << pPtr->getId() << ";" << endl;
}
DEL_TAB;
s << TAB << "}" << endl << endl;
s << TAB << "namespace " << pPtr->getId() << " {" << endl;
INC_TAB;
s << TAB << "interface Object {" << endl;
INC_TAB;
for (size_t i = 0; i < member.size(); i++)
{
const string &sType = getTsType(member[i]->getTypePtr(), false);
s << TAB << (member[i]->getId()) << (member[i]->isRequire() ? ": " : "?: ") << (!sType.empty() ? sType : "never") << ";" << endl;
}
DEL_TAB;
s << TAB << "}" << endl;
DEL_TAB;
s << TAB << "}" << endl;
DEL_TAB;
return s.str();
}
string CodeGenerator::generateDTS(const NamespacePtr &pPtr, bool &bNeedStream)
{
// struct
ostringstream sstr;
vector<StructPtr> ss(pPtr->getAllStructPtr());
for (size_t last = 0; last != ss.size() && ss.size() != 0;)
{
last = ss.size();
for (vector<StructPtr>::iterator iter=ss.begin(); iter!=ss.end();)
{
string str = generateDTS(*iter, pPtr->getId());
if (!str.empty())
{
sstr << str << endl;
iter = ss.erase(iter);
}
else
{
iter++;
}
}
}
// const
ostringstream cstr;
vector<ConstPtr> &cs = pPtr->getAllConstPtr();
for (size_t i = 0; i < cs.size(); i++)
{
cstr << generateDTS(cs[i], pPtr->getId(), bNeedStream);
}
// enum
ostringstream estr;
vector<EnumPtr> &es = pPtr->getAllEnumPtr();
for (size_t i = 0; i < es.size(); i++)
{
estr << generateDTS(es[i], pPtr->getId());
}
ostringstream kstr;
if (!estr.str().empty()) kstr << estr.str() << endl;
if (!cstr.str().empty()) kstr << cstr.str() << endl;
if (!sstr.str().empty())
{
bNeedStream = true;
kstr << sstr.str();
}
return kstr.str();
}
string CodeGenerator::generateDTS(const NamespacePtr &pPtr, const string &sContent)
{
ostringstream str;
if (!sContent.empty())
{
str << "export namespace " << pPtr->getId() << " {" << endl;
str << sContent;
str << "}" << endl << endl;
}
return str.str();
}
void CodeGenerator::generateDTS(const ContextPtr &pPtr)
{
vector<NamespacePtr> namespaces = pPtr->getNamespaces();
// generate encoders and decoders
ostringstream estr;
bool bNeedStream = false;
for (size_t i = 0; i < namespaces.size(); i++)
{
estr << generateDTS(namespaces[i], generateDTS(namespaces[i], bNeedStream));
}
if (estr.str().empty())
{
return;
}
// generate module imports
ostringstream ostr;
if (bNeedStream)
{
ostr << "import * as " << IDL_NAMESPACE_STR << "Stream from \"" << _sStreamPath << "\";" << endl;
}
for (map<string, ImportFile>::iterator it = _mapFiles.begin(); it != _mapFiles.end(); it++)
{
if (it->second.sModule.empty()) continue;
if (estr.str().find(it->second.sModule + ".") == string::npos) continue;
ostr << "import * as " << it->second.sModule << " from \"" << TC_File::excludeFileExt(it->second.sFile) << "\";" << endl;
}
// concat generated code
ostringstream sstr;
sstr << printHeaderRemark("Structure");
sstr << DISABLE_TSLINT << endl;
sstr << DISABLE_ESLINT << endl;
sstr << endl;
sstr << ostr.str() << endl;
sstr << estr.str() << endl;
string sFileName = TC_File::excludeFileExt(_sToPath + TC_File::extractFileName(pPtr->getFileName())) + IDL_TYPE + ".d.ts";
TC_File::makeDirRecursive(_sToPath);
makeUTF8File(sFileName, sstr.str());
}