ccc: Allow host to over-ride default arch based on command line

arguments (e.g., -m32 and -m64).

llvm-svn: 62145
This commit is contained in:
Daniel Dunbar 2009-01-13 04:05:40 +00:00
parent f343168f1f
commit 8af0d3447e
2 changed files with 15 additions and 7 deletions

View File

@ -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)

View File

@ -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):