mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
Mark the methods in the Mangler const.
A const ObjectFile needs to be able to provide its name. For an IRObjectFile, that means being able to call the mangler. Since each IRObjectFile can have a different mangling, it is natural for them to contain a Mangler which is therefore also const. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201113 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b89b11926c
commit
4822c5fa52
@ -39,11 +39,11 @@ private:
|
|||||||
/// they are mangled. This keeps track of the number we give to anonymous
|
/// they are mangled. This keeps track of the number we give to anonymous
|
||||||
/// ones.
|
/// ones.
|
||||||
///
|
///
|
||||||
DenseMap<const GlobalValue*, unsigned> AnonGlobalIDs;
|
mutable DenseMap<const GlobalValue*, unsigned> AnonGlobalIDs;
|
||||||
|
|
||||||
/// NextAnonGlobalID - This simple counter is used to unique value names.
|
/// NextAnonGlobalID - This simple counter is used to unique value names.
|
||||||
///
|
///
|
||||||
unsigned NextAnonGlobalID;
|
mutable unsigned NextAnonGlobalID;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Mangler(const DataLayout *DL) : DL(DL), NextAnonGlobalID(1) {}
|
Mangler(const DataLayout *DL) : DL(DL), NextAnonGlobalID(1) {}
|
||||||
@ -51,15 +51,16 @@ public:
|
|||||||
/// Print the appropriate prefix and the specified global variable's name.
|
/// Print 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
|
/// If the global variable doesn't have a name, this fills in a unique name
|
||||||
/// for the global.
|
/// for the global.
|
||||||
void getNameWithPrefix(raw_ostream &OS, const GlobalValue *GV);
|
void getNameWithPrefix(raw_ostream &OS, const GlobalValue *GV) const;
|
||||||
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const GlobalValue *GV);
|
void getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
||||||
|
const GlobalValue *GV) const;
|
||||||
|
|
||||||
/// Print the appropriate prefix and the specified name as the global variable
|
/// Print the appropriate prefix and the specified name as the global variable
|
||||||
/// name. GVName must not be empty.
|
/// name. GVName must not be empty.
|
||||||
void getNameWithPrefix(raw_ostream &OS, const Twine &GVName,
|
void getNameWithPrefix(raw_ostream &OS, const Twine &GVName,
|
||||||
ManglerPrefixTy PrefixTy = Mangler::Default);
|
ManglerPrefixTy PrefixTy = Mangler::Default) const;
|
||||||
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const Twine &GVName,
|
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const Twine &GVName,
|
||||||
ManglerPrefixTy PrefixTy = Mangler::Default);
|
ManglerPrefixTy PrefixTy = Mangler::Default) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // End llvm namespace
|
} // End llvm namespace
|
||||||
|
@ -44,13 +44,14 @@ static void getNameWithPrefixx(raw_ostream &OS, const Twine &GVName,
|
|||||||
OS << Name;
|
OS << Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Mangler::getNameWithPrefix(raw_ostream &OS,
|
void Mangler::getNameWithPrefix(raw_ostream &OS, const Twine &GVName,
|
||||||
const Twine &GVName, ManglerPrefixTy PrefixTy) {
|
ManglerPrefixTy PrefixTy) const {
|
||||||
return getNameWithPrefixx(OS, GVName, PrefixTy, *DL, false);
|
return getNameWithPrefixx(OS, GVName, PrefixTy, *DL, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
||||||
const Twine &GVName, ManglerPrefixTy PrefixTy) {
|
const Twine &GVName,
|
||||||
|
ManglerPrefixTy PrefixTy) const {
|
||||||
raw_svector_ostream OS(OutName);
|
raw_svector_ostream OS(OutName);
|
||||||
return getNameWithPrefix(OS, GVName, PrefixTy);
|
return getNameWithPrefix(OS, GVName, PrefixTy);
|
||||||
}
|
}
|
||||||
@ -75,7 +76,7 @@ static void AddFastCallStdCallSuffix(raw_ostream &OS, const Function *F,
|
|||||||
OS << '@' << ArgWords;
|
OS << '@' << ArgWords;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Mangler::getNameWithPrefix(raw_ostream &OS, const GlobalValue *GV) {
|
void Mangler::getNameWithPrefix(raw_ostream &OS, const GlobalValue *GV) const {
|
||||||
ManglerPrefixTy PrefixTy = Mangler::Default;
|
ManglerPrefixTy PrefixTy = Mangler::Default;
|
||||||
if (GV->hasPrivateLinkage())
|
if (GV->hasPrivateLinkage())
|
||||||
PrefixTy = Mangler::Private;
|
PrefixTy = Mangler::Private;
|
||||||
@ -133,7 +134,7 @@ void Mangler::getNameWithPrefix(raw_ostream &OS, const GlobalValue *GV) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
||||||
const GlobalValue *GV) {
|
const GlobalValue *GV) const {
|
||||||
raw_svector_ostream OS(OutName);
|
raw_svector_ostream OS(OutName);
|
||||||
getNameWithPrefix(OS, GV);
|
getNameWithPrefix(OS, GV);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user