From: Chris Lattner Date: Fri, 8 Jun 2001 00:35:25 +0000 (+0000) Subject: Added a stupid testcase for iterators. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=84608e43b25a99862f424487c97b1f9842a7d6e5;p=oota-llvm.git Added a stupid testcase for iterators. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/opt/opt.cpp b/tools/opt/opt.cpp index a0cf140c4de..ff513d75a31 100644 --- a/tools/opt/opt.cpp +++ b/tools/opt/opt.cpp @@ -29,6 +29,25 @@ #include "llvm/Tools/CommandLine.h" #include "llvm/Opt/AllOpts.h" +#if 1 // Testcase, TODO: REMOVE +#include "llvm/CFG.h" +#include "llvm/Assembly/Writer.h" +#include "llvm/Method.h" +static bool DoPrintM(Method *M) { + df_iterator I = df_begin(M->getBasicBlocks().front(), false); + df_iterator E = df_end(M->getBasicBlocks().front()); + unsigned i = 0; + for (; I != E; ++I, ++i) { + cerr << "Basic Block Visited #" << i << *I; + } + return false; +} + +static bool DoPrint(Module *C) { + return ApplyOptToAllMethods(C, DoPrintM); +} +#endif + struct { const string ArgName, Name; bool (*OptPtr)(Module *C); @@ -38,6 +57,7 @@ struct { { "-inline" ,"Method Inlining", DoMethodInlining }, { "-strip" ,"Strip Symbols", DoSymbolStripping }, { "-mstrip" ,"Strip Module Symbols", DoFullSymbolStripping }, + { "-print" ,"Test printing stuff", DoPrint }, }; int main(int argc, char **argv) {