From ad988f397d63c99cf141eee0f9e6743f53543842 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 15 Mar 2005 22:51:40 +0000 Subject: [PATCH] consolidate LinkLibraries into LinkItems git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20629 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Linker/LinkItems.cpp | 57 +++++++++++++++++++++++++++ lib/Linker/LinkLibraries.cpp | 76 ------------------------------------ 2 files changed, 57 insertions(+), 76 deletions(-) delete mode 100644 lib/Linker/LinkLibraries.cpp diff --git a/lib/Linker/LinkItems.cpp b/lib/Linker/LinkItems.cpp index f43166c861b..2899d69eec1 100644 --- a/lib/Linker/LinkItems.cpp +++ b/lib/Linker/LinkItems.cpp @@ -47,3 +47,60 @@ Linker::LinkInItems(const ItemList& Items) { return false; } + + +/// LinkInLibrary - links one library into the HeadModule. +/// +bool Linker::LinkInLibrary(const std::string& Lib) { + // Determine where this library lives. + sys::Path Pathname = FindLib(Lib); + if (Pathname.isEmpty()) + return warning("Cannot find library '" + Lib + "'"); + + // If its an archive, try to link it in + if (Pathname.isArchive()) { + if (LinkInArchive(Pathname)) + return error("Cannot link archive '" + Pathname.toString() + "'"); + } else if (Pathname.isBytecodeFile()) { + // LLVM ".so" file. + if (LinkInFile(Pathname)) + return error("Cannot link file '" + Pathname.toString() + "'"); + + } else if (Pathname.isDynamicLibrary()) { + return warning("Library '" + Lib + "' is a native dynamic library."); + } else { + return warning("Supposed library '" + Lib + "' isn't a library."); + } + return false; +} + +/// LinkLibraries - takes the specified library files and links them into the +/// main bytecode object file. +/// +/// Inputs: +/// Libraries - The list of libraries to link into the module. +/// +/// Return value: +/// FALSE - No error. +/// TRUE - Error. +/// +bool Linker::LinkInLibraries(const std::vector &Libraries) { + + // Process the set of libraries we've been provided. + for (unsigned i = 0; i < Libraries.size(); ++i) + if (LinkInLibrary(Libraries[i])) + return true; + + // At this point we have processed all the libraries provided to us. Since + // we have an aggregated module at this point, the dependent libraries in + // 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) + if (LinkInLibrary(*I)) + return true; + + return false; +} diff --git a/lib/Linker/LinkLibraries.cpp b/lib/Linker/LinkLibraries.cpp deleted file mode 100644 index eb31fb96da0..00000000000 --- a/lib/Linker/LinkLibraries.cpp +++ /dev/null @@ -1,76 +0,0 @@ -//===- lib/Linker/LinkLibraries.cpp - Link LLVM libraries -----------------===// -// -// 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 finding libraries and linking them in. -// -//===----------------------------------------------------------------------===// - -#include "llvm/Linker.h" -#include "llvm/Module.h" - -using namespace llvm; - -/// LinkInLibrary - links one library into the HeadModule -bool -Linker::LinkInLibrary(const std::string& Lib) -{ - // Determine where this library lives. - sys::Path Pathname = FindLib(Lib); - if (Pathname.isEmpty()) - return warning("Cannot find library '" + Lib + "'"); - - // If its an archive, try to link it in - if (Pathname.isArchive()) { - if (LinkInArchive(Pathname)) - return error("Cannot link archive '" + Pathname.toString() + "'"); - } else if (Pathname.isBytecodeFile()) { - // LLVM ".so" file. - if (LinkInFile(Pathname)) - return error("Cannot link file '" + Pathname.toString() + "'"); - - } else if (Pathname.isDynamicLibrary()) { - return warning("Library '" + Lib + "' is a native dynamic library."); - } else { - return warning("Supposed library '" + Lib + "' isn't a library."); - } - return false; -} - -/// LinkLibraries - takes the specified library files and links them into the -/// main bytecode object file. -/// -/// Inputs: -/// Libraries - The list of libraries to link into the module. -/// -/// Return value: -/// FALSE - No error. -/// TRUE - Error. -/// -bool -Linker::LinkInLibraries(const std::vector &Libraries) { - - // Process the set of libraries we've been provided - for (unsigned i = 0; i < Libraries.size(); ++i) { - if (LinkInLibrary(Libraries[i])) - return true; - } - - // At this point we have processed all the libraries provided to us. Since - // we have an aggregated module at this point, the dependent libraries in - // 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) { - if (LinkInLibrary(*I)) - return true; - } - return false; -} -- 2.34.1