From 61f160a84e068fde0c3b1f706d43381851dbe14e Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 16 Jan 2010 18:06:34 +0000 Subject: [PATCH] add an inefficient version of getNameWithPrefix that returns an std::string. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93641 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Support/Mangler.h | 5 +++++ lib/VMCore/Mangler.cpp | 10 ++++++++++ 2 files changed, 15 insertions(+) diff --git a/include/llvm/Support/Mangler.h b/include/llvm/Support/Mangler.h index aa230d48e86..252a707699c 100644 --- a/include/llvm/Support/Mangler.h +++ b/include/llvm/Support/Mangler.h @@ -120,6 +120,11 @@ public: void getNameWithPrefix(SmallVectorImpl &OutName, const Twine &GVName, ManglerPrefixTy PrefixTy = Mangler::Default); + /// getNameWithPrefix - Return the name of the appropriate prefix + /// and the specified global variable's name. If the global variable doesn't + /// have a name, this fills in a unique name for the global. + std::string getNameWithPrefix(const GlobalValue *GV,bool isImplicitlyPrivate); + private: /// makeNameProper - We don't want identifier names with ., space, or /// - in them, so we mangle these characters into the strings "d_", diff --git a/lib/VMCore/Mangler.cpp b/lib/VMCore/Mangler.cpp index 7d9f330f4c4..9f6c9605076 100644 --- a/lib/VMCore/Mangler.cpp +++ b/lib/VMCore/Mangler.cpp @@ -249,6 +249,16 @@ void Mangler::getNameWithPrefix(SmallVectorImpl &OutName, raw_svector_ostream(OutName) << "__unnamed_" << ID; } +/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix +/// and the specified global variable's name. If the global variable doesn't +/// have a name, this fills in a unique name for the global. +std::string Mangler::getNameWithPrefix(const GlobalValue *GV, + bool isImplicitlyPrivate) { + SmallString<64> Buf; + getNameWithPrefix(Buf, GV, isImplicitlyPrivate); + return std::string(Buf.begin(), Buf.end()); +} + Mangler::Mangler(Module &M, const char *prefix, const char *privatePrefix, const char *linkerPrivatePrefix)