[cfe-commits] r124856 - in /cfe/trunk: include/clang/Sema/Sema.h lib/Sema/SemaDecl.cpp lib/Sema/SemaTemplate.cpp test/CXX/temp/temp.param/p9-0x.cpp
Douglas Gregor
dgregor at apple.com
Fri Feb 4 04:26:54 PST 2011
I meant PR8748; test case fixed in r124863.
- Doug
On Feb 3, 2011, at 9:59 PM, Nick Lewycky wrote:
> On 3 February 2011 20:20, Douglas Gregor <dgregor at apple.com> wrote:
> Author: dgregor
> Date: Thu Feb 3 22:20:44 2011
> New Revision: 124856
>
> URL: http://llvm.org/viewvc/llvm-project?rev=124856&view=rev
> Log:
> Tighten up the semantics of default template arguments, per C++0x
> [temp.param]p9 and C++ DR226. Fixes PR8747.
>
> Hi Doug, I suspect this is the wrong PR#?
>
> Nick
>
>
> Modified:
> cfe/trunk/include/clang/Sema/Sema.h
> cfe/trunk/lib/Sema/SemaDecl.cpp
> cfe/trunk/lib/Sema/SemaTemplate.cpp
> cfe/trunk/test/CXX/temp/temp.param/p9-0x.cpp
>
> Modified: cfe/trunk/include/clang/Sema/Sema.h
> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Sema/Sema.h?rev=124856&r1=124855&r2=124856&view=diff
> ==============================================================================
> --- cfe/trunk/include/clang/Sema/Sema.h (original)
> +++ cfe/trunk/include/clang/Sema/Sema.h Thu Feb 3 22:20:44 2011
> @@ -2914,7 +2914,8 @@
> TPC_ClassTemplate,
> TPC_FunctionTemplate,
> TPC_ClassTemplateMember,
> - TPC_FriendFunctionTemplate
> + TPC_FriendFunctionTemplate,
> + TPC_FriendFunctionTemplateDefinition
> };
>
> bool CheckTemplateParameterList(TemplateParameterList *NewParams,
>
> Modified: cfe/trunk/lib/Sema/SemaDecl.cpp
> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDecl.cpp?rev=124856&r1=124855&r2=124856&view=diff
> ==============================================================================
> --- cfe/trunk/lib/Sema/SemaDecl.cpp (original)
> +++ cfe/trunk/lib/Sema/SemaDecl.cpp Thu Feb 3 22:20:44 2011
> @@ -3967,8 +3967,14 @@
> FunctionTemplateDecl *PrevTemplate = FunctionTemplate->getPreviousDeclaration();
> CheckTemplateParameterList(FunctionTemplate->getTemplateParameters(),
> PrevTemplate? PrevTemplate->getTemplateParameters() : 0,
> - D.getDeclSpec().isFriendSpecified()? TPC_FriendFunctionTemplate
> - : TPC_FunctionTemplate);
> + D.getDeclSpec().isFriendSpecified()
> + ? (IsFunctionDefinition
> + ? TPC_FriendFunctionTemplateDefinition
> + : TPC_FriendFunctionTemplate)
> + : (D.getCXXScopeSpec().isSet() &&
> + DC && DC->isRecord())
> + ? TPC_ClassTemplateMember
> + : TPC_FunctionTemplate);
> }
>
> if (NewFD->isInvalidDecl()) {
>
> Modified: cfe/trunk/lib/Sema/SemaTemplate.cpp
> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaTemplate.cpp?rev=124856&r1=124855&r2=124856&view=diff
> ==============================================================================
> --- cfe/trunk/lib/Sema/SemaTemplate.cpp (original)
> +++ cfe/trunk/lib/Sema/SemaTemplate.cpp Thu Feb 3 22:20:44 2011
> @@ -946,7 +946,10 @@
> // template declaration.
> if (CheckTemplateParameterList(TemplateParams,
> PrevClassTemplate? PrevClassTemplate->getTemplateParameters() : 0,
> - TPC_ClassTemplate))
> + (SS.isSet() && SemanticContext &&
> + SemanticContext->isRecord())
> + ? TPC_ClassTemplateMember
> + : TPC_ClassTemplate))
> Invalid = true;
>
> if (SS.isSet()) {
> @@ -1045,11 +1048,15 @@
> return false;
>
> case Sema::TPC_FunctionTemplate:
> + case Sema::TPC_FriendFunctionTemplateDefinition:
> // C++ [temp.param]p9:
> // A default template-argument shall not be specified in a
> // function template declaration or a function template
> // definition [...]
> - // (This sentence is not in C++0x, per DR226).
> + // If a friend function template declaration specifies a default
> + // template-argument, that declaration shall be a definition and shall be
> + // the only declaration of the function template in the translation unit.
> + // (C++98/03 doesn't have this wording; see DR226).
> if (!S.getLangOptions().CPlusPlus0x)
> S.Diag(ParamLoc,
> diag::ext_template_parameter_default_in_function_template)
>
> Modified: cfe/trunk/test/CXX/temp/temp.param/p9-0x.cpp
> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CXX/temp/temp.param/p9-0x.cpp?rev=124856&r1=124855&r2=124856&view=diff
> ==============================================================================
> --- cfe/trunk/test/CXX/temp/temp.param/p9-0x.cpp (original)
> +++ cfe/trunk/test/CXX/temp/temp.param/p9-0x.cpp Thu Feb 3 22:20:44 2011
> @@ -12,3 +12,41 @@
>
> template<template<class> class ...Templates = vector> // expected-error{{template parameter pack cannot have a default argument}}
> struct X2;
> +
> +struct X3 {
> + template<typename T = int> // expected-error{{default template argument not permitted on a friend template}}
> + friend void f0(X3);
> +
> + template<typename T = int>
> + friend void f1(X3) {
> + }
> +};
> +
> +namespace PR8747 {
> + // Testcase 1
> + struct A0 { template<typename U> struct B; };
> + template<typename U = int> struct A0::B { }; // expected-error{{cannot add a default template argument to the definition of a member of a class template}}
> +
> + // Testcase 2
> + template<typename T> struct A1 { template<typename U> struct B; };
> + template<typename T> template<typename U = int> struct A1<T>::B { }; // expected-error{{cannot add a default template argument to the definition of a member of a class template}}
> +
> + // Testcase 3
> + template<typename T>
> + struct X2 {
> + void f0();
> + template<typename U> void f1();
> + };
> +
> + template<typename T = int> void X2<T>::f0() { } // expected-error{{cannot add a default template argument to the definition of a member of a class template}}
> + template<typename T> template<typename U = int> void X2<T>::f1() { } // expected-error{{cannot add a default template argument to the definition of a member of a class template}}
> +
> + namespace Inner {
> + template<typename T> struct X3;
> + template<typename T> void f2();
> + }
> +
> + // Okay; not class members.
> + template<typename T = int> struct Inner::X3 { };
> + template<typename T = int> void Inner::f2() {}
> +}
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20110204/3cf8b4c9/attachment.html>
More information about the cfe-commits
mailing list