From 06fcc4cb755eac7646e831131ca85d8ad78a6276 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 25 Jun 2005 03:32:05 +0000 Subject: [PATCH] add a new -filetype argument to llc. llvm-svn: 22287 --- llvm/tools/llc/llc.cpp | 38 +++++++++++++++++++++++++++++++------- 1 file changed, 31 insertions(+), 7 deletions(-) diff --git a/llvm/tools/llc/llc.cpp b/llvm/tools/llc/llc.cpp index a6f3e8a5ec93..70d8c70fc315 100644 --- a/llvm/tools/llc/llc.cpp +++ b/llvm/tools/llc/llc.cpp @@ -23,6 +23,7 @@ #include "llvm/Support/CommandLine.h" #include "llvm/Support/PluginLoader.h" #include "llvm/System/Signals.h" +#include "llvm/Config/config.h" #include #include #include @@ -44,7 +45,20 @@ static cl::opt Force("f", cl::desc("Overwrite output files")); static cl::opt MArch("march", cl::desc("Architecture to generate code for:")); -// GetFileNameRoot - Helper function to get the basename of a filename... +cl::opt +FileType("filetype", cl::init(TargetMachine::AssemblyFile), + cl::desc("Choose a file type (not all types are supported by all targets):"), + cl::values( + clEnumValN(TargetMachine::AssemblyFile, "asm", + " Emit an assembly ('.s') file"), + clEnumValN(TargetMachine::ObjectFile, "obj", + " Emit a native object ('.o') file"), + clEnumValN(TargetMachine::DynamicLibrary, "dynlib", + " Emit a native dynamic library ('.so') file"), + clEnumValEnd)); + + +// GetFileNameRoot - Helper function to get the basename of a filename. static inline std::string GetFileNameRoot(const std::string &InputFilename) { std::string IFN = InputFilename; @@ -126,10 +140,20 @@ int main(int argc, char **argv) { } else { OutputFilename = GetFileNameRoot(InputFilename); - if (MArch->Name[0] != 'c' || MArch->Name[1] != 0) // not CBE - OutputFilename += ".s"; - else - OutputFilename += ".cbe.c"; + switch (FileType) { + case TargetMachine::AssemblyFile: + if (MArch->Name[0] != 'c' || MArch->Name[1] != 0) // not CBE + OutputFilename += ".s"; + else + OutputFilename += ".cbe.c"; + break; + case TargetMachine::ObjectFile: + OutputFilename += ".o"; + break; + case TargetMachine::DynamicLibrary: + OutputFilename += LTDL_SHLIB_EXT; + break; + } if (!Force && std::ifstream(OutputFilename.c_str())) { // If force is not specified, make sure not to overwrite a file! @@ -153,9 +177,9 @@ int main(int argc, char **argv) { } // Ask the target to add backend passes as necessary. - if (Target.addPassesToEmitFile(Passes, *Out, TargetMachine::AssemblyFile)) { + if (Target.addPassesToEmitFile(Passes, *Out, FileType)) { std::cerr << argv[0] << ": target '" << Target.getName() - << "' does not support static compilation!\n"; + << "' does not support generation of this file type!\n"; if (Out != &std::cout) delete Out; // And the Out file is empty and useless, so remove it now. std::remove(OutputFilename.c_str());