aboutsummaryrefslogtreecommitdiffstats
path: root/tools/gccld/Linker.cpp
diff options
context:
space:
mode:
authorBrian Gaeke <gaeke@uiuc.edu>2003-11-11 21:54:01 +0000
committerBrian Gaeke <gaeke@uiuc.edu>2003-11-11 21:54:01 +0000
commit0d723acf15b0326e2df09ecb614b02a617f536e4 (patch)
tree122c71dd08da379c876d58325bd8cbb14997dfff /tools/gccld/Linker.cpp
parenta2302ffe78b2afe334f3b41eaf8a745b5608fa23 (diff)
downloadexternal_llvm-0d723acf15b0326e2df09ecb614b02a617f536e4.zip
external_llvm-0d723acf15b0326e2df09ecb614b02a617f536e4.tar.gz
external_llvm-0d723acf15b0326e2df09ecb614b02a617f536e4.tar.bz2
Move IsArchive, IsBytecode to FileUtilities. Fix up some method comments.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9902 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/gccld/Linker.cpp')
-rw-r--r--tools/gccld/Linker.cpp77
1 files changed, 17 insertions, 60 deletions
diff --git a/tools/gccld/Linker.cpp b/tools/gccld/Linker.cpp
index 7e8d655..06f0635 100644
--- a/tools/gccld/Linker.cpp
+++ b/tools/gccld/Linker.cpp
@@ -30,50 +30,15 @@
#include <memory>
#include <set>
-/// IsArchive - Returns true IFF the file named FN appears to be a "ar" library
-/// archive. The file named FN must exist.
+/// FindLib - Try to convert Filename into the name of a file that we can open,
+/// if it does not already name a file we can open, by first trying to open
+/// Filename, then libFilename.<suffix> for each of a set of several common
+/// library suffixes, in each of the directories in Paths and the directory
+/// named by the value of the environment variable LLVM_LIB_SEARCH_PATH. Returns
+/// an empty string if no matching file can be found.
///
-static inline bool IsArchive(const std::string &FN) {
- // Inspect the beginning of the file to see if it contains the "ar" magic
- // string.
- std::string Magic("!<arch>\012");
- char buf[1 + Magic.size()];
- std::ifstream f(FN.c_str());
- f.read(buf, Magic.size());
- buf[Magic.size()] = '\0';
- return Magic == buf;
-}
-
-/// IsBytecode - Returns true IFF the file named FN appears to be an
-/// LLVM bytecode file. The file named FN must exist.
-///
-static inline bool IsBytecode(const std::string &FN) {
- // Inspect the beginning of the file to see if it contains the LLVM
- // bytecode format magic string.
- std::string Magic("llvm");
- char buf[1 + Magic.size()];
- std::ifstream f(FN.c_str());
- f.read(buf, Magic.size());
- buf[Magic.size()] = '\0';
- return Magic == buf;
-}
-
-/// FindLib - locates a particular library. It will prepend and append
-/// various directories, prefixes, and suffixes until it can find the library.
-///
-/// Inputs:
-/// Filename - Name of the file to find.
-/// Paths - List of directories to search.
-///
-/// Outputs:
-/// None.
-///
-/// Return value:
-/// The name of the file is returned.
-/// If the file is not found, an empty string is returned.
-///
-static std::string
-FindLib(const std::string &Filename, const std::vector<std::string> &Paths) {
+static std::string FindLib(const std::string &Filename,
+ const std::vector<std::string> &Paths) {
// Determine if the pathname can be found as it stands.
if (FileOpenable(Filename))
return Filename;
@@ -165,25 +130,17 @@ GetAllUndefinedSymbols(Module *M, std::set<std::string> &UndefinedSymbols) {
}
-/// LoadObject - reads the specified bytecode object file.
-///
-/// Inputs:
-/// FN - The name of the file to load.
+/// LoadObject - Read in and parse the bytecode file named by FN and return the
+/// module it contains (wrapped in an auto_ptr), or 0 and set ErrorMessage if an
+/// error occurs.
///
-/// Outputs:
-/// OutErrorMessage - The error message to give back to the caller.
-///
-/// Return Value:
-/// A pointer to a module represening the bytecode file is returned.
-/// If an error occurs, the pointer is 0.
-///
-std::auto_ptr<Module>
-LoadObject(const std::string & FN, std::string &OutErrorMessage) {
- std::string ErrorMessage;
- Module *Result = ParseBytecodeFile(FN, &ErrorMessage);
+std::auto_ptr<Module> LoadObject(const std::string &FN,
+ std::string &ErrorMessage) {
+ std::string ParserErrorMessage;
+ Module *Result = ParseBytecodeFile(FN, &ParserErrorMessage);
if (Result) return std::auto_ptr<Module>(Result);
- OutErrorMessage = "Bytecode file '" + FN + "' corrupt!";
- if (ErrorMessage.size()) OutErrorMessage += ": " + ErrorMessage;
+ ErrorMessage = "Bytecode file '" + FN + "' could not be loaded";
+ if (ParserErrorMessage.size()) ErrorMessage += ": " + ParserErrorMessage;
return std::auto_ptr<Module>();
}