diff options
author | Chris Lattner <sabre@nondot.org> | 2005-03-15 22:55:17 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-03-15 22:55:17 +0000 |
commit | fc82ef67971403c01f19e672b6af8d2a5caf8a30 (patch) | |
tree | b03e7d6b3c2926c8dadec3b7a5e2a3ec02bf1826 /lib/Linker | |
parent | ad988f397d63c99cf141eee0f9e6743f53543842 (diff) | |
download | external_llvm-fc82ef67971403c01f19e672b6af8d2a5caf8a30.zip external_llvm-fc82ef67971403c01f19e672b6af8d2a5caf8a30.tar.gz external_llvm-fc82ef67971403c01f19e672b6af8d2a5caf8a30.tar.bz2 |
consolidate LinkFiles into LinkItems, use lib_* iterators.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20630 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Linker')
-rw-r--r-- | lib/Linker/LinkFiles.cpp | 81 | ||||
-rw-r--r-- | lib/Linker/LinkItems.cpp | 65 |
2 files changed, 61 insertions, 85 deletions
diff --git a/lib/Linker/LinkFiles.cpp b/lib/Linker/LinkFiles.cpp deleted file mode 100644 index 2868346..0000000 --- a/lib/Linker/LinkFiles.cpp +++ /dev/null @@ -1,81 +0,0 @@ -//===- lib/Linker/LinkFiles.cpp - Link LLVM bytecode files ---------------===// -// -// The LLVM Compiler Infrastructure -// -// This file was developed by Reid Spencer and is distributed under the -// University of Illinois Open Source License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file contains routines to handle linking together LLVM bytecode files. -// -//===----------------------------------------------------------------------===// - -#include "llvm/Linker.h" -#include "llvm/Module.h" - -using namespace llvm; - -/// LinkInFile - opens a bytecode file and links in all objects which -/// provide symbols that are currently undefined. -/// -/// Inputs: -/// File - The pathname of the bytecode file. -/// -/// Outputs: -/// ErrorMessage - A C++ string detailing what error occurred, if any. -/// -/// Return Value: -/// TRUE - An error occurred. -/// FALSE - No errors. -/// -bool -Linker::LinkInFile(const sys::Path &File) -{ - // Make sure we can at least read the file - if (!File.readable()) - return error("Cannot find linker input '" + File.toString() + "'"); - - // A user may specify an ar archive without -l, perhaps because it - // is not installed as a library. Detect that and link the library. - if (File.isArchive()) { - if (LinkInArchive(File)) - return error("Cannot link archive '" + File.toString() + "'"); - } else if (File.isBytecodeFile()) { - verbose("Linking bytecode file '" + File.toString() + "'"); - - std::auto_ptr<Module> M(LoadObject(File)); - if (M.get() == 0) - return error("Cannot load file '" + File.toString() + "'" + Error); - if (LinkInModule(M.get())) - return error("Cannot link file '" + File.toString() + "'" + Error); - - verbose("Linked in file '" + File.toString() + "'"); - } else { - return warning("File of unknown type '" + File.toString() + "' ignored."); - } - return false; -} - -/// LinkFiles - takes a module and a list of files and links them all together. -/// It locates the file either in the current directory, as its absolute -/// or relative pathname, or as a file somewhere in LLVM_LIB_SEARCH_PATH. -/// -/// Inputs: -/// Files - A vector of sys::Path indicating the LLVM bytecode filenames -/// to be linked. The names can refer to a mixture of pure LLVM -/// bytecode files and archive (ar) formatted files. -/// -/// Return value: -/// FALSE - No errors. -/// TRUE - Some error occurred. -/// -bool -Linker::LinkInFiles(const std::vector<sys::Path> &Files) -{ - for (unsigned i = 0; i < Files.size(); ++i) { - if (LinkInFile(Files[i])) - return true; - } - return false; -} diff --git a/lib/Linker/LinkItems.cpp b/lib/Linker/LinkItems.cpp index 2899d69..b3fb5b0 100644 --- a/lib/Linker/LinkItems.cpp +++ b/lib/Linker/LinkItems.cpp @@ -38,12 +38,10 @@ Linker::LinkInItems(const ItemList& Items) { // that module should also be aggregated with duplicates eliminated. This is // now the time to process the dependent libraries to resolve any remaining // symbols. - const Module::LibraryListType& DepLibs = Composite->getLibraries(); - for (Module::LibraryListType::const_iterator I = DepLibs.begin(), - E = DepLibs.end(); I != E; ++I) { + for (Module::lib_iterator I = Composite->lib_begin(), + E = Composite->lib_end(); I != E; ++I) if(LinkInLibrary(*I)) return true; - } return false; } @@ -104,3 +102,62 @@ bool Linker::LinkInLibraries(const std::vector<std::string> &Libraries) { return false; } + +/// LinkInFile - opens a bytecode file and links in all objects which +/// provide symbols that are currently undefined. +/// +/// Inputs: +/// File - The pathname of the bytecode file. +/// +/// Outputs: +/// ErrorMessage - A C++ string detailing what error occurred, if any. +/// +/// Return Value: +/// TRUE - An error occurred. +/// FALSE - No errors. +/// +bool Linker::LinkInFile(const sys::Path &File) { + // Make sure we can at least read the file + if (!File.readable()) + return error("Cannot find linker input '" + File.toString() + "'"); + + // A user may specify an ar archive without -l, perhaps because it + // is not installed as a library. Detect that and link the library. + if (File.isArchive()) { + if (LinkInArchive(File)) + return error("Cannot link archive '" + File.toString() + "'"); + } else if (File.isBytecodeFile()) { + verbose("Linking bytecode file '" + File.toString() + "'"); + + std::auto_ptr<Module> M(LoadObject(File)); + if (M.get() == 0) + return error("Cannot load file '" + File.toString() + "'" + Error); + if (LinkInModule(M.get())) + return error("Cannot link file '" + File.toString() + "'" + Error); + + verbose("Linked in file '" + File.toString() + "'"); + } else { + return warning("File of unknown type '" + File.toString() + "' ignored."); + } + return false; +} + +/// LinkFiles - takes a module and a list of files and links them all together. +/// It locates the file either in the current directory, as its absolute +/// or relative pathname, or as a file somewhere in LLVM_LIB_SEARCH_PATH. +/// +/// Inputs: +/// Files - A vector of sys::Path indicating the LLVM bytecode filenames +/// to be linked. The names can refer to a mixture of pure LLVM +/// bytecode files and archive (ar) formatted files. +/// +/// Return value: +/// FALSE - No errors. +/// TRUE - Some error occurred. +/// +bool Linker::LinkInFiles(const std::vector<sys::Path> &Files) { + for (unsigned i = 0; i < Files.size(); ++i) + if (LinkInFile(Files[i])) + return true; + return false; +} |