diff options
author | Alon Zakai <alonzakai@gmail.com> | 2013-12-02 20:04:19 -0500 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2013-12-02 20:04:19 -0500 |
commit | 3e52819f36ce4ff6a173874762c66de7339d5442 (patch) | |
tree | eee76ea93d179e99254cb65be484bcf32dbecf33 /lib/Target/CppBackend/CPPBackend.cpp | |
parent | ecaeed511cc78f577ae11c7c3caba61a3ed8b501 (diff) |
use externs for fastcomp vars and declare for fastcomp funcs
Diffstat (limited to 'lib/Target/CppBackend/CPPBackend.cpp')
-rw-r--r-- | lib/Target/CppBackend/CPPBackend.cpp | 24 |
1 files changed, 6 insertions, 18 deletions
diff --git a/lib/Target/CppBackend/CPPBackend.cpp b/lib/Target/CppBackend/CPPBackend.cpp index 1b69ce7ee6..9a7eb4a25a 100644 --- a/lib/Target/CppBackend/CPPBackend.cpp +++ b/lib/Target/CppBackend/CPPBackend.cpp @@ -138,8 +138,8 @@ namespace { HeapData GlobalData32; HeapData GlobalData64; GlobalAddressMap GlobalAddresses; - NameSet ExternalVars, ExternalFuncs; - NameSet Declares; + NameSet Externals; // vars + NameSet Declares; // funcs std::string PostSets; #include "CallHandlers.h" @@ -244,7 +244,7 @@ namespace { // We don't have a constant to emit here, so we must emit a postSet // All postsets are of external values, so they are pointers, hence 32-bit std::string Name = getOpName(V); - ExternalVars.insert(Name); + Externals.insert(Name); PostSets += "HEAP32[" + utostr(AbsoluteTarget>>2) + "] = " + Name + ';'; return 0; // emit zero in there for now, until the postSet } @@ -259,7 +259,7 @@ namespace { if (const GlobalValue *GV = dyn_cast<GlobalValue>(Ptr)) { if (GV->hasExternalLinkage()) { std::string Name = getOpName(Ptr); - ExternalVars.insert(Name); + Externals.insert(Name); return Name; } } @@ -2344,21 +2344,9 @@ void CppWriter::printModuleBody() { Out << "\"" + *I + "\""; } Out << "],"; - Out << "\"externVars\": ["; + Out << "\"externs\": ["; first = true; - for (NameSet::iterator I = ExternalVars.begin(), E = ExternalVars.end(); - I != E; ++I) { - if (first) { - first = false; - } else { - Out << ", "; - } - Out << "\"" + *I + "\""; - } - Out << "],"; - Out << "\"externFuncs\": ["; - first = true; - for (NameSet::iterator I = ExternalFuncs.begin(), E = ExternalFuncs.end(); + for (NameSet::iterator I = Externals.begin(), E = Externals.end(); I != E; ++I) { if (first) { first = false; |