]> granicus.if.org Git - clang/commitdiff
Change our silencing of C typedef redefinition handling to what we had
authorChris Lattner <sabre@nondot.org>
Mon, 27 Apr 2009 01:46:12 +0000 (01:46 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 27 Apr 2009 01:46:12 +0000 (01:46 +0000)
before r69391: typedef redefinition is an error by default, but if
*either* the old or new definition are from a system header, we silence
it.

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

include/clang/Basic/DiagnosticSemaKinds.td
lib/Sema/SemaDecl.cpp
test/Preprocessor/line-directive.c

index 448f16b0b820de1c4270e792f0901883bbcc815d..7225aadbbc1ec04952f90084c3954302db31694e 100644 (file)
@@ -740,9 +740,9 @@ def warn_missing_prototype : Warning<
   InGroup<DiagGroup<"missing-prototypes">>, DefaultIgnore;
 def err_redefinition : Error<"redefinition of %0">;
 
-def warn_redefinition_of_typedef : ExtWarn<
+def warn_redefinition_of_typedef : Warning<
   "redefinition of typedef %0 is invalid in C">,
-  InGroup<DiagGroup<"typedef-redefinition"> >;
+  InGroup<DiagGroup<"typedef-redefinition"> >, DefaultError;
 
 def err_static_non_static : Error<
   "static declaration of %0 follows non-static declaration">;
index 1ea3a9ec3c7ccd4bf7c300003b37abaf63d5bf4b..482c304603b824add8ca868b987bf3be62718948 100644 (file)
@@ -560,7 +560,12 @@ void Sema::MergeTypeDefDecl(TypedefDecl *New, Decl *OldD) {
 
   // If we have a redefinition of a typedef in C, emit a warning.  This warning
   // is normally mapped to an error, but can be controlled with
-  // -Wtypedef-redefinition.
+  // -Wtypedef-redefinition.  If either the original was in a system header,
+  // don't emit this for compatibility with GCC.
+  if (PP.getDiagnostics().getSuppressSystemWarnings() &&
+      Context.getSourceManager().isInSystemHeader(Old->getLocation()))
+    return;
+  
   Diag(New->getLocation(), diag::warn_redefinition_of_typedef)
     << New->getDeclName();
   Diag(Old->getLocation(), diag::note_previous_definition);
index 53e9ab7b5de910532e2b35689ed211dd1544f827..ed9a6c40e5d7e9eaa6531bd10f75e185609af847 100644 (file)
 
 # 192 "glomp.h" // not a system header.
 typedef int x;  // expected-note {{previous definition is here}}
-typedef int x;  // expected-warning {{redefinition of typedef 'x' is invalid in C}}
+typedef int x;  // expected-error {{redefinition of typedef 'x' is invalid in C}}
 
 # 192 "glomp.h" 3 // System header.
 typedef int y;  // ok
 typedef int y;  // ok
 
+typedef int q;  // q is in system header.
+
 #line 42 "blonk.h"  // doesn't change system headerness.
 
 typedef int z;  // ok
@@ -60,8 +62,9 @@ typedef int z1;  // ok
 # 42 "blonk.h"  // DOES change system headerness.
 
 typedef int w;  // expected-note {{previous definition is here}}
-typedef int w;  // expected-warning {{redefinition of typedef 'w' is invalid in C}}
+typedef int w;  // expected-error {{redefinition of typedef 'w' is invalid in C}}
 
+typedef int q;  // original definition in system header, should not diagnose.
 
 // This should not produce an "extra tokens at end of #line directive" warning,
 // because #line is allowed to contain expanded tokens.