Mercurial > projects > ldc
diff gen/cl_options.h @ 986:a8cb25d478c4
Use LLVM-style command line (instead of DMD-style)
Note: For a backward compatible interface, use the new bin/ldmd script. It
supports all old options while passing on anything it doesn't recognize.
Some changes caused by this:
* -debug and -version are now -d-debug and -d-version due to a conflict with
standard LLVM options.
* All "flag" options now allow an optional =true/=1/=false/=0 suffix.
* Some "hidden debug switches" starting with "--" were renamed because LLVM
doesn't care about the number of dashes, so they were conflicting with other
options (such as -c).
The new versions start with "-hidden-debug-" instead of "--"
* --help works, but has a non-zero exit code. This breaks some Tango scripts
which use it to test for compiler existence. See tango.patch.
Some changes not (directly) caused by this;
* (-enable/-disable)-FOO options are now available for pre- and postconditions.
* -march is used instead of -m (like other LLVM programs), but -m is an alias
for it.
* -defaultlib, -debuglib, -d-debug and -d-version allow comma-separated values.
The effect should be identical to specifying the same option multiple times.
I decided against allowing these for some other options because paths might
contain commas on some systems.
* -fPIC is removed in favor of the standard LLVM option -relocation-model=pic
Bug:
* If -run is specified as the last argument in DFLAGS, no error is generated.
(Not very serious IMHO)
author | Frits van Bommel <fvbommel wxs.nl> |
---|---|
date | Wed, 25 Feb 2009 17:34:51 +0100 |
parents | |
children | 2667e3a145be |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gen/cl_options.h Wed Feb 25 17:34:51 2009 +0100 @@ -0,0 +1,46 @@ +#ifndef LDC_CL_OPTIONS_H +#define LDC_CL_OPTIONS_H + +#include "mars.h" + +#include <deque> +#include <vector> + +#include "llvm/Support/RegistryParser.h" +#include "llvm/Target/TargetMachineRegistry.h" +#include "llvm/Support/CommandLine.h" + +namespace opts { + namespace cl = llvm::cl; + + /* Mostly generated with the following command: + egrep -e '^(cl::|#if|#e)' gen/cl_options.cpp \ + | sed -re 's/^(cl::.*)\(.*$/ extern \1;/' + */ + extern cl::list<std::string> fileList; + extern cl::list<std::string> runargs; + extern cl::opt<bool> compileOnly; + extern cl::opt<bool> noAsm; + extern cl::opt<bool> dontWriteObj; + extern cl::opt<std::string> objectFile; + extern cl::opt<std::string> objectDir; + extern cl::opt<bool> output_bc; + extern cl::opt<bool> output_ll; + extern cl::opt<bool> output_s; + extern cl::opt<cl::boolOrDefault> output_o; + extern cl::opt<std::string> ddocDir; + extern cl::opt<std::string> ddocFile; +#ifdef _DH + extern cl::opt<std::string> hdrDir; + extern cl::opt<std::string> hdrFile; +#endif + extern cl::list<std::string> versions; + + extern cl::opt<const llvm::TargetMachineRegistry::entry*, false, + llvm::RegistryParser<llvm::TargetMachine> > mArch; + + // Arguments to -d-debug + extern std::vector<std::string> debugArgs; + // Arguments to -run +} +#endif