forked from OSchip/llvm-project
Driver: Move HostInfo::lookupTypeForExtension to ToolChain::LookupTypeForExtension.
llvm-svn: 110024
This commit is contained in:
parent
a36c2b3a62
commit
cc7df6cc7b
|
@ -10,7 +10,6 @@
|
||||||
#ifndef CLANG_DRIVER_HOSTINFO_H_
|
#ifndef CLANG_DRIVER_HOSTINFO_H_
|
||||||
#define CLANG_DRIVER_HOSTINFO_H_
|
#define CLANG_DRIVER_HOSTINFO_H_
|
||||||
|
|
||||||
#include "clang/Driver/Types.h"
|
|
||||||
#include "llvm/ADT/Triple.h"
|
#include "llvm/ADT/Triple.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
@ -48,10 +47,6 @@ public:
|
||||||
/// this host and support -arch, -Xarch, etc.
|
/// this host and support -arch, -Xarch, etc.
|
||||||
virtual bool useDriverDriver() const = 0;
|
virtual bool useDriverDriver() const = 0;
|
||||||
|
|
||||||
/// lookupTypeForExtension - Return the default language type to use for the
|
|
||||||
/// given extension.
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const = 0;
|
|
||||||
|
|
||||||
/// CreateToolChain - Construct the toolchain to use for this host (which the
|
/// CreateToolChain - Construct the toolchain to use for this host (which the
|
||||||
/// host retains ownership of).
|
/// host retains ownership of).
|
||||||
///
|
///
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
#ifndef CLANG_DRIVER_TOOLCHAIN_H_
|
#ifndef CLANG_DRIVER_TOOLCHAIN_H_
|
||||||
#define CLANG_DRIVER_TOOLCHAIN_H_
|
#define CLANG_DRIVER_TOOLCHAIN_H_
|
||||||
|
|
||||||
|
#include "clang/Driver/Types.h"
|
||||||
#include "llvm/ADT/SmallVector.h"
|
#include "llvm/ADT/SmallVector.h"
|
||||||
#include "llvm/ADT/Triple.h"
|
#include "llvm/ADT/Triple.h"
|
||||||
#include "llvm/System/Path.h"
|
#include "llvm/System/Path.h"
|
||||||
|
@ -89,6 +90,10 @@ public:
|
||||||
|
|
||||||
// Platform defaults information
|
// Platform defaults information
|
||||||
|
|
||||||
|
/// LookupTypeForExtension - Return the default language type to use for the
|
||||||
|
/// given extension.
|
||||||
|
virtual types::ID LookupTypeForExtension(const char *Ext) const;
|
||||||
|
|
||||||
/// IsBlocksDefault - Does this tool chain enable -fblocks by default.
|
/// IsBlocksDefault - Does this tool chain enable -fblocks by default.
|
||||||
virtual bool IsBlocksDefault() const { return false; }
|
virtual bool IsBlocksDefault() const { return false; }
|
||||||
|
|
||||||
|
|
|
@ -662,7 +662,7 @@ void Driver::BuildActions(const ToolChain &TC, const ArgList &Args,
|
||||||
// found. We use a host hook here because Darwin at least has its own
|
// found. We use a host hook here because Darwin at least has its own
|
||||||
// idea of what .s is.
|
// idea of what .s is.
|
||||||
if (const char *Ext = strrchr(Value, '.'))
|
if (const char *Ext = strrchr(Value, '.'))
|
||||||
Ty = Host->lookupTypeForExtension(Ext + 1);
|
Ty = TC.LookupTypeForExtension(Ext + 1);
|
||||||
|
|
||||||
if (Ty == types::TY_INVALID)
|
if (Ty == types::TY_INVALID)
|
||||||
Ty = types::TY_Object;
|
Ty = types::TY_Object;
|
||||||
|
|
|
@ -53,17 +53,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
types::ID Ty = types::lookupTypeForExtension(Ext);
|
|
||||||
|
|
||||||
// Darwin always preprocesses assembly files (unless -x is used
|
|
||||||
// explicitly).
|
|
||||||
if (Ty == types::TY_PP_Asm)
|
|
||||||
return types::TY_Asm;
|
|
||||||
|
|
||||||
return Ty;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -170,15 +159,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
types::ID Ty = types::lookupTypeForExtension(Ext);
|
|
||||||
|
|
||||||
if (Ty == types::TY_PP_Asm)
|
|
||||||
return types::TY_Asm;
|
|
||||||
|
|
||||||
return Ty;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -212,10 +192,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
return types::lookupTypeForExtension(Ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -279,10 +255,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
return types::lookupTypeForExtension(Ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -330,10 +302,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
return types::lookupTypeForExtension(Ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -379,10 +347,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
return types::lookupTypeForExtension(Ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -439,10 +403,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
return types::lookupTypeForExtension(Ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -491,10 +451,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
return types::lookupTypeForExtension(Ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
@ -540,10 +496,6 @@ public:
|
||||||
|
|
||||||
virtual bool useDriverDriver() const;
|
virtual bool useDriverDriver() const;
|
||||||
|
|
||||||
virtual types::ID lookupTypeForExtension(const char *Ext) const {
|
|
||||||
return types::lookupTypeForExtension(Ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
virtual ToolChain *CreateToolChain(const ArgList &Args,
|
||||||
const char *ArchName) const;
|
const char *ArchName) const;
|
||||||
};
|
};
|
||||||
|
|
|
@ -34,3 +34,7 @@ std::string ToolChain::GetFilePath(const char *Name) const {
|
||||||
std::string ToolChain::GetProgramPath(const char *Name, bool WantFile) const {
|
std::string ToolChain::GetProgramPath(const char *Name, bool WantFile) const {
|
||||||
return Host.getDriver().GetProgramPath(Name, *this, WantFile);
|
return Host.getDriver().GetProgramPath(Name, *this, WantFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
types::ID ToolChain::LookupTypeForExtension(const char *Ext) const {
|
||||||
|
return types::lookupTypeForExtension(Ext);
|
||||||
|
}
|
||||||
|
|
|
@ -40,6 +40,16 @@ Darwin::Darwin(const HostInfo &Host, const llvm::Triple& Triple,
|
||||||
<< _DarwinVersion[1];
|
<< _DarwinVersion[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
types::ID Darwin::LookupTypeForExtension(const char *Ext) const {
|
||||||
|
types::ID Ty = types::lookupTypeForExtension(Ext);
|
||||||
|
|
||||||
|
// Darwin always preprocesses assembly files (unless -x is used explicitly).
|
||||||
|
if (Ty == types::TY_PP_Asm)
|
||||||
|
return types::TY_Asm;
|
||||||
|
|
||||||
|
return Ty;
|
||||||
|
}
|
||||||
|
|
||||||
// FIXME: Can we tablegen this?
|
// FIXME: Can we tablegen this?
|
||||||
static const char *GetArmArchForMArch(llvm::StringRef Value) {
|
static const char *GetArmArchForMArch(llvm::StringRef Value) {
|
||||||
if (Value == "armv6k")
|
if (Value == "armv6k")
|
||||||
|
|
|
@ -147,6 +147,8 @@ public:
|
||||||
/// @name ToolChain Implementation
|
/// @name ToolChain Implementation
|
||||||
/// {
|
/// {
|
||||||
|
|
||||||
|
virtual types::ID LookupTypeForExtension(const char *Ext) const;
|
||||||
|
|
||||||
virtual DerivedArgList *TranslateArgs(const DerivedArgList &Args,
|
virtual DerivedArgList *TranslateArgs(const DerivedArgList &Args,
|
||||||
const char *BoundArch) const;
|
const char *BoundArch) const;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue