diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-07-27 17:43:39 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-07-27 17:43:39 +0000 |
commit | d612997e732be3863fd613dda96c09ff3793c1f1 (patch) | |
tree | 4b0ed7a119c7fbed69cfcdaa6c2f41040a2328dd | |
parent | e48c85fa8be7ddb4ff296f6b95fedfed7747b1d1 (diff) | |
download | bcm5719-llvm-d612997e732be3863fd613dda96c09ff3793c1f1.tar.gz bcm5719-llvm-d612997e732be3863fd613dda96c09ff3793c1f1.zip |
When instantiating a variable without an initializer, call
ActOnUninitializedDecl.
llvm-svn: 77211
-rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateDecl.cpp | 5 | ||||
-rw-r--r-- | clang/test/SemaTemplate/instantiate-static-var.cpp | 22 |
2 files changed, 24 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp index a6513f16726..b04b63523df 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp @@ -146,9 +146,8 @@ Decl *TemplateDeclInstantiator::VisitVarDecl(VarDecl *D) { else SemaRef.AddInitializerToDecl(Sema::DeclPtrTy::make(Var), move(Init), D->hasCXXDirectInitializer()); - } else { - // FIXME: Call ActOnUninitializedDecl? (Not always) - } + } else if (!Var->isStaticDataMember() || Var->isOutOfLine()) + SemaRef.ActOnUninitializedDecl(Sema::DeclPtrTy::make(Var), false); // Link instantiations of static data members back to the template from // which they were instantiated. diff --git a/clang/test/SemaTemplate/instantiate-static-var.cpp b/clang/test/SemaTemplate/instantiate-static-var.cpp index 99e6b9cc06c..ebf6658ba3a 100644 --- a/clang/test/SemaTemplate/instantiate-static-var.cpp +++ b/clang/test/SemaTemplate/instantiate-static-var.cpp @@ -16,3 +16,25 @@ class Y { }; Y<float> fy; // expected-note{{in instantiation of template class 'class Y<float>' requested here}} + + +// out-of-line static member variables + +template<typename T> +struct Z { + static T value; +}; + +template<typename T> +T Z<T>::value; // expected-error{{no matching constructor}} + +struct DefCon {}; + +struct NoDefCon { + NoDefCon(const NoDefCon&); +}; + +void test() { + DefCon &DC = Z<DefCon>::value; + NoDefCon &NDC = Z<NoDefCon>::value; // expected-note{{instantiation}} +}
\ No newline at end of file |