diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-01-13 04:05:40 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-01-13 04:05:40 +0000 |
commit | 1f73ecb228129fc3c00b04196fb0ea0fab1da145 (patch) | |
tree | 31f39d71539c33e9b0ace3577c378d7f54734af3 | |
parent | 2a3eb0e22e671112ab19b62e9a40615d195a7f17 (diff) |
ccc: Allow host to over-ride default arch based on command line
arguments (e.g., -m32 and -m64).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62145 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | tools/ccc/ccclib/Driver.py | 2 | ||||
-rw-r--r-- | tools/ccc/ccclib/HostInfo.py | 20 |
2 files changed, 15 insertions, 7 deletions
diff --git a/tools/ccc/ccclib/Driver.py b/tools/ccc/ccclib/Driver.py index 1685f0b93a..46b4541fc4 100644 --- a/tools/ccc/ccclib/Driver.py +++ b/tools/ccc/ccclib/Driver.py @@ -466,7 +466,7 @@ class Driver(object): hasDashM = arg if not archs: - archs.append(args.makeSeparateArg(self.hostInfo.getArchName(), + archs.append(args.makeSeparateArg(self.hostInfo.getArchName(args), self.parser.archOption)) actions = self.buildNormalPipeline(args) diff --git a/tools/ccc/ccclib/HostInfo.py b/tools/ccc/ccclib/HostInfo.py index 12fdfef404..d976138eec 100644 --- a/tools/ccc/ccclib/HostInfo.py +++ b/tools/ccc/ccclib/HostInfo.py @@ -8,7 +8,7 @@ class HostInfo(object): def __init__(self, driver): self.driver = driver - def getArchName(self): + def getArchName(self, args): abstract def useDriverDriver(self): @@ -38,7 +38,7 @@ class DarwinHostInfo(HostInfo): return True def getToolChain(self): - return self.getToolChainForArch(self.getArchName()) + return self.getToolChainForArch(self.getArchName(None)) def getToolChainForArch(self, arch): if arch in ('i386', 'x86_64'): @@ -49,19 +49,27 @@ class DarwinHostInfo(HostInfo): return ToolChain.Generic_GCC_ToolChain(self.driver) class DarwinPPCHostInfo(DarwinHostInfo): - def getArchName(self): + def getArchName(self, args): + if args and args.getLastArg(args.parser.m_64Option): + return 'ppc64' return 'ppc' class DarwinPPC_64HostInfo(DarwinHostInfo): - def getArchName(self): + def getArchName(self, args): + if args and args.getLastArg(args.parser.m_32Option): + return 'ppc' return 'ppc64' class DarwinX86HostInfo(DarwinHostInfo): - def getArchName(self): + def getArchName(self, args): + if args and args.getLastArg(args.parser.m_64Option): + return 'x86_64' return 'i386' class DarwinX86_64HostInfo(DarwinHostInfo): - def getArchName(self): + def getArchName(self, args): + if args and args.getLastArg(args.parser.m_32Option): + return 'i386' return 'x86_64' def getDarwinHostInfo(driver): |