[cfe-commits] r62241 - in /cfe/trunk/tools/ccc/ccclib: Arguments.py Tools.py
Daniel Dunbar
daniel at zuster.org
Wed Jan 14 11:42:31 PST 2009
Author: ddunbar
Date: Wed Jan 14 13:42:31 2009
New Revision: 62241
URL: http://llvm.org/viewvc/llvm-project?rev=62241&view=rev
Log:
ccc: Finish main clang compiler argument translation.
- Still missing some odds and ends like -M.
- Also, we still need to do some translation and forwarding of
codegen options.
Modified:
cfe/trunk/tools/ccc/ccclib/Arguments.py
cfe/trunk/tools/ccc/ccclib/Tools.py
Modified: cfe/trunk/tools/ccc/ccclib/Arguments.py
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/tools/ccc/ccclib/Arguments.py?rev=62241&r1=62240&r2=62241&view=diff
==============================================================================
--- cfe/trunk/tools/ccc/ccclib/Arguments.py (original)
+++ cfe/trunk/tools/ccc/ccclib/Arguments.py Wed Jan 14 13:42:31 2009
@@ -50,8 +50,8 @@
"""OptionGroup - A fake option class used to group options so that
the driver can efficiently refer to an entire set of options."""
- def __init__(self, name):
- super(OptionGroup, self).__init__(name)
+ def __init__(self, name, group=None):
+ super(OptionGroup, self).__init__(name, group)
def accept(self, index, arg, it):
raise RuntimeError,"accept() should never be called on an OptionGroup"
@@ -671,6 +671,8 @@
# C options for testing
+ self.trigraphsOption = self.addOption(FlagOption('-trigraphs'))
+
# FIXME: This is broken, we need -A as a single option to send
# stuff to cc1, but the way the ld spec is constructed it
# wants to see -A options but only as a separate arg.
@@ -718,33 +720,42 @@
self.g3Option = self.addOption(JoinedOption('-g3', self.gGroup))
self.gOption = self.addOption(JoinedOption('-g', self.gGroup))
+ # FIXME: How should we handle clang specific options? Do we
+ # want to avoid passing them to gcc/cc1 (which will generally
+ # not eat them), or should we let the user sort it out.
+
self.fGroup = OptionGroup('-f')
self.fastOption = self.addOption(FlagOption('-fast', self.fGroup))
self.fastfOption = self.addOption(FlagOption('-fastf', self.fGroup))
self.fastcpOption = self.addOption(FlagOption('-fastcp', self.fGroup))
self.f_appleKextOption = self.addOption(FlagOption('-fapple-kext', self.fGroup))
- self.f_noEliminateUnusedDebugSymbolsOption = self.addOption(FlagOption('-fno-eliminate-unused-debug-symbols', self.fGroup))
+ self.f_constantCfstringsOption = self.addOption(FlagOption('-fconstant-cfstrings', self.fGroup))
+ self.f_createProfileOption = self.addOption(FlagOption('-fcreate-profile', self.fGroup))
self.f_exceptionsOption = self.addOption(FlagOption('-fexceptions', self.fGroup))
- self.f_objcOption = self.addOption(FlagOption('-fobjc', self.fGroup))
- self.f_objcGcOption = self.addOption(FlagOption('-fobjc-gc', self.fGroup))
- self.f_objcGcOnlyOption = self.addOption(FlagOption('-fobjc-gc-only', self.fGroup))
- self.f_openmpOption = self.addOption(FlagOption('-fopenmp', self.fGroup))
self.f_gnuRuntimeOption = self.addOption(FlagOption('-fgnu-runtime', self.fGroup))
- self.f_nextRuntimeOption = self.addOption(FlagOption('-fnext-runtime', self.fGroup))
- self.f_constantCfstringsOption = self.addOption(FlagOption('-fconstant-cfstrings', self.fGroup))
- self.f_noConstantCfstringsOption = self.addOption(FlagOption('-fno-constant-cfstrings', self.fGroup))
- self.f_pascalStringsOption = self.addOption(FlagOption('-fpascal-strings', self.fGroup))
- self.f_noPascalStringsOption = self.addOption(FlagOption('-fno-pascal-strings', self.fGroup))
self.f_gnuRuntimeOption = self.addOption(FlagOption('-fgnu-runtime', self.fGroup))
+ self.f_laxVectorConversionsOption = self.addOption(FlagOption('-flax-vector-conversions', self.fGroup))
+ self.f_msExtensionsOption = self.addOption(FlagOption('-fms-extensions', self.fGroup))
self.f_mudflapOption = self.addOption(FlagOption('-fmudflap', self.fGroup))
self.f_mudflapthOption = self.addOption(FlagOption('-fmudflapth', self.fGroup))
self.f_nestedFunctionsOption = self.addOption(FlagOption('-fnested-functions', self.fGroup))
+ self.f_nextRuntimeOption = self.addOption(FlagOption('-fnext-runtime', self.fGroup))
+ self.f_noCaretDiagnosticsOption = self.addOption(FlagOption('-fno-caret-diagnostics', self.fGroup))
+ self.f_noConstantCfstringsOption = self.addOption(FlagOption('-fno-constant-cfstrings', self.fGroup))
+ self.f_noEliminateUnusedDebugSymbolsOption = self.addOption(FlagOption('-fno-eliminate-unused-debug-symbols', self.fGroup))
+ self.f_noPascalStringsOption = self.addOption(FlagOption('-fno-pascal-strings', self.fGroup))
+ self.f_noShowColumnOption = self.addOption(FlagOption('-fno-show-column', self.fGroup))
+ self.f_objcGcOnlyOption = self.addOption(FlagOption('-fobjc-gc-only', self.fGroup))
+ self.f_objcGcOption = self.addOption(FlagOption('-fobjc-gc', self.fGroup))
+ self.f_objcOption = self.addOption(FlagOption('-fobjc', self.fGroup))
+ self.f_openmpOption = self.addOption(FlagOption('-fopenmp', self.fGroup))
+ self.f_pascalStringsOption = self.addOption(FlagOption('-fpascal-strings', self.fGroup))
self.f_pieOption = self.addOption(FlagOption('-fpie', self.fGroup))
self.f_profileArcsOption = self.addOption(FlagOption('-fprofile-arcs', self.fGroup))
self.f_profileGenerateOption = self.addOption(FlagOption('-fprofile-generate', self.fGroup))
- self.f_createProfileOption = self.addOption(FlagOption('-fcreate-profile', self.fGroup))
self.f_traditionalOption = self.addOption(FlagOption('-ftraditional', self.fGroup))
+ self.f_writableStringsOption = self.addOption(FlagOption('-fwritable-strings', self.fGroup))
self.addOption(JoinedOption('-f', self.fGroup))
self.coverageOption = self.addOption(FlagOption('-coverage'))
@@ -776,13 +787,26 @@
self.ansiOption = self.addOption(FlagOption('-ansi', self.aGroup))
self.aOption = self.addOption(JoinedOption('-a', self.aGroup))
- self.trigraphsOption = self.addOption(FlagOption('-trigraphs'))
- self.pedanticOption = self.addOption(FlagOption('-pedantic'))
+ self.pedanticGroup = OptionGroup('-pedantic')
+ self.pedanticOption = self.addOption(FlagOption('-pedantic', self.pedanticGroup))
+ self.pedanticErrorsOption = self.addOption(FlagOption('-pedantic-errors', self.pedanticGroup))
self.OOption = self.addOption(JoinedOption('-O'))
+
self.WGroup = OptionGroup('-W')
+ self.ClangWGroup = OptionGroup('-W', self.WGroup)
+
+ self.addOption(JoinedOption('-Wunused-macros', self.ClangWGroup))
+ self.addOption(JoinedOption('-Wfloat-equal', self.ClangWGroup))
+ self.addOption(JoinedOption('-Wreadonly-setter-attrs', self.ClangWGroup))
+ self.addOption(JoinedOption('-Wno-format-nonliteral', self.ClangWGroup))
+ self.addOption(JoinedOption('-Wundef', self.ClangWGroup))
+ self.addOption(JoinedOption('-Wimplicit-function-declaration', self.ClangWGroup))
+ self.addOption(JoinedOption('-Wno-strict-selector-match', self.ClangWGroup))
+
self.WnonportableCfstringsOption = self.addOption(JoinedOption('-Wnonportable-cfstrings', self.WGroup))
self.WnoNonportableCfstringsOption = self.addOption(JoinedOption('-Wno-nonportable-cfstrings', self.WGroup))
self.WOption = self.addOption(JoinedOption('-W', self.WGroup))
+
# FIXME: Weird. This option isn't really separate, --param=a=b
# works. There is something else going on which interprets the
# '='.
Modified: cfe/trunk/tools/ccc/ccclib/Tools.py
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/tools/ccc/ccclib/Tools.py?rev=62241&r1=62240&r2=62241&view=diff
==============================================================================
--- cfe/trunk/tools/ccc/ccclib/Tools.py (original)
+++ cfe/trunk/tools/ccc/ccclib/Tools.py Wed Jan 14 13:42:31 2009
@@ -191,13 +191,8 @@
raise ValueError,"Unexpected output type for clang tool."
arglist.addAllArgs(cmd_args, arglist.parser.vOption)
- arglist.addAllArgs(cmd_args, arglist.parser.f_objcGcOption)
- arglist.addAllArgs(cmd_args, arglist.parser.f_objcGcOnlyOption)
- arglist.addAllArgs(cmd_args, arglist.parser.f_nextRuntimeOption)
- arglist.addAllArgs(cmd_args, arglist.parser.f_gnuRuntimeOption)
arglist.addAllArgs2(cmd_args, arglist.parser.DOption, arglist.parser.UOption)
arglist.addAllArgs2(cmd_args, arglist.parser.IOption, arglist.parser.FOption)
- arglist.addAllArgs(cmd_args, arglist.parser.stdOption)
arglist.addAllArgs(cmd_args, arglist.parser.m_macosxVersionMinOption)
# Special case debug options to only pass -g to clang. This is
@@ -205,12 +200,31 @@
if arglist.getLastArg(arglist.parser.gGroup):
cmd_args.append('-g')
+ arglist.addLastArg(cmd_args, arglist.parser.nostdincOption)
+
# FIXME: Clang isn't going to accept just anything here.
arglist.addAllArgs(cmd_args, arglist.parser.iGroup)
# FIXME: Dehardcode this.
cmd_args.append('-fblocks')
+ arglist.addAllArgs(cmd_args, arglist.parser.OOption)
+ arglist.addAllArgs2(cmd_args, arglist.parser.ClangWGroup, arglist.parser.pedanticGroup)
+ arglist.addLastArg(cmd_args, arglist.parser.wOption)
+ arglist.addAllArgs3(cmd_args, arglist.parser.stdOption, arglist.parser.ansiOption, arglist.parser.trigraphsOption)
+
+ arglist.addAllArgs(cmd_args, arglist.parser.f_objcGcOption)
+ arglist.addAllArgs(cmd_args, arglist.parser.f_objcGcOnlyOption)
+ arglist.addAllArgs(cmd_args, arglist.parser.f_nextRuntimeOption)
+ arglist.addAllArgs(cmd_args, arglist.parser.f_gnuRuntimeOption)
+ arglist.addLastArg(cmd_args, arglist.parser.f_exceptionsOption)
+ arglist.addLastArg(cmd_args, arglist.parser.f_laxVectorConversionsOption)
+ arglist.addLastArg(cmd_args, arglist.parser.f_msExtensionsOption)
+ arglist.addLastArg(cmd_args, arglist.parser.f_noCaretDiagnosticsOption)
+ arglist.addLastArg(cmd_args, arglist.parser.f_noShowColumnOption)
+ arglist.addLastArg(cmd_args, arglist.parser.f_pascalStringsOption)
+ arglist.addLastArg(cmd_args, arglist.parser.f_writableStringsOption)
+
if arch is not None:
cmd_args.extend(arglist.render(arch))
@@ -474,10 +488,10 @@
cmd_args.append(self.getBaseInputStem(inputs, arglist))
arglist.addAllArgs(cmd_args, arglist.parser.gGroup)
-
+
arglist.addAllArgs(cmd_args, arglist.parser.OOption)
# FIXME: -Wall is getting some special treatment. Investigate.
- arglist.addAllArgs2(cmd_args, arglist.parser.WGroup, arglist.parser.pedanticOption)
+ arglist.addAllArgs2(cmd_args, arglist.parser.WGroup, arglist.parser.pedanticGroup)
arglist.addLastArg(cmd_args, arglist.parser.wOption)
arglist.addAllArgs3(cmd_args, arglist.parser.stdOption, arglist.parser.ansiOption, arglist.parser.trigraphsOption)
if arglist.getLastArg(arglist.parser.vOption):
More information about the cfe-commits
mailing list