diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-01-12 07:40:25 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-01-12 07:40:25 +0000 |
commit | 996ce9646a9eeba7105b015034574d2e323d489b (patch) | |
tree | d3129ce0a56c63cb056b293fd1bf599169e49cd8 /tools/ccc/ccclib/Tools.py | |
parent | 4a0ba1aac16952c38dc65c45a877ea3035478569 (diff) |
ccc: Implement the rest of Darwin/Assembler argument translation.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62081 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/ccc/ccclib/Tools.py')
-rw-r--r-- | tools/ccc/ccclib/Tools.py | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/tools/ccc/ccclib/Tools.py b/tools/ccc/ccclib/Tools.py index 7f3b0cf630..a920982148 100644 --- a/tools/ccc/ccclib/Tools.py +++ b/tools/ccc/ccclib/Tools.py @@ -112,14 +112,32 @@ class DarwinAssembleTool(Tool): input = inputs[0] cmd_args = [] + + if arglist.getLastArg(arglist.parser.gOption): + cmd_args.append('--gstabs') + + # Derived from asm spec. if arch: cmd_args.extend(arglist.render(arch)) cmd_args.append('-force_cpusubtype_ALL') cmd_args.extend(arglist.render(output)) + if (arglist.getLastArg(arglist.parser.m_kernelOption) or + arglist.getLastArg(arglist.parser.staticOption) or + arglist.getLastArg(arglist.parser.f_appleKextOption)): + if not arglist.getLastArg(arglist.parser.ZdynamicOption): + cmd_args.append('-static') + + for arg in arglist.getArgs2(arglist.parser.WaOption, + arglist.parser.XassemblerOption): + cmd_args.extend(arglist.getValues(arg)) + if isinstance(input.source, Jobs.PipedJob): cmd_args.append('-') else: cmd_args.extend(arglist.renderAsInput(input.source)) + + # asm_final spec is empty. + jobs.addJob(Jobs.Command('as', cmd_args)) class GCC_AssembleTool(GCC_Common_Tool): |