aboutsummaryrefslogtreecommitdiff
path: root/lib/Bitcode/Writer/BitcodeWriterPass.cpp
diff options
context:
space:
mode:
authorTanya Lattner <tonic@nondot.org>2007-09-13 04:38:30 +0000
committerTanya Lattner <tonic@nondot.org>2007-09-13 04:38:30 +0000
commitf1c1d0fca6997d398f76036c76c5cf457fb9bc2a (patch)
treec17c23faff45927d5ecb112acb4db6daddb3fb87 /lib/Bitcode/Writer/BitcodeWriterPass.cpp
parent36df74e8af9da1d24130da079716887b0aa576bc (diff)
parentffddf97e5dd1fc222cec049c30ca5d9018a741f8 (diff)
Creating 2.1 release branch.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_21@41920 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode/Writer/BitcodeWriterPass.cpp')
-rw-r--r--lib/Bitcode/Writer/BitcodeWriterPass.cpp43
1 files changed, 43 insertions, 0 deletions
diff --git a/lib/Bitcode/Writer/BitcodeWriterPass.cpp b/lib/Bitcode/Writer/BitcodeWriterPass.cpp
new file mode 100644
index 0000000000..74123116da
--- /dev/null
+++ b/lib/Bitcode/Writer/BitcodeWriterPass.cpp
@@ -0,0 +1,43 @@
+//===--- Bitcode/Writer/BitcodeWriterPass.cpp - Bitcode Writer ------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file was developed by Chris Lattner and is distributed under
+// the University of Illinois Open Source License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// BitcodeWriterPass implementation.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/Bitcode/ReaderWriter.h"
+#include "llvm/Pass.h"
+using namespace llvm;
+
+namespace {
+ class WriteBitcodePass : public ModulePass {
+ std::ostream *Out; // ostream to print on
+ public:
+ static char ID; // Pass identifcation, replacement for typeid
+ WriteBitcodePass() : ModulePass((intptr_t) &ID), Out(0) { }
+ WriteBitcodePass(std::ostream &o) : ModulePass((intptr_t) &ID), Out(&o) {}
+
+ bool runOnModule(Module &M) {
+ if (Out)
+ WriteBitcodeToFile(&M, *Out);
+ return false;
+ }
+ };
+}
+
+char WriteBitcodePass::ID = 0;
+static RegisterPass<WriteBitcodePass> X("emitbitcode", "Bitcode Writer");
+
+/// CreateBitcodeWriterPass - Create and return a pass that writes the module
+/// to the specified ostream.
+ModulePass *llvm::CreateBitcodeWriterPass(std::ostream &Str) {
+ return new WriteBitcodePass(Str);
+}
+
+