Temporary disable the const-object-declaration-without-initializer check, because it depends on linkage-specifier semantics we don't yet have
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@58377 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp
index 78f0d8f..90fe1ee 100644
--- a/lib/Sema/SemaDecl.cpp
+++ b/lib/Sema/SemaDecl.cpp
@@ -1540,6 +1540,12 @@
Var->getName(),
SourceRange(Var->getLocation(), Var->getLocation()));
+#if 0
+ // FIXME: Temporarily disabled because we are not properly parsing
+ // linkage specifications on declarations, e.g.,
+ //
+ // extern "C" const CGPoint CGPointerZero;
+ //
// C++ [dcl.init]p9:
//
// If no initializer is specified for an object, and the
@@ -1558,11 +1564,13 @@
// FIXME: Actually perform the POD/user-defined default
// constructor check.
if (getLangOptions().CPlusPlus &&
- Context.getCanonicalType(Type).isConstQualified())
+ Context.getCanonicalType(Type).isConstQualified() &&
+ Var->getStorageClass() != VarDecl::Extern)
Diag(Var->getLocation(),
diag::err_const_var_requires_init,
Var->getName(),
SourceRange(Var->getLocation(), Var->getLocation()));
+#endif
}
}