Don't special case one line extern "C" decls.
authorRafael Espindola <rafael.espindola@gmail.com>
Fri, 29 Mar 2013 07:02:31 +0000 (07:02 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Fri, 29 Mar 2013 07:02:31 +0000 (07:02 +0000)
We already avoided warning for

extern "C" const char *Version_string = "2.9";

now we also don't produce any warnings for

extern "C" {
  extern const char *Version_string2 = "2.9";
}

llvm-svn: 178333

clang/lib/Sema/SemaDecl.cpp
clang/test/SemaCXX/linkage-spec.cpp

index ab4a17a..1c6bbed 100644 (file)
@@ -7565,6 +7565,7 @@ void Sema::AddInitializerToDecl(Decl *RealDecl, Expr *Init,
     }
   } else if (VDecl->isFileVarDecl()) {
     if (VDecl->getStorageClassAsWritten() == SC_Extern &&
+        !VDecl->isExternC() &&
         (!getLangOpts().CPlusPlus ||
          !Context.getBaseElementType(VDecl->getType()).isConstQualified()))
       Diag(VDecl->getLocation(), diag::warn_extern_init);
index cb7e32c..0ba9508 100644 (file)
@@ -90,6 +90,10 @@ extern "C++" using N::value;
 // PR7076
 extern "C" const char *Version_string = "2.9";
 
+extern "C" {
+  extern const char *Version_string2 = "2.9";
+}
+
 namespace PR9162 {
   extern "C" {
     typedef struct _ArtsSink ArtsSink;