summaryrefslogtreecommitdiff
path: root/tools/llvm-ranlib
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2004-11-16 06:41:20 +0000
committerReid Spencer <rspencer@reidspencer.com>2004-11-16 06:41:20 +0000
commitbabb45b3277e0d85358d19d6618818a9cef561a3 (patch)
tree94d4cbf965f32747e4f308c18727a116cc8d8bf0 /tools/llvm-ranlib
parentbede58363c647a4e73112fdfb409e9af7051301e (diff)
downloadllvm-babb45b3277e0d85358d19d6618818a9cef561a3.tar.gz
llvm-babb45b3277e0d85358d19d6618818a9cef561a3.tar.bz2
llvm-babb45b3277e0d85358d19d6618818a9cef561a3.tar.xz
Per code review: \
* Make static things static \ * Get rid of unused TmpArchive variable \ * Implement symbol table printing \ * Adjust to changes in llvm::Archive interface \ * Make sure we destruct objects even if exceptions occur. \ * Fix a typo in an output string. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17878 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/llvm-ranlib')
-rw-r--r--tools/llvm-ranlib/llvm-ranlib.cpp31
1 files changed, 17 insertions, 14 deletions
diff --git a/tools/llvm-ranlib/llvm-ranlib.cpp b/tools/llvm-ranlib/llvm-ranlib.cpp
index b387aa5eec..6ac2b16da1 100644
--- a/tools/llvm-ranlib/llvm-ranlib.cpp
+++ b/tools/llvm-ranlib/llvm-ranlib.cpp
@@ -17,24 +17,27 @@
#include "llvm/Support/FileUtilities.h"
#include "llvm/System/Signals.h"
#include <iostream>
-#include <algorithm>
#include <iomanip>
using namespace llvm;
// llvm-ar operation code and modifier flags
-cl::opt<std::string>
+static cl::opt<std::string>
ArchiveName(cl::Positional, cl::Optional, cl::desc("<archive-file>..."));
-cl::opt<bool>
+static cl::opt<bool>
Verbose("verbose",cl::Optional,cl::init(false),
cl::desc("Print the symbol table"));
-sys::Path TmpArchive;
-
-void cleanup() {
- if (TmpArchive.exists())
- TmpArchive.destroyFile();
+// printSymbolTable - print out the archive's symbol table.
+void printSymbolTable(Archive* TheArchive) {
+ std::cout << "\nArchive Symbol Table:\n";
+ const Archive::SymTabType& symtab = TheArchive->getSymbolTable();
+ for (Archive::SymTabType::const_iterator I=symtab.begin(), E=symtab.end();
+ I != E; ++I ) {
+ unsigned offset = TheArchive->getFirstFileOffset() + I->second;
+ std::cout << " " << std::setw(9) << offset << "\t" << I->first <<"\n";
+ }
}
int main(int argc, char **argv) {
@@ -64,14 +67,15 @@ int main(int argc, char **argv) {
if (!ArchivePath.exists())
throw "Archive file does not exist";
- // Archive* TheArchive = Archive::OpenAndLoad(ArchivePath);
- Archive* TheArchive = Archive::OpenAndLoad(ArchivePath);
+ std::auto_ptr<Archive> AutoArchive(Archive::OpenAndLoad(ArchivePath));
+ Archive* TheArchive = AutoArchive.get();
assert(TheArchive && "Unable to instantiate the archive");
- TheArchive->writeToDisk(true,false,false,Verbose);
+ TheArchive->writeToDisk(true, false, false );
- delete TheArchive;
+ if (Verbose)
+ printSymbolTable(TheArchive);
} catch (const char*msg) {
std::cerr << argv[0] << ": " << msg << "\n\n";
@@ -80,9 +84,8 @@ int main(int argc, char **argv) {
std::cerr << argv[0] << ": " << msg << "\n";
exitCode = 2;
} catch (...) {
- std::cerr << argv[0] << ": An nexpected unknown exception occurred.\n";
+ std::cerr << argv[0] << ": An unexpected unknown exception occurred.\n";
exitCode = 3;
}
- cleanup();
return exitCode;
}