1 //===-- llvm-ranlib.cpp - LLVM archive index generator --------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // Adds or updates an index (symbol table) for an LLVM archive file.
12 //===----------------------------------------------------------------------===//
14 #include "llvm/Module.h"
15 #include "llvm/Bitcode/Archive.h"
16 #include "llvm/Support/CommandLine.h"
17 #include "llvm/Support/ManagedStatic.h"
18 #include "llvm/Support/PrettyStackTrace.h"
19 #include "llvm/System/Signals.h"
26 // llvm-ar operation code and modifier flags
27 static cl::opt
<std::string
>
28 ArchiveName(cl::Positional
, cl::Optional
, cl::desc("<archive-file>"));
31 Verbose("verbose",cl::Optional
,cl::init(false),
32 cl::desc("Print the symbol table"));
34 // printSymbolTable - print out the archive's symbol table.
35 void printSymbolTable(Archive
* TheArchive
) {
36 std::cout
<< "\nArchive Symbol Table:\n";
37 const Archive::SymTabType
& symtab
= TheArchive
->getSymbolTable();
38 for (Archive::SymTabType::const_iterator I
=symtab
.begin(), E
=symtab
.end();
40 unsigned offset
= TheArchive
->getFirstFileOffset() + I
->second
;
41 std::cout
<< " " << std::setw(9) << offset
<< "\t" << I
->first
<<"\n";
45 int main(int argc
, char **argv
) {
46 // Print a stack trace if we signal out.
47 llvm::sys::PrintStackTraceOnErrorSignal();
48 llvm::PrettyStackTraceProgram
X(argc
, argv
);
50 llvm_shutdown_obj Y
; // Call llvm_shutdown() on exit.
52 // Have the command line options parsed and handle things
53 // like --help and --version.
54 cl::ParseCommandLineOptions(argc
, argv
,
55 "LLVM Archive Index Generator (llvm-ranlib)\n\n"
56 " This program adds or updates an index of bitcode symbols\n"
57 " to an LLVM archive file."
62 // Make sure we don't exit with "unhandled exception".
65 // Check the path name of the archive
66 sys::Path ArchivePath
;
67 if (!ArchivePath
.set(ArchiveName
))
68 throw std::string("Archive name invalid: ") + ArchiveName
;
70 // Make sure it exists, we don't create empty archives
71 if (!ArchivePath
.exists())
72 throw std::string("Archive file does not exist");
75 std::auto_ptr
<Archive
>
76 AutoArchive(Archive::OpenAndLoad(ArchivePath
,&err_msg
));
77 Archive
* TheArchive
= AutoArchive
.get();
81 if (TheArchive
->writeToDisk(true, false, false, &err_msg
))
85 printSymbolTable(TheArchive
);
87 } catch (const char* msg
) {
88 std::cerr
<< argv
[0] << ": " << msg
<< "\n\n";
90 } catch (const std::string
& msg
) {
91 std::cerr
<< argv
[0] << ": " << msg
<< "\n";
94 std::cerr
<< argv
[0] << ": An unexpected unknown exception occurred.\n";