diff options
| author | Anton Korobeynikov <asl@math.spbu.ru> | 2008-03-04 20:16:11 +0000 |
|---|---|---|
| committer | Anton Korobeynikov <asl@math.spbu.ru> | 2008-03-04 20:16:11 +0000 |
| commit | 555f071a9972a7d8403b3d0a2604f8c89aa436e9 (patch) | |
| tree | f703baa328ca4bf8bbf2d23ddefbd15d0263b5a2 | |
| parent | b39d368285a4fedb98cb0f08bf0a2d45d2408896 (diff) | |
| download | external_llvm-555f071a9972a7d8403b3d0a2604f8c89aa436e9.zip external_llvm-555f071a9972a7d8403b3d0a2604f8c89aa436e9.tar.gz external_llvm-555f071a9972a7d8403b3d0a2604f8c89aa436e9.tar.bz2 | |
Properly populate lists of defined/undefined symbols in presence of aliases
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47900 91177308-0d34-0410-b5e6-96231b3b80d8
| -rw-r--r-- | lib/Linker/LinkArchives.cpp | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/lib/Linker/LinkArchives.cpp b/lib/Linker/LinkArchives.cpp index 974ad26..308a775 100644 --- a/lib/Linker/LinkArchives.cpp +++ b/lib/Linker/LinkArchives.cpp @@ -56,6 +56,7 @@ GetAllUndefinedSymbols(Module *M, std::set<std::string> &UndefinedSymbols) { DefinedSymbols.insert(I->getName()); } } + for (Module::global_iterator I = M->global_begin(), E = M->global_end(); I != E; ++I) if (I->hasName()) { @@ -68,6 +69,16 @@ GetAllUndefinedSymbols(Module *M, std::set<std::string> &UndefinedSymbols) { } } + for (Module::alias_iterator I = M->alias_begin(), E = M->alias_end(); + I != E; ++I) + if (I->hasName()) { + const GlobalValue *Aliased = I->getAliasedGlobal(); + if (Aliased->isDeclaration()) + UndefinedSymbols.insert(I->getName()); + else + DefinedSymbols.insert(I->getName()); + } + // Prune out any defined symbols from the undefined symbols set... for (std::set<std::string>::iterator I = UndefinedSymbols.begin(); I != UndefinedSymbols.end(); ) @@ -88,7 +99,6 @@ GetAllUndefinedSymbols(Module *M, std::set<std::string> &UndefinedSymbols) { /// FALSE - No errors. bool Linker::LinkInArchive(const sys::Path &Filename, bool &is_native) { - // Make sure this is an archive file we're dealing with if (!Filename.isArchive()) return error("File '" + Filename.toString() + "' is not an archive."); |
