[llvm-commits] CVS: llvm/lib/VMCore/Mangler.cpp
Chris Lattner
lattner at cs.uiuc.edu
Sat Sep 24 01:24:40 PDT 2005
Changes in directory llvm/lib/VMCore:
Mangler.cpp updated: 1.17 -> 1.18
---
Log message:
Add support for a marker byte that indicates that we shouldn't add the user
prefix to a symbol name
---
Diffs of the changes: (+12 -7)
Mangler.cpp | 19 ++++++++++++-------
1 files changed, 12 insertions(+), 7 deletions(-)
Index: llvm/lib/VMCore/Mangler.cpp
diff -u llvm/lib/VMCore/Mangler.cpp:1.17 llvm/lib/VMCore/Mangler.cpp:1.18
--- llvm/lib/VMCore/Mangler.cpp:1.17 Thu Apr 21 18:46:51 2005
+++ llvm/lib/VMCore/Mangler.cpp Sat Sep 24 03:24:28 2005
@@ -28,16 +28,21 @@
/// makeNameProper - We don't want identifier names non-C-identifier characters
/// in them, so mangle them as appropriate.
///
-std::string Mangler::makeNameProper(const std::string &X) {
+std::string Mangler::makeNameProper(const std::string &X, const char *Prefix) {
std::string Result;
- // Mangle the first letter specially, don't allow numbers...
- if ((X[0] < 'a' || X[0] > 'z') && (X[0] < 'A' || X[0] > 'Z') && X[0] != '_')
- Result += MangleLetter(X[0]);
+ // If X does not start with (char)1, add the prefix.
+ std::string::const_iterator I = X.begin();
+ if (*I != 1)
+ Result = Prefix;
else
- Result += X[0];
+ ++I; // Skip over the marker.
+
+ // Mangle the first letter specially, don't allow numbers...
+ if (*I >= '0' && *I <= '9')
+ Result += MangleLetter(*I++);
- for (std::string::const_iterator I = X.begin()+1, E = X.end(); I != E; ++I)
+ for (std::string::const_iterator E = X.end(); I != E; ++I)
if ((*I < 'a' || *I > 'z') && (*I < 'A' || *I > 'Z') &&
(*I < '0' || *I > '9') && *I != '_')
Result += MangleLetter(*I);
@@ -75,7 +80,7 @@
if (gv && isa<Function>(gv) && cast<Function>(gv)->getIntrinsicID()) {
name = gv->getName(); // Is an intrinsic function
} else if (gv && !gv->hasInternalLinkage() && !MangledGlobals.count(gv)) {
- name = Prefix + makeNameProper(gv->getName());
+ name = makeNameProper(gv->getName(), Prefix);
} else {
// Non-global, or global with internal linkage / colliding name
// -> mangle.
More information about the llvm-commits
mailing list