aboutsummaryrefslogtreecommitdiffstats
path: root/tools/gccld/Linker.cpp
diff options
context:
space:
mode:
authorBrian Gaeke <gaeke@uiuc.edu>2003-11-05 22:12:52 +0000
committerBrian Gaeke <gaeke@uiuc.edu>2003-11-05 22:12:52 +0000
commit3b3640a3733c6ecdba4a8ca2ca9d28a6ce957769 (patch)
tree2abf0752264ee3e0abbd86643961e4684841a7ce /tools/gccld/Linker.cpp
parent1548c35a5e5182d092fe7d05096f41a9c3d87cba (diff)
downloadexternal_llvm-3b3640a3733c6ecdba4a8ca2ca9d28a6ce957769.zip
external_llvm-3b3640a3733c6ecdba4a8ca2ca9d28a6ce957769.tar.gz
external_llvm-3b3640a3733c6ecdba4a8ca2ca9d28a6ce957769.tar.bz2
Shorten and correct some function-header comments.
Make "verbose" output MUCH nicer. Now it tells you when you are linking a bytecode file, or an archive, and whether it's because you called it by name, or because you gave it a -l option, and it says "Trying" before it takes action and prints a message in the past tense afterwards. Make LinkFiles not skip the first file in Files. Make LinkFiles warn you if it can't find a file and LLVM_LIB_SEARCH_PATH is unset. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9747 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/gccld/Linker.cpp')
-rw-r--r--tools/gccld/Linker.cpp81
1 files changed, 28 insertions, 53 deletions
diff --git a/tools/gccld/Linker.cpp b/tools/gccld/Linker.cpp
index d9c029a..75e3df3 100644
--- a/tools/gccld/Linker.cpp
+++ b/tools/gccld/Linker.cpp
@@ -30,39 +30,21 @@
#include <memory>
#include <set>
-/// FileExists - determines if the specified filename exists and is readable.
-///
-/// Inputs:
-/// FN - The name of the file.
-///
-/// Outputs:
-/// None.
-///
-/// Return Value:
-/// TRUE - The file exists and is readable.
-/// FALSE - The file does not exist or is unreadable.
+/// FileExists - Returns true IFF a file named FN exists and is readable.
///
static inline bool FileExists(const std::string &FN) {
return access(FN.c_str(), R_OK | F_OK) != -1;
}
-/// IsArchive - determines if the specified file is an ar archive
-/// by checking the magic string at the beginning of the file.
-///
-/// Inputs:
-/// filename - A C++ string containing the name of the file.
+/// IsArchive - Returns true IFF the file named FN appears to be a "ar" library
+/// archive. The file named FN must exist.
///
-/// Outputs:
-/// None.
-///
-/// Return value:
-/// TRUE - The file is an archive.
-/// FALSE - The file is not an archive.
-///
-static inline bool IsArchive(const std::string &filename) {
+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 ArchiveMagic("!<arch>\012");
char buf[1 + ArchiveMagic.size()];
- std::ifstream f(filename.c_str());
+ std::ifstream f(FN.c_str());
f.read(buf, ArchiveMagic.size());
buf[ArchiveMagic.size()] = '\0';
return ArchiveMagic == buf;
@@ -118,18 +100,8 @@ FindLib(const std::string &Filename, const std::vector<std::string> &Paths) {
return std::string();
}
-/// GetAllDefinedSymbols - finds all of the defined symbols in the specified
-/// module.
-///
-/// Inputs:
-/// M - The module in which to find defined symbols.
-///
-/// Outputs:
-/// DefinedSymbols - A set of C++ strings that will contain the name of all
-/// defined symbols.
-///
-/// Return value:
-/// None.
+/// GetAllDefinedSymbols - Modifies its parameter DefinedSymbols to contain the
+/// name of each externally-visible symbol defined in M.
///
void GetAllDefinedSymbols(Module *M, std::set<std::string> &DefinedSymbols) {
for (Module::iterator I = M->begin(), E = M->end(); I != E; ++I)
@@ -238,7 +210,7 @@ static bool LinkInArchive(Module *M,
}
// Load in the archive objects.
- if (Verbose) std::cerr << " Loading '" << Filename << "'\n";
+ if (Verbose) std::cerr << " Loading archive file '" << Filename << "'\n";
std::vector<Module*> Objects;
if (ReadArchiveFile(Filename, Objects, &ErrorMessage))
return true;
@@ -294,12 +266,12 @@ static bool LinkInArchive(Module *M,
return false;
}
-/// LinkInFile - opens an archive library and link in all objects which
+/// LinkInFile - opens a bytecode file and links in all objects which
/// provide symbols that are currently undefined.
///
/// Inputs:
-/// HeadModule - The module in which to link the archives.
-/// Filename - The pathname of the archive.
+/// HeadModule - The module in which to link the bytecode file.
+/// Filename - The pathname of the bytecode file.
/// Verbose - Flags whether verbose messages should be printed.
///
/// Outputs:
@@ -316,8 +288,9 @@ static bool LinkInFile(Module *HeadModule,
{
std::auto_ptr<Module> M(LoadObject(Filename, ErrorMessage));
if (M.get() == 0) return true;
- if (Verbose) std::cerr << "Linking in '" << Filename << "'\n";
- return LinkModules(HeadModule, M.get(), &ErrorMessage);
+ bool Result = LinkModules(HeadModule, M.get(), &ErrorMessage);
+ if (Verbose) std::cerr << "Linked in bytecode file '" << Filename << "'\n";
+ return Result;
}
/// LinkFiles - takes a module and a list of files and links them all together.
@@ -354,7 +327,7 @@ bool LinkFiles(const char *progname,
// Get the library search path from the environment
char *SearchPath = getenv("LLVM_LIB_SEARCH_PATH");
- for (unsigned i = 1; i < Files.size(); ++i) {
+ for (unsigned i = 0; i < Files.size(); ++i) {
// Determine where this file lives.
if (FileExists(Files[i])) {
Pathname = Files[i];
@@ -362,6 +335,8 @@ bool LinkFiles(const char *progname,
if (SearchPath == NULL) {
std::cerr << progname << ": Cannot find linker input file '"
<< Files[i] << "'\n";
+ std::cerr << progname
+ << ": Warning: Your LLVM_LIB_SEARCH_PATH is unset.\n";
return true;
}
@@ -377,20 +352,20 @@ bool LinkFiles(const char *progname,
// is not installed as a library. Detect that and link the library.
if (IsArchive(Pathname)) {
if (Verbose)
- std::cerr << "Linking archive '" << Files[i] << "'\n";
+ std::cerr << "Trying to link archive '" << Pathname << "'\n";
if (LinkInArchive(HeadModule, Pathname, ErrorMessage, Verbose)) {
PrintAndReturn(progname, ErrorMessage,
- ": Error linking in '" + Files[i] + "'");
+ ": Error linking in archive '" + Pathname + "'");
return true;
}
} else {
if (Verbose)
- std::cerr << "Linking file '" << Files[i] << "'\n";
+ std::cerr << "Trying to link bytecode file '" << Pathname << "'\n";
if (LinkInFile(HeadModule, Pathname, ErrorMessage, Verbose)) {
PrintAndReturn(progname, ErrorMessage,
- ": Error linking in '" + Files[i] + "'");
+ ": Error linking in bytecode file '" + Pathname + "'");
return true;
}
}
@@ -435,7 +410,7 @@ bool LinkLibraries(const char *progname,
// we're doing a native link and give an error if we're doing a bytecode
// link.
if (!Native) {
- PrintAndReturn(progname, "Cannot find " + Libraries[i] + "\n");
+ PrintAndReturn(progname, "Cannot find library -l" + Libraries[i] + "\n");
return true;
}
}
@@ -444,20 +419,20 @@ bool LinkLibraries(const char *progname,
// is not installed as a library. Detect that and link the library.
if (IsArchive(Pathname)) {
if (Verbose)
- std::cerr << "Linking archive '" << Libraries[i] << "'\n";
+ std::cerr << "Trying to link archive '" << Pathname << "' (-l" << Libraries[i] << ")\n";
if (LinkInArchive(HeadModule, Pathname, ErrorMessage, Verbose)) {
PrintAndReturn(progname, ErrorMessage,
- ": Error linking in '" + Libraries[i] + "'");
+ ": Error linking in archive '" + Pathname + "' (-l" + Libraries[i] + ")");
return true;
}
} else {
if (Verbose)
- std::cerr << "Linking file '" << Libraries[i] << "'\n";
+ std::cerr << "Trying to link bytecode file '" << Pathname << "' (-l" << Libraries[i] << ")\n";
if (LinkInFile(HeadModule, Pathname, ErrorMessage, Verbose)) {
PrintAndReturn(progname, ErrorMessage,
- ": error linking in '" + Libraries[i] + "'");
+ ": error linking in bytecode file '" + Pathname + "' (-l" + Libraries[i] + ")");
return true;
}
}