diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2004-12-05 19:15:29 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2004-12-05 19:15:29 +0000 |
commit | c191d497d54e42880ea662fff48759f53143f8ed (patch) | |
tree | 15e012eb8c6e862878d1aa9e6731a0e029f249f1 /tools/gccld | |
parent | 8bcd0502a3cad823a1521713b55d577ac0eb20f4 (diff) | |
download | external_llvm-c191d497d54e42880ea662fff48759f53143f8ed.zip external_llvm-c191d497d54e42880ea662fff48759f53143f8ed.tar.gz external_llvm-c191d497d54e42880ea662fff48759f53143f8ed.tar.bz2 |
Fix PR139:\
When not linking as a library, use LinkItems to retain command line order of \
linking, otherwise use LinkFiles
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18549 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/gccld')
-rw-r--r-- | tools/gccld/gccld.cpp | 41 |
1 files changed, 20 insertions, 21 deletions
diff --git a/tools/gccld/gccld.cpp b/tools/gccld/gccld.cpp index c1f430a..48fbd8b 100644 --- a/tools/gccld/gccld.cpp +++ b/tools/gccld/gccld.cpp @@ -168,31 +168,30 @@ int main(int argc, char **argv, char **envp) { int exitCode = 0; try { - std::string ModuleID("gccld-output"); - std::auto_ptr<Module> Composite(new Module(ModuleID)); - - // We always look first in the current directory when searching for - // libraries. - LibPaths.insert(LibPaths.begin(), "."); - - // If the user specified an extra search path in their environment, respect - // it. - if (char *SearchPath = getenv("LLVM_LIB_SEARCH_PATH")) - LibPaths.push_back(SearchPath); - // Remove any consecutive duplicates of the same library... Libraries.erase(std::unique(Libraries.begin(), Libraries.end()), Libraries.end()); - // Link in all of the files - if (LinkFiles(argv[0], Composite.get(), InputFilenames, Verbose)) - return 1; // Error already printed - - if (!LinkAsLibrary) - LinkLibraries(argv[0], Composite.get(), Libraries, LibPaths, - Verbose, Native); - - // Link in all of the libraries next... + // Set up the Composite module. + std::auto_ptr<Module> Composite(0); + + if (LinkAsLibrary) { + // Link in only the files, we ignore libraries in this case. + Composite.reset( new Module(argv[0]) ); + if (LinkFiles(argv[0], Composite.get(), InputFilenames, Verbose)) + return 1; // Error already printed + } else { + // Build a list of the items from our command line + LinkItemList Items; + BuildLinkItems(Items, InputFilenames, Libraries); + + // Link all the items together + Composite.reset( LinkItems(argv[0], Items, LibPaths, Verbose, Native) ); + + // Check for an error during linker + if (!Composite.get()) + return 1; // Error already printed + } // Create the output file. std::string RealBytecodeOutput = OutputFilename; |