BitcodeWriterPass.cpp 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. //===- BitcodeWriterPass.cpp - Bitcode writing pass -----------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. //
  10. // BitcodeWriterPass implementation.
  11. //
  12. //===----------------------------------------------------------------------===//
  13. #include "llvm/Bitcode/BitcodeWriterPass.h"
  14. #include "llvm/Bitcode/ReaderWriter.h"
  15. #include "llvm/IR/Module.h"
  16. #include "llvm/IR/PassManager.h"
  17. #include "llvm/IR/UseListOrder.h"
  18. #include "llvm/Pass.h"
  19. using namespace llvm;
  20. PreservedAnalyses BitcodeWriterPass::run(Module &M) {
  21. WriteBitcodeToFile(&M, OS, ShouldPreserveUseListOrder);
  22. return PreservedAnalyses::all();
  23. }
  24. namespace {
  25. class WriteBitcodePass : public ModulePass {
  26. raw_ostream &OS; // raw_ostream to print on
  27. bool ShouldPreserveUseListOrder;
  28. public:
  29. static char ID; // Pass identification, replacement for typeid
  30. explicit WriteBitcodePass(raw_ostream &o, bool ShouldPreserveUseListOrder)
  31. : ModulePass(ID), OS(o),
  32. ShouldPreserveUseListOrder(ShouldPreserveUseListOrder) {}
  33. const char *getPassName() const override { return "Bitcode Writer"; }
  34. bool runOnModule(Module &M) override {
  35. WriteBitcodeToFile(&M, OS, ShouldPreserveUseListOrder);
  36. return false;
  37. }
  38. };
  39. }
  40. char WriteBitcodePass::ID = 0;
  41. ModulePass *llvm::createBitcodeWriterPass(raw_ostream &Str,
  42. bool ShouldPreserveUseListOrder) {
  43. return new WriteBitcodePass(Str, ShouldPreserveUseListOrder);
  44. }