summaryrefslogtreecommitdiffstats
path: root/llvm/tools
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2001-12-08 20:31:32 +0000
committerChris Lattner <sabre@nondot.org>2001-12-08 20:31:32 +0000
commit5053ba9749b37c0f74b4aee802ce170595bf4dfb (patch)
tree9369eb709a0156f39f9350453fcc567409026830 /llvm/tools
parente51379766b16f91c038b5cb3690f07703ccd3d0a (diff)
downloadbcm5719-llvm-5053ba9749b37c0f74b4aee802ce170595bf4dfb.tar.gz
bcm5719-llvm-5053ba9749b37c0f74b4aee802ce170595bf4dfb.zip
Tell the user if a file is corrupt or not... not that the file cannot be
found. llvm-svn: 1433
Diffstat (limited to 'llvm/tools')
-rw-r--r--llvm/tools/link/link.cpp23
-rw-r--r--llvm/tools/llvm-link/llvm-link.cpp23
2 files changed, 44 insertions, 2 deletions
diff --git a/llvm/tools/link/link.cpp b/llvm/tools/link/link.cpp
index 9bf766fcaad..83141c86e7d 100644
--- a/llvm/tools/link/link.cpp
+++ b/llvm/tools/link/link.cpp
@@ -18,6 +18,8 @@
#include "Support/CommandLine.h"
#include <fstream>
#include <memory>
+#include <sys/types.h> // For FileExists
+#include <sys/stat.h>
cl::StringList InputFilenames("", "Load <arg> files, linking them together",
@@ -28,14 +30,26 @@ cl::Flag Verbose ("v", "Print information about actions taken");
cl::Flag DumpAsm ("d", "Print assembly as linked", cl::Hidden, false);
cl::StringList LibPaths ("L", "Specify a library search path", cl::ZeroOrMore);
+
+// FileExists - Return true if the specified string is an openable file...
+static inline bool FileExists(const string &FN) {
+ struct stat StatBuf;
+ return stat(FN.c_str(), &StatBuf) != -1;
+}
+
+// LoadFile - Read the specified bytecode file in and return it. This routine
+// searches the link path for the specified file to try to find it...
+//
static inline std::auto_ptr<Module> LoadFile(const string &FN) {
string Filename = FN;
string ErrorMessage;
unsigned NextLibPathIdx = 0;
+ bool FoundAFile = false;
while (1) {
if (Verbose) cerr << "Loading '" << Filename << "'\n";
+ if (FileExists(Filename)) FoundAFile = true;
Module *Result = ParseBytecodeFile(Filename, &ErrorMessage);
if (Result) return std::auto_ptr<Module>(Result); // Load successful!
@@ -49,10 +63,17 @@ static inline std::auto_ptr<Module> LoadFile(const string &FN) {
Filename = LibPaths[NextLibPathIdx++] + "/" + FN;
}
- cerr << "Could not locate bytecode file: '" << FN << "'\n";
+ if (FoundAFile)
+ cerr << "Bytecode file '" << FN << "' corrupt! "
+ << "Use 'link -v ...' for more info.\n";
+ else
+ cerr << "Could not locate bytecode file: '" << FN << "'\n";
return std::auto_ptr<Module>();
}
+
+
+
int main(int argc, char **argv) {
cl::ParseCommandLineOptions(argc, argv, " llvm linker\n",
cl::EnableSingleLetterArgValue |
diff --git a/llvm/tools/llvm-link/llvm-link.cpp b/llvm/tools/llvm-link/llvm-link.cpp
index 9bf766fcaad..83141c86e7d 100644
--- a/llvm/tools/llvm-link/llvm-link.cpp
+++ b/llvm/tools/llvm-link/llvm-link.cpp
@@ -18,6 +18,8 @@
#include "Support/CommandLine.h"
#include <fstream>
#include <memory>
+#include <sys/types.h> // For FileExists
+#include <sys/stat.h>
cl::StringList InputFilenames("", "Load <arg> files, linking them together",
@@ -28,14 +30,26 @@ cl::Flag Verbose ("v", "Print information about actions taken");
cl::Flag DumpAsm ("d", "Print assembly as linked", cl::Hidden, false);
cl::StringList LibPaths ("L", "Specify a library search path", cl::ZeroOrMore);
+
+// FileExists - Return true if the specified string is an openable file...
+static inline bool FileExists(const string &FN) {
+ struct stat StatBuf;
+ return stat(FN.c_str(), &StatBuf) != -1;
+}
+
+// LoadFile - Read the specified bytecode file in and return it. This routine
+// searches the link path for the specified file to try to find it...
+//
static inline std::auto_ptr<Module> LoadFile(const string &FN) {
string Filename = FN;
string ErrorMessage;
unsigned NextLibPathIdx = 0;
+ bool FoundAFile = false;
while (1) {
if (Verbose) cerr << "Loading '" << Filename << "'\n";
+ if (FileExists(Filename)) FoundAFile = true;
Module *Result = ParseBytecodeFile(Filename, &ErrorMessage);
if (Result) return std::auto_ptr<Module>(Result); // Load successful!
@@ -49,10 +63,17 @@ static inline std::auto_ptr<Module> LoadFile(const string &FN) {
Filename = LibPaths[NextLibPathIdx++] + "/" + FN;
}
- cerr << "Could not locate bytecode file: '" << FN << "'\n";
+ if (FoundAFile)
+ cerr << "Bytecode file '" << FN << "' corrupt! "
+ << "Use 'link -v ...' for more info.\n";
+ else
+ cerr << "Could not locate bytecode file: '" << FN << "'\n";
return std::auto_ptr<Module>();
}
+
+
+
int main(int argc, char **argv) {
cl::ParseCommandLineOptions(argc, argv, " llvm linker\n",
cl::EnableSingleLetterArgValue |
OpenPOWER on IntegriCloud