diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-04-07 21:16:11 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-04-07 21:16:11 +0000 |
commit | d18049ab1dd687ebf18af46132120b3131c0baea (patch) | |
tree | b938280c5c40190459075fa5b80f40c0d364785d /clang/lib/Driver/Tools.cpp | |
parent | 30bf11e181b88f7da831f80bb2ce01d4af8e6502 (diff) | |
download | bcm5719-llvm-d18049ab1dd687ebf18af46132120b3131c0baea.tar.gz bcm5719-llvm-d18049ab1dd687ebf18af46132120b3131c0baea.zip |
Driver: Manually translate a number of -f with no- variants options to
clang.
- We will eventually want some more driver infrastructre for this
probably.
- For now, the clang-cc interface stays relatively the same, but we
don't accept multiple instances anymore, or the [no-] variants
directly.
llvm-svn: 68550
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
-rw-r--r-- | clang/lib/Driver/Tools.cpp | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index e26bb9e85ad..dd3a00ecb33 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/lib/Driver/Tools.cpp @@ -357,8 +357,34 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA, CmdArgs.push_back(A->getValue(Args)); } + // Forward -f options which we can pass directly. Args.AddAllArgs(CmdArgs, options::OPT_clang_f_Group); + // Forward -f options with positive and negative forms; we translate + // these by hand. + + // -fbuiltin is default, only pass non-default. + if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin)) + CmdArgs.push_back("-fbuiltin=0"); + + // -fblocks default varies depending on platform and language; + // -always pass if specified. + if (Arg *A = Args.getLastArg(options::OPT_fblocks, options::OPT_fno_blocks)) { + if (A->getOption().matches(options::OPT_fblocks)) + CmdArgs.push_back("-fblocks"); + else + CmdArgs.push_back("-fblocks=0"); + } + + // -fno-pascal-strings is default, only pass non-default. + if (Args.hasFlag(options::OPT_fpascal_strings, + options::OPT_fno_pascal_strings)) + CmdArgs.push_back("-fpascal-strings"); + + // -fcommon is default, only pass non-default. + if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common)) + CmdArgs.push_back("-fno-common"); + // If tool chain translates fpascal-strings, we want to back // translate here. // FIXME: This is gross; that translation should be pulled from the |