зеркало из https://github.com/microsoft/clang-1.git
Driver: Reject -fasm-blocks except on X86 (where we just ignore it, since
passing it is very prevalent in some circles). git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@116761 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
fcec10bded
Коммит
25b26ebdeb
|
@ -53,6 +53,8 @@ def err_drv_no_ast_support : Error<
|
|||
"'%0': unable to use AST files with this tool">;
|
||||
def err_drv_clang_unsupported : Error<
|
||||
"the clang compiler does not support '%0'">;
|
||||
def err_drv_clang_unsupported_per_platform : Error<
|
||||
"the clang compiler does not support '%0' on this platform">;
|
||||
def err_drv_clang_unsupported_opt_cxx_darwin_i386 : Error<
|
||||
"the clang compiler does not support '%0' for C++ on Darwin/i386">;
|
||||
def err_drv_command_failed : Error<
|
||||
|
|
|
@ -237,7 +237,10 @@ def faccess_control : Flag<"-faccess-control">, Group<f_Group>;
|
|||
def fallow_unsupported : Flag<"-fallow-unsupported">, Group<f_Group>;
|
||||
def fapple_kext : Flag<"-fapple-kext">, Group<f_Group>;
|
||||
def fasm : Flag<"-fasm">, Group<f_Group>;
|
||||
def fasm_blocks : Flag<"-fasm-blocks">, Group<clang_ignored_f_Group>;
|
||||
|
||||
def fasm_blocks : Flag<"-fasm-blocks">, Group<f_Group>;
|
||||
def fno_asm_blocks : Flag<"-fno-asm-blocks">, Group<f_Group>;
|
||||
|
||||
def fassume_sane_operator_new : Flag<"-fassume-sane-operator-new">, Group<f_Group>;
|
||||
def fastcp : Flag<"-fastcp">, Group<f_Group>;
|
||||
def fastf : Flag<"-fastf">, Group<f_Group>;
|
||||
|
|
|
@ -1469,6 +1469,18 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
|
|||
options::OPT_fno_spell_checking))
|
||||
CmdArgs.push_back("-fno-spell-checking");
|
||||
|
||||
|
||||
// -fasm-blocks is disallowed except on X86, where we just ignore it.
|
||||
if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
|
||||
false)) {
|
||||
if (getToolChain().getTriple().getArch() != llvm::Triple::x86 &&
|
||||
getToolChain().getTriple().getArch() != llvm::Triple::x86_64)
|
||||
D.Diag(clang::diag::err_drv_clang_unsupported_per_platform)
|
||||
<< "-fasm-blocks";
|
||||
}
|
||||
|
||||
// -fasm-blocks is disallowed except on X86, where we just ignore it.
|
||||
|
||||
if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
|
||||
A->render(Args, CmdArgs);
|
||||
|
||||
|
@ -1577,7 +1589,7 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
|
|||
(*it)->claim();
|
||||
D.Diag(clang::diag::warn_drv_clang_unsupported) << (*it)->getAsString(Args);
|
||||
}
|
||||
|
||||
|
||||
// Claim some arguments which clang supports automatically.
|
||||
|
||||
// -fpch-preprocess is used with gcc to add a special marker in the output to
|
||||
|
|
Загрузка…
Ссылка в новой задаче