}
// 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();
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}}
-}