]> granicus.if.org Git - clang/commitdiff
Fix Clang's __DEPRECATED define to be controled by -Wdeprecated. This
authorChandler Carruth <chandlerc@gmail.com>
Sat, 23 Apr 2011 09:27:53 +0000 (09:27 +0000)
committerChandler Carruth <chandlerc@gmail.com>
Sat, 23 Apr 2011 09:27:53 +0000 (09:27 +0000)
matches GCC behavior which libstdc++ uses to limit #warning-based
messages about deprecation.

The machinery involves threading this through a new '-fdeprecated-macro'
flag for CC1. The flag defaults to "on", similarly to -Wdeprecated. We
turn the flag off in the driver when the warning is turned off (modulo
matching some GCC bugs). We record this as a language option, and key
the preprocessor on the option when introducing the define.

A separate flag rather than a '-D' flag allows us to properly represent
the difference between C and C++ builds (only C++ receives the define),
and it allows the specific behavior of following -Wdeprecated without
potentially impacting the set of user-provided macro flags.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@130055 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Basic/LangOptions.h
include/clang/Driver/CC1Options.td
include/clang/Driver/Options.td
lib/Driver/Tools.cpp
lib/Frontend/CompilerInvocation.cpp
lib/Frontend/InitPreprocessor.cpp
test/Driver/clang_f_opts.c

index 91287815cd59c0c7347804437799a002e0db0f86..2b1319c1a0b587e12991104bcee92a4e0bfc3d94 100644 (file)
@@ -89,6 +89,8 @@ public:
                                   // used (instead of C99 semantics).
   unsigned NoInline          : 1; // Should __NO_INLINE__ be defined.
 
+  unsigned Deprecated        : 1; // Should __DEPRECATED be defined.
+
   unsigned ObjCGCBitmapPrint : 1; // Enable printing of gc's bitmap layout
                                   // for __weak/__strong ivars.
 
@@ -213,6 +215,8 @@ public:
     GNUInline = 0;
     NoInline = 0;
 
+    Deprecated = 1;  // -Wdeprecated defaults to "on".
+
     CharIsSigned = 1;
     ShortWChar = 0;
     ShortEnums = 0;
index 442488bf87dca1d56c25d460c46a58a359b78763..716e27b903411f8b6a5fb5ca3176be57d269f5e7 100644 (file)
@@ -539,6 +539,10 @@ def fdelayed_template_parsing : Flag<"-fdelayed-template-parsing">,
            "translation unit ">;
 def funknown_anytype : Flag<"-funknown-anytype">,
   HelpText<"Enable parser support for the __unknown_anytype type; for testing purposes only">;
+def fdeprecated_macro : Flag<"-fdeprecated-macro">,
+  HelpText<"Defines the __DEPRECATED macro in C++ compilations">;
+def fno_deprecated_macro : Flag<"-fno-deprecated-macro">,
+  HelpText<"Undefines the __DEPRECATED macro in C++ compilations">;
 
 //===----------------------------------------------------------------------===//
 // Header Search Options
index 06b3d347c04491dcf559b9c0639e00f1e6997773..b31da00ecaee2b06b269e435e741d79c865621de 100644 (file)
@@ -166,6 +166,8 @@ def Wa_COMMA : CommaJoined<"-Wa,">,
   HelpText<"Pass the comma separated arguments in <arg> to the assembler">,
   MetaVarName<"<arg>">;
 def Wall : Flag<"-Wall">, Group<W_Group>;
+def Wdeprecated : Flag<"-Wdeprecated">, Group<W_Group>;
+def Wno_deprecated : Flag<"-Wno-deprecated">, Group<W_Group>;
 def Wextra : Flag<"-Wextra">, Group<W_Group>;
 def Wl_COMMA : CommaJoined<"-Wl,">, Flags<[LinkerInput, RenderAsInput]>,
   HelpText<"Pass the comma separated arguments in <arg> to the linker">,
index 436a2a42a42e7f699e009f75608aec44cb70b1d2..f5dacfa6cfa28c7f416eec9be7ea7231b426c23a 100644 (file)
@@ -1362,6 +1362,17 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
     CmdArgs.push_back("-fconst-strings");
   }
 
+  // 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");
+  }
+
   // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
   if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
     if (Asm->getOption().matches(options::OPT_fasm))
index 0dd2093b7a00da44dc53bfb751a28789f40870ba..daaaad0c2c6dfdb4e222b195abe3b820e8acf303 100644 (file)
@@ -694,6 +694,8 @@ static void LangOptsToArgs(const LangOptions &Opts,
     Res.push_back("-funknown-anytype");
   if (Opts.DelayedTemplateParsing)
     Res.push_back("-fdelayed-template-parsing");
+  if (!Opts.Deprecated)
+    Res.push_back("-fno-deprecated-macro");
 }
 
 static void PreprocessorOptsToArgs(const PreprocessorOptions &Opts,
@@ -1528,6 +1530,11 @@ static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK,
   Opts.FakeAddressSpaceMap = Args.hasArg(OPT_ffake_address_space_map);
   Opts.ParseUnknownAnytype = Args.hasArg(OPT_funknown_anytype);
 
+  // Record whether the __DEPRECATED define was requested.
+  Opts.Deprecated = Args.hasFlag(OPT_fdeprecated_macro,
+                                 OPT_fno_deprecated_macro,
+                                 Opts.Deprecated);
+
   // FIXME: Eliminate this dependency.
   unsigned Opt = getOptimizationLevel(Args, IK, Diags);
   Opts.Optimize = Opt != 0;
index ff3cf4b9cdb52255fe2e78706f77294e2daa36a7..802d66ff0ea009663097afb200f6c8887cd0e634 100644 (file)
@@ -319,7 +319,8 @@ static void InitializePredefinedMacros(const TargetInfo &TI,
     Builder.defineMacro("__USING_SJLJ_EXCEPTIONS__");
 
   if (LangOpts.CPlusPlus) {
-    Builder.defineMacro("__DEPRECATED");
+    if (LangOpts.Deprecated)
+      Builder.defineMacro("__DEPRECATED");
     Builder.defineMacro("__GNUG__", "4");
     Builder.defineMacro("__GXX_WEAK__");
     if (LangOpts.GNUMode)
index 8d63ca8706e89d29e835c0f0fdd8432161c00fbf..98952e60c1f3ac6489756abd74f4e57305bd9c3c 100644 (file)
 // WRITE-STRINGS2-NOT: -fconst-strings
 // RUN: %clang -### -S -Wwrite-strings -w %s 2>&1 | FileCheck -check-prefix=WRITE-STRINGS3 %s
 // WRITE-STRINGS3: -fconst-strings
+
+// RUN: %clang -### -c %s 2>&1 | FileCheck -check-prefix=DEPRECATED-ON-CHECK %s
+// RUN: %clang -### -c -Wdeprecated %s 2>&1 | FileCheck -check-prefix=DEPRECATED-ON-CHECK %s
+// RUN: %clang -### -c -Wno-deprecated %s 2>&1 | FileCheck -check-prefix=DEPRECATED-OFF-CHECK %s
+// RUN: %clang -### -c -Wno-deprecated -Wdeprecated %s 2>&1 | FileCheck -check-prefix=DEPRECATED-ON-CHECK %s
+// RUN: %clang -### -c -w %s 2>&1 | FileCheck -check-prefix=DEPRECATED-ON-CHECK %s
+// DEPRECATED-OFF-CHECK: -fno-deprecated-macro
+// DEPRECATED-ON-CHECK-NOT: -fno-deprecated-macro