mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-11-01 00:17:01 +00:00
ugh, my last patch just sped up a method and changed all the clients
that I want to completely eliminate. Add fixme's so I remember this in the future, and add the missing helper that they should be upgraded to use instead. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93300 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -102,6 +102,9 @@ public:
|
|||||||
/// specified suffix. If 'ForcePrivate' is specified, the label is specified
|
/// specified suffix. If 'ForcePrivate' is specified, the label is specified
|
||||||
/// to have a private label prefix.
|
/// to have a private label prefix.
|
||||||
///
|
///
|
||||||
|
/// FIXME: This is deprecated, new code should use getNameWithPrefix and use
|
||||||
|
/// MCSymbol printing to handle quotes or not etc.
|
||||||
|
///
|
||||||
std::string getMangledName(const GlobalValue *V, const char *Suffix = "",
|
std::string getMangledName(const GlobalValue *V, const char *Suffix = "",
|
||||||
bool ForcePrivate = false);
|
bool ForcePrivate = false);
|
||||||
|
|
||||||
@@ -112,6 +115,9 @@ public:
|
|||||||
/// does this for you, so there's no point calling it on the result
|
/// does this for you, so there's no point calling it on the result
|
||||||
/// from getValueName.
|
/// from getValueName.
|
||||||
///
|
///
|
||||||
|
/// FIXME: This is deprecated, new code should use getNameWithPrefix and use
|
||||||
|
/// MCSymbol printing to handle quotes or not etc.
|
||||||
|
///
|
||||||
void makeNameProper(SmallVectorImpl<char> &OutName,
|
void makeNameProper(SmallVectorImpl<char> &OutName,
|
||||||
const Twine &Name,
|
const Twine &Name,
|
||||||
ManglerPrefixTy PrefixTy = Mangler::Default);
|
ManglerPrefixTy PrefixTy = Mangler::Default);
|
||||||
@@ -121,6 +127,12 @@ public:
|
|||||||
/// have a name, this fills in a unique name for the global.
|
/// have a name, this fills in a unique name for the global.
|
||||||
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const GlobalValue *GV,
|
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const GlobalValue *GV,
|
||||||
bool isImplicitlyPrivate);
|
bool isImplicitlyPrivate);
|
||||||
|
|
||||||
|
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
||||||
|
/// and the specified name as the global variable name. GVName must not be
|
||||||
|
/// empty.
|
||||||
|
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const Twine &GVName,
|
||||||
|
ManglerPrefixTy PrefixTy = Mangler::Default);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // End llvm namespace
|
} // End llvm namespace
|
||||||
|
|||||||
@@ -34,6 +34,9 @@ static void MangleLetter(SmallVectorImpl<char> &OutName, unsigned char C) {
|
|||||||
/// makeNameProper - We don't want identifier names non-C-identifier characters
|
/// makeNameProper - We don't want identifier names non-C-identifier characters
|
||||||
/// in them, so mangle them as appropriate.
|
/// in them, so mangle them as appropriate.
|
||||||
///
|
///
|
||||||
|
/// FIXME: This is deprecated, new code should use getNameWithPrefix and use
|
||||||
|
/// MCSymbol printing to handle quotes or not etc.
|
||||||
|
///
|
||||||
void Mangler::makeNameProper(SmallVectorImpl<char> &OutName,
|
void Mangler::makeNameProper(SmallVectorImpl<char> &OutName,
|
||||||
const Twine &TheName,
|
const Twine &TheName,
|
||||||
ManglerPrefixTy PrefixTy) {
|
ManglerPrefixTy PrefixTy) {
|
||||||
@@ -151,6 +154,9 @@ void Mangler::makeNameProper(SmallVectorImpl<char> &OutName,
|
|||||||
/// specified suffix. If 'ForcePrivate' is specified, the label is specified
|
/// specified suffix. If 'ForcePrivate' is specified, the label is specified
|
||||||
/// to have a private label prefix.
|
/// to have a private label prefix.
|
||||||
///
|
///
|
||||||
|
/// FIXME: This is deprecated, new code should use getNameWithPrefix and use
|
||||||
|
/// MCSymbol printing to handle quotes or not etc.
|
||||||
|
///
|
||||||
std::string Mangler::getMangledName(const GlobalValue *GV, const char *Suffix,
|
std::string Mangler::getMangledName(const GlobalValue *GV, const char *Suffix,
|
||||||
bool ForcePrivate) {
|
bool ForcePrivate) {
|
||||||
assert((!isa<Function>(GV) || !cast<Function>(GV)->isIntrinsic()) &&
|
assert((!isa<Function>(GV) || !cast<Function>(GV)->isIntrinsic()) &&
|
||||||
@@ -176,6 +182,37 @@ std::string Mangler::getMangledName(const GlobalValue *GV, const char *Suffix,
|
|||||||
return Result.str().str();
|
return Result.str().str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
||||||
|
/// and the specified name as the global variable name. GVName must not be
|
||||||
|
/// empty.
|
||||||
|
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
||||||
|
const Twine &GVName, ManglerPrefixTy PrefixTy) {
|
||||||
|
SmallString<256> TmpData;
|
||||||
|
GVName.toVector(TmpData);
|
||||||
|
StringRef Name = TmpData.str();
|
||||||
|
assert(!Name.empty() && "getNameWithPrefix requires non-empty name");
|
||||||
|
|
||||||
|
// If the global name is not led with \1, add the appropriate prefixes.
|
||||||
|
if (Name[0] != '\1') {
|
||||||
|
if (PrefixTy == Mangler::Private)
|
||||||
|
OutName.append(PrivatePrefix, PrivatePrefix+strlen(PrivatePrefix));
|
||||||
|
else if (PrefixTy == Mangler::LinkerPrivate)
|
||||||
|
OutName.append(LinkerPrivatePrefix,
|
||||||
|
LinkerPrivatePrefix+strlen(LinkerPrivatePrefix));
|
||||||
|
|
||||||
|
if (Prefix[0] == 0)
|
||||||
|
; // Common noop, no prefix.
|
||||||
|
else if (Prefix[1] == 0)
|
||||||
|
OutName.push_back(Prefix[0]); // Common, one character prefix.
|
||||||
|
else
|
||||||
|
OutName.append(Prefix, Prefix+strlen(Prefix)); // Arbitrary prefix.
|
||||||
|
} else {
|
||||||
|
Name = Name.substr(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
OutName.append(Name.begin(), Name.end());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
||||||
/// and the specified global variable's name. If the global variable doesn't
|
/// and the specified global variable's name. If the global variable doesn't
|
||||||
@@ -183,33 +220,28 @@ std::string Mangler::getMangledName(const GlobalValue *GV, const char *Suffix,
|
|||||||
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
||||||
const GlobalValue *GV,
|
const GlobalValue *GV,
|
||||||
bool isImplicitlyPrivate) {
|
bool isImplicitlyPrivate) {
|
||||||
|
// If this global has a name, handle it simply.
|
||||||
// If the global is anonymous or not led with \1, then add the appropriate
|
|
||||||
// prefix.
|
|
||||||
if (!GV->hasName() || GV->getName()[0] != '\1') {
|
|
||||||
if (GV->hasPrivateLinkage() || isImplicitlyPrivate)
|
|
||||||
OutName.append(PrivatePrefix, PrivatePrefix+strlen(PrivatePrefix));
|
|
||||||
else if (GV->hasLinkerPrivateLinkage())
|
|
||||||
OutName.append(LinkerPrivatePrefix,
|
|
||||||
LinkerPrivatePrefix+strlen(LinkerPrivatePrefix));;
|
|
||||||
OutName.append(Prefix, Prefix+strlen(Prefix));
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the global has a name, just append it now.
|
|
||||||
if (GV->hasName()) {
|
if (GV->hasName()) {
|
||||||
StringRef Name = GV->getName();
|
ManglerPrefixTy PrefixTy = Mangler::Default;
|
||||||
|
if (GV->hasPrivateLinkage() || isImplicitlyPrivate)
|
||||||
|
PrefixTy = Mangler::Private;
|
||||||
|
else if (GV->hasLinkerPrivateLinkage())
|
||||||
|
PrefixTy = Mangler::LinkerPrivate;
|
||||||
|
|
||||||
// Strip off the prefix marker if present.
|
return getNameWithPrefix(OutName, GV->getName(), PrefixTy);
|
||||||
if (Name[0] != '\1')
|
|
||||||
OutName.append(Name.begin(), Name.end());
|
|
||||||
else
|
|
||||||
OutName.append(Name.begin()+1, Name.end());
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the global variable doesn't have a name, return a unique name for the
|
// If the global variable doesn't have a name, return a unique name for the
|
||||||
// global based on a numbering.
|
// global based on a numbering.
|
||||||
|
|
||||||
|
// Anonymous names always get prefixes.
|
||||||
|
if (GV->hasPrivateLinkage() || isImplicitlyPrivate)
|
||||||
|
OutName.append(PrivatePrefix, PrivatePrefix+strlen(PrivatePrefix));
|
||||||
|
else if (GV->hasLinkerPrivateLinkage())
|
||||||
|
OutName.append(LinkerPrivatePrefix,
|
||||||
|
LinkerPrivatePrefix+strlen(LinkerPrivatePrefix));;
|
||||||
|
OutName.append(Prefix, Prefix+strlen(Prefix));
|
||||||
|
|
||||||
// Get the ID for the global, assigning a new one if we haven't got one
|
// Get the ID for the global, assigning a new one if we haven't got one
|
||||||
// already.
|
// already.
|
||||||
unsigned &ID = AnonGlobalIDs[GV];
|
unsigned &ID = AnonGlobalIDs[GV];
|
||||||
|
|||||||
Reference in New Issue
Block a user