C++ gives us auto_ptr's, so we might as well use them. :)
authorChris Lattner <sabre@nondot.org>
Tue, 18 Sep 2001 17:04:18 +0000 (17:04 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 18 Sep 2001 17:04:18 +0000 (17:04 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@629 91177308-0d34-0410-b5e6-96231b3b80d8

tools/llc/llc.cpp

index 73298edadee2fde3c6b28ff4b57b5de5e34e9086..77cc7cee16e9bb69e73d2575b78ddcb9da8968aa 100644 (file)
@@ -11,6 +11,7 @@
 #include "llvm/Support/CommandLine.h"
 #include "llvm/Module.h"
 #include "llvm/Method.h"
+#include <memory>
 
 cl::String InputFilename ("", "Input filename", cl::NoFlags, "-");
 cl::String OutputFilename("o", "Output filename", cl::NoFlags, "");
@@ -18,9 +19,7 @@ cl::String OutputFilename("o", "Output filename", cl::NoFlags, "");
 
 //-------------------------- Internal Functions -----------------------------//
 
-static void
-NormalizeMethod(Method* method)
-{
+static void NormalizeMethod(Method* method) {
   NormalizePhiConstantArgs(method);
 }
 
@@ -31,39 +30,34 @@ NormalizeMethod(Method* method)
 // Entry point for the llc compiler.
 //===---------------------------------------------------------------------===//
 
-int
-main(int argc, char** argv)
-{
+int main(int argc, char **argv) {
+  // Parse command line options...
   cl::ParseCommandLineOptions(argc, argv, " llvm system compiler\n");
-  TargetMachine *Target = allocateSparcTargetMachine();
-  
-  Module *M = ParseBytecodeFile(InputFilename);
-  if (M == 0)
-    {
-      cerr << "bytecode didn't read correctly.\n";
-      delete Target;
-      return 1;
-    }
 
-  bool Failed = false;
-  for (Module::const_iterator MI = M->begin(), ME = M->end(); MI != ME; ++MI)
-    {
-      Method *Meth = *MI;
+  // Allocate a target... in the future this will be controllable on the
+  // command line.
+  auto_ptr<TargetMachine> Target(allocateSparcTargetMachine());
+
+  // Load the module to be compiled...
+  auto_ptr<Module> M(ParseBytecodeFile(InputFilename));
+  if (M.get() == 0) {
+    cerr << "bytecode didn't read correctly.\n";
+    return 1;
+  }
+
+  // Loop over all of the methods in the module, compiling them.
+  for (Module::const_iterator MI = M->begin(), ME = M->end(); MI != ME; ++MI) {
+    Method *Meth = *MI;
     
-      NormalizeMethod(Meth);
+    NormalizeMethod(Meth);
     
-      if (Target->compileMethod(Meth))
-       {
-         cerr << "Error compiling " << InputFilename << "!\n";
-         Failed = true;
-         break;
-       }
+    if (Target.get()->compileMethod(Meth)) {
+      cerr << "Error compiling " << InputFilename << "!\n";
+      return 1;
     }
+  }
   
-  // Clean up and exit
-  delete M;
-  delete Target;
-  return Failed;
+  return 0;
 }