diff options
author | Chris Lattner <sabre@nondot.org> | 2001-06-06 20:29:01 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2001-06-06 20:29:01 +0000 |
commit | 009505452b713ed2e3a8e99c5545a6e721c65495 (patch) | |
tree | 136a71c5b87bdf534d1f20a67558b49226b5a4d6 /tools/llvm-as/llvm-as.cpp | |
parent | 8d0afd3d32d1d67f9aa5df250a1d6955aa8f1ac9 (diff) |
Initial revision
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/llvm-as/llvm-as.cpp')
-rw-r--r-- | tools/llvm-as/llvm-as.cpp | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/tools/llvm-as/llvm-as.cpp b/tools/llvm-as/llvm-as.cpp new file mode 100644 index 0000000000..2c319a0849 --- /dev/null +++ b/tools/llvm-as/llvm-as.cpp @@ -0,0 +1,85 @@ +//===------------------------------------------------------------------------=== +// LLVM 'AS' UTILITY +// +// This utility may be invoked in the following manner: +// as --help - Output information about command line switches +// as [options] - Read LLVM assembly from stdin, write bytecode to stdout +// as [options] x.ll - Read LLVM assembly from the x.ll file, write bytecode +// to the x.bc file. +// +//===------------------------------------------------------------------------=== + +#include <iostream.h> +#include <fstream.h> +#include <string> +#include "llvm/Module.h" +#include "llvm/Assembly/Parser.h" +#include "llvm/Assembly/Writer.h" +#include "llvm/Bytecode/Writer.h" +#include "llvm/Tools/CommandLine.h" + + +int main(int argc, char **argv) { + ToolCommandLine Opts(argc, argv); + bool DumpAsm = false; + + for (int i = 1; i < argc; i++) { + if (string(argv[i]) == string("-d")) { + argv[i] = 0; DumpAsm = true; + } + } + + bool PrintMessage = false; + for (int i = 1; i < argc; i++) { + if (argv[i] == 0) continue; + + if (string(argv[i]) == string("--help")) { + PrintMessage = true; + } else { + cerr << argv[0] << ": argument not recognized: '" << argv[i] << "'!\n"; + } + } + + if (PrintMessage) { + cerr << argv[0] << " usage:\n" + << " " << argv[0] << " --help - Print this usage information\n" + << " " << argv[0] << " x.ll - Parse <x.ll> file and output " + << "bytecodes to x.bc\n" + << " " << argv[0] << " - Parse stdin and write to stdout.\n"; + return 1; + } + + ostream *Out = &cout; // Default to output to stdout... + try { + // Parse the file now... + Module *C = ParseAssemblyFile(Opts); + if (C == 0) { + cerr << "assembly didn't read correctly.\n"; + return 1; + } + + if (DumpAsm) + cerr << "Here's the assembly:\n" << C; + + if (Opts.getOutputFilename() != "-") { + Out = new ofstream(Opts.getOutputFilename().c_str(), + (Opts.getForce() ? 0 : ios::noreplace)|ios::out); + if (!Out->good()) { + cerr << "Error opening " << Opts.getOutputFilename() << "!\n"; + delete C; + return 1; + } + } + + WriteBytecodeToFile(C, *Out); + + delete C; + } catch (const ParseException &E) { + cerr << E.getMessage() << endl; + return 1; + } + + if (Out != &cout) delete Out; + return 0; +} + |