diff options
author | Chandler Carruth <chandlerc@gmail.com> | 2011-04-23 19:48:40 +0000 |
---|---|---|
committer | Chandler Carruth <chandlerc@gmail.com> | 2011-04-23 19:48:40 +0000 |
commit | 30483fb188fe76e28f2d6e608db008549ef6d673 (patch) | |
tree | 457836f329d608f78661a0b56f4f1fb6579ff9a4 /clang/lib/Driver/Tools.cpp | |
parent | dbbdd2fe50e05c3f0da240b774e4d267e3c980cf (diff) | |
download | bcm5719-llvm-30483fb188fe76e28f2d6e608db008549ef6d673.tar.gz bcm5719-llvm-30483fb188fe76e28f2d6e608db008549ef6d673.zip |
Move all of the logic for __DEPRECATED to the driver based on comments
from dgregor.
llvm-svn: 130066
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
-rw-r--r-- | clang/lib/Driver/Tools.cpp | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index f5dacfa6cfa..2e74e272cb0 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/lib/Driver/Tools.cpp @@ -1363,14 +1363,12 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA, } // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active - // during C++ compilation. CC1 uses '-fdeprecated-macro' to control this. - // Both '-Wdeprecated' and '-fdeprecated-macro' default to on, so the flag - // logic here is inverted. - if (Args.hasFlag(options::OPT_Wno_deprecated, options::OPT_Wdeprecated, - false)) { - // GCC keeps this define even in the presence of '-w', match this behavior - // bug-for-bug. - CmdArgs.push_back("-fno-deprecated-macro"); + // during C++ compilation, which it is by default. GCC keeps this define even + // in the presence of '-w', match this behavior bug-for-bug. + if (types::isCXX(InputType) && + Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated, + true)) { + CmdArgs.push_back("-fdeprecated-macro"); } // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'. |