X-Git-Url: http://plrg.eecs.uci.edu/git/?p=oota-llvm.git;a=blobdiff_plain;f=examples%2FModuleMaker%2FModuleMaker.cpp;h=154e24065c0a82cef9b0a5fadb932d97f0e6671b;hp=30f63bb8f4496698b13746fd6219e6fe20882460;hb=dbc2e856fce973243d2dfba88d573d3c88f06020;hpb=68fe61d6a165ea6090008e281330895a21607daf diff --git a/examples/ModuleMaker/ModuleMaker.cpp b/examples/ModuleMaker/ModuleMaker.cpp index 30f63bb8f44..154e24065c0 100644 --- a/examples/ModuleMaker/ModuleMaker.cpp +++ b/examples/ModuleMaker/ModuleMaker.cpp @@ -2,13 +2,13 @@ // // The LLVM Compiler Infrastructure // -// This file was developed by the LLVM research group and is distributed under -// the University of Illinois Open Source License. See LICENSE.TXT for details. +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This programs is a simple example that creates an LLVM module "from scratch", -// emitting it as a bytecode file to standard out. This is just to show how +// emitting it as a bitcode file to standard out. This is just to show how // LLVM projects work and to demonstrate some of the LLVM APIs. // //===----------------------------------------------------------------------===// @@ -17,8 +17,8 @@ #include "llvm/DerivedTypes.h" #include "llvm/Constants.h" #include "llvm/Instructions.h" -#include "llvm/Bytecode/Writer.h" -#include "llvm/Support/Streams.h" +#include "llvm/Bitcode/ReaderWriter.h" +#include using namespace llvm; int main() { @@ -27,33 +27,33 @@ int main() { Module *M = new Module("test"); // Create the main function: first create the type 'int ()' - FunctionType *FT = FunctionType::get(Type::IntTy, std::vector(), + FunctionType *FT = FunctionType::get(Type::Int32Ty, std::vector(), /*not vararg*/false); // By passing a module as the last parameter to the Function constructor, // it automatically gets appended to the Module. - Function *F = new Function(FT, Function::ExternalLinkage, "main", M); + Function *F = Function::Create(FT, Function::ExternalLinkage, "main", M); // Add a basic block to the function... again, it automatically inserts // because of the last argument. - BasicBlock *BB = new BasicBlock("EntryBlock", F); + BasicBlock *BB = BasicBlock::Create("EntryBlock", F); // Get pointers to the constant integers... - Value *Two = ConstantInt::get(Type::IntTy, 2); - Value *Three = ConstantInt::get(Type::IntTy, 3); + Value *Two = ConstantInt::get(Type::Int32Ty, 2); + Value *Three = ConstantInt::get(Type::Int32Ty, 3); // Create the add instruction... does not insert... - Instruction *Add = BinaryOperator::create(Instruction::Add, Two, Three, + Instruction *Add = BinaryOperator::Create(Instruction::Add, Two, Three, "addresult"); // explicitly insert it into the basic block... BB->getInstList().push_back(Add); // Create the return instruction and add it to the basic block - BB->getInstList().push_back(new ReturnInst(Add)); + BB->getInstList().push_back(ReturnInst::Create(Add)); - // Output the bytecode file to stdout - WriteBytecodeToFile(M, llvm_cout); + // Output the bitcode file to stdout + WriteBitcodeToFile(M, std::cout); // Delete the module and all of its contents. delete M;