]> granicus.if.org Git - clang/commitdiff
Revert "Sema: An extern declaration can't be a redeclaration of a parameter"
authorDavid Majnemer <david.majnemer@gmail.com>
Tue, 13 Jan 2015 10:14:57 +0000 (10:14 +0000)
committerDavid Majnemer <david.majnemer@gmail.com>
Tue, 13 Jan 2015 10:14:57 +0000 (10:14 +0000)
This reverts commit r225780, we can't compile line 181 in
sanitizer_platform_limits_posix.cc with this commit.

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

lib/Sema/SemaDecl.cpp
test/Sema/private-extern.c

index 82ffd4da5f8790fff60fff39c6b5e521d35575db..baa6822da71eef0ab7eb5f0bb709c4a36c1eb16a 100644 (file)
@@ -3282,12 +3282,14 @@ void Sema::MergeVarDecl(VarDecl *New, LookupResult &Previous) {
   }
 
   // Check if extern is followed by non-extern and vice-versa.
-  if (New->hasGlobalStorage() && !Old->hasLinkage() && Old->hasLocalStorage()) {
+  if (New->hasExternalStorage() &&
+      !Old->hasLinkage() && Old->isLocalVarDecl()) {
     Diag(New->getLocation(), diag::err_extern_non_extern) << New->getDeclName();
     Diag(OldLocation, PrevDiag);
     return New->setInvalidDecl();
   }
-  if (Old->hasGlobalStorage() && !New->hasLinkage() && New->hasLocalStorage()) {
+  if (Old->hasLinkage() && New->isLocalVarDecl() &&
+      !New->hasExternalStorage()) {
     Diag(New->getLocation(), diag::err_non_extern_extern) << New->getDeclName();
     Diag(OldLocation, PrevDiag);
     return New->setInvalidDecl();
index 94afd87fbb8743500ea9573ad4b6b53913e917ab..0c13c92bba7749fab38653b6f04d559705e85efd 100644 (file)
@@ -83,7 +83,3 @@ __private_extern__ int g19;
 int g19 = 0;
 
 __private_extern__ int g20 = 0;
-
-void f10(int g20) { // expected-note{{previous definition is here}}
-  extern int g20; // expected-error{{extern declaration of 'g20' follows non-extern declaration}}
-}