1987319d3SReid Spencer //===- examples/ModuleMaker/ModuleMaker.cpp - Example project ---*- C++ -*-===//
25b81eea7SReid Spencer //
33779fd65SChris Lattner //                     The LLVM Compiler Infrastructure
43779fd65SChris Lattner //
5bcf65db6SChris Lattner // This file is distributed under the University of Illinois Open Source
6bcf65db6SChris Lattner // License. See LICENSE.TXT for details.
73779fd65SChris Lattner //
83779fd65SChris Lattner //===----------------------------------------------------------------------===//
93779fd65SChris Lattner //
105b81eea7SReid Spencer // This programs is a simple example that creates an LLVM module "from scratch",
11e16561cdSGabor Greif // emitting it as a bitcode file to standard out.  This is just to show how
125b81eea7SReid Spencer // LLVM projects work and to demonstrate some of the LLVM APIs.
135b81eea7SReid Spencer //
145b81eea7SReid Spencer //===----------------------------------------------------------------------===//
155b81eea7SReid Spencer 
16*605e30e9SChandler Carruth #include "llvm/Bitcode/ReaderWriter.h"
17*605e30e9SChandler Carruth #include "llvm/Constants.h"
18*605e30e9SChandler Carruth #include "llvm/DerivedTypes.h"
19*605e30e9SChandler Carruth #include "llvm/Instructions.h"
206773d388SOwen Anderson #include "llvm/LLVMContext.h"
215b81eea7SReid Spencer #include "llvm/Module.h"
226973395cSChris Lattner #include "llvm/Support/raw_ostream.h"
235b81eea7SReid Spencer using namespace llvm;
245b81eea7SReid Spencer 
255b81eea7SReid Spencer int main() {
266773d388SOwen Anderson   LLVMContext Context;
276773d388SOwen Anderson 
285b81eea7SReid Spencer   // Create the "module" or "program" or "translation unit" to hold the
295b81eea7SReid Spencer   // function
301cf085d5SOwen Anderson   Module *M = new Module("test", Context);
315b81eea7SReid Spencer 
325b81eea7SReid Spencer   // Create the main function: first create the type 'int ()'
33b6b25300SOwen Anderson   FunctionType *FT =
3455f1c09eSOwen Anderson     FunctionType::get(Type::getInt32Ty(Context), /*not vararg*/false);
355b81eea7SReid Spencer 
365b81eea7SReid Spencer   // By passing a module as the last parameter to the Function constructor,
375b81eea7SReid Spencer   // it automatically gets appended to the Module.
38e9ecc68dSGabor Greif   Function *F = Function::Create(FT, Function::ExternalLinkage, "main", M);
395b81eea7SReid Spencer 
405b81eea7SReid Spencer   // Add a basic block to the function... again, it automatically inserts
415b81eea7SReid Spencer   // because of the last argument.
4255f1c09eSOwen Anderson   BasicBlock *BB = BasicBlock::Create(Context, "EntryBlock", F);
435b81eea7SReid Spencer 
445b81eea7SReid Spencer   // Get pointers to the constant integers...
4555f1c09eSOwen Anderson   Value *Two = ConstantInt::get(Type::getInt32Ty(Context), 2);
4655f1c09eSOwen Anderson   Value *Three = ConstantInt::get(Type::getInt32Ty(Context), 3);
475b81eea7SReid Spencer 
485b81eea7SReid Spencer   // Create the add instruction... does not insert...
49e1f6e4b2SGabor Greif   Instruction *Add = BinaryOperator::Create(Instruction::Add, Two, Three,
505b81eea7SReid Spencer                                             "addresult");
515b81eea7SReid Spencer 
525b81eea7SReid Spencer   // explicitly insert it into the basic block...
535b81eea7SReid Spencer   BB->getInstList().push_back(Add);
545b81eea7SReid Spencer 
555b81eea7SReid Spencer   // Create the return instruction and add it to the basic block
5655f1c09eSOwen Anderson   BB->getInstList().push_back(ReturnInst::Create(Context, Add));
575b81eea7SReid Spencer 
58e16561cdSGabor Greif   // Output the bitcode file to stdout
596973395cSChris Lattner   WriteBitcodeToFile(M, outs());
605b81eea7SReid Spencer 
615b81eea7SReid Spencer   // Delete the module and all of its contents.
625b81eea7SReid Spencer   delete M;
635b81eea7SReid Spencer   return 0;
645b81eea7SReid Spencer }
65