summaryrefslogtreecommitdiffstats
path: root/llvm/tools/llvm2cpp/llvm2cpp.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-05-06 05:21:42 +0000
committerChris Lattner <sabre@nondot.org>2007-05-06 05:21:42 +0000
commit99016c3f2dd241d9193e400afd0e319d93c91e69 (patch)
treebb193d471911b5076dd2d237a593033793b81232 /llvm/tools/llvm2cpp/llvm2cpp.cpp
parentb94d80b6fbb97a72ece3e7dc131166a2f1faf467 (diff)
downloadbcm5719-llvm-99016c3f2dd241d9193e400afd0e319d93c91e69.tar.gz
bcm5719-llvm-99016c3f2dd241d9193e400afd0e319d93c91e69.zip
bitcodify, remove eh cruft
llvm-svn: 36844
Diffstat (limited to 'llvm/tools/llvm2cpp/llvm2cpp.cpp')
-rw-r--r--llvm/tools/llvm2cpp/llvm2cpp.cpp22
1 files changed, 18 insertions, 4 deletions
diff --git a/llvm/tools/llvm2cpp/llvm2cpp.cpp b/llvm/tools/llvm2cpp/llvm2cpp.cpp
index fe9504e5673..3424482fda6 100644
--- a/llvm/tools/llvm2cpp/llvm2cpp.cpp
+++ b/llvm/tools/llvm2cpp/llvm2cpp.cpp
@@ -17,19 +17,22 @@
//===------------------------------------------------------------------------===
#include "llvm/Module.h"
+#include "llvm/Bitcode/ReaderWriter.h"
#include "llvm/Bytecode/Reader.h"
#include "llvm/Analysis/Verifier.h"
#include "llvm/Support/CommandLine.h"
#include "llvm/Support/ManagedStatic.h"
+#include "llvm/Support/MemoryBuffer.h"
#include "llvm/Support/SystemUtils.h"
#include "llvm/System/Signals.h"
#include "CppWriter.h"
#include <fstream>
#include <iostream>
#include <memory>
-
using namespace llvm;
+cl::opt<bool> Bitcode("bitcode");
+
static cl::opt<std::string>
InputFilename(cl::Positional, cl::desc("<input LLVM bytecode file>"),
cl::init("-"));
@@ -49,9 +52,20 @@ int main(int argc, char **argv) {
int exitCode = 0;
std::ostream *Out = 0;
std::string ErrorMessage;
- std::auto_ptr<Module> M(ParseBytecodeFile(InputFilename,
- Compressor::decompressToNewBuffer,
- &ErrorMessage));
+
+ std::auto_ptr<Module> M;
+ if (Bitcode) {
+ std::auto_ptr<MemoryBuffer> Buffer(
+ MemoryBuffer::getFileOrSTDIN(&InputFilename[0], InputFilename.size()));
+ if (Buffer.get())
+ M.reset(ParseBitcodeFile(Buffer.get(), &ErrorMessage));
+ else
+ ErrorMessage = "Error reading file '" + InputFilename + "'";
+ } else {
+ M.reset(ParseBytecodeFile(InputFilename,
+ Compressor::decompressToNewBuffer,
+ &ErrorMessage));
+ }
if (M.get() == 0) {
std::cerr << argv[0] << ": ";
if (ErrorMessage.size())
OpenPOWER on IntegriCloud