r295379 - Properly set up the DeclContext for parameters of implicit deduction guides;
Eric Fiselier via cfe-commits
cfe-commits at lists.llvm.org
Thu Feb 16 22:38:32 PST 2017
I put my attempt to fix this up for review:
https://reviews.llvm.org/D30082
On Thu, Feb 16, 2017 at 10:17 PM, Eric Fiselier <eric at efcs.ca> wrote:
> Hi Richard,
>
> One more issue. When compiling with `-g` the following code hits a
> `llvm_unreachable` in CGDebugInfo::CreateTypeNode.
>
> template <class T> struct S { S(T) {} };
> S s(42);
>
> /Eric
>
> On Thu, Feb 16, 2017 at 2:29 PM, Richard Smith via cfe-commits <
> cfe-commits at lists.llvm.org> wrote:
>
>> Author: rsmith
>> Date: Thu Feb 16 15:29:21 2017
>> New Revision: 295379
>>
>> URL: http://llvm.org/viewvc/llvm-project?rev=295379&view=rev
>> Log:
>> Properly set up the DeclContext for parameters of implicit deduction
>> guides;
>> this is needed for deferred instantiation of default arguments.
>>
>> Modified:
>> cfe/trunk/lib/Sema/SemaTemplate.cpp
>> cfe/trunk/test/SemaCXX/cxx1z-class-template-argument-deduction.cpp
>>
>> Modified: cfe/trunk/lib/Sema/SemaTemplate.cpp
>> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaT
>> emplate.cpp?rev=295379&r1=295378&r2=295379&view=diff
>> ============================================================
>> ==================
>> --- cfe/trunk/lib/Sema/SemaTemplate.cpp (original)
>> +++ cfe/trunk/lib/Sema/SemaTemplate.cpp Thu Feb 16 15:29:21 2017
>> @@ -1677,6 +1677,9 @@ private:
>> bool Explicit, TypeSourceInfo *TInfo,
>> SourceLocation LocStart, SourceLocation
>> Loc,
>> SourceLocation LocEnd) {
>> + ArrayRef<ParmVarDecl *> Params =
>> + TInfo->getTypeLoc().castAs<FunctionProtoTypeLoc>().getParams();
>> +
>> // Build the implicit deduction guide template.
>> auto *Guide = FunctionDecl::Create(SemaRef.Context, DC, LocStart,
>> Loc,
>> DeductionGuideName,
>> TInfo->getType(),
>> @@ -1685,8 +1688,10 @@ private:
>> if (Explicit)
>> Guide->setExplicitSpecified();
>> Guide->setRangeEnd(LocEnd);
>> - Guide->setParams(
>> - TInfo->getTypeLoc().castAs<FunctionProtoTypeLoc>().getParams());
>> + Guide->setParams(Params);
>> +
>> + for (auto *Param : Params)
>> + Param->setDeclContext(Guide);
>>
>> auto *GuideTemplate = FunctionTemplateDecl::Create(
>> SemaRef.Context, DC, Loc, DeductionGuideName, TemplateParams,
>> Guide);
>>
>> Modified: cfe/trunk/test/SemaCXX/cxx1z-class-template-argument-deducti
>> on.cpp
>> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/
>> cxx1z-class-template-argument-deduction.cpp?rev=295379&r1=
>> 295378&r2=295379&view=diff
>> ============================================================
>> ==================
>> --- cfe/trunk/test/SemaCXX/cxx1z-class-template-argument-deduction.cpp
>> (original)
>> +++ cfe/trunk/test/SemaCXX/cxx1z-class-template-argument-deduction.cpp
>> Thu Feb 16 15:29:21 2017
>> @@ -168,3 +168,11 @@ namespace nondeducible {
>> typename ...B>
>> X(float) -> X<A, B...>; // ok
>> }
>> +
>> +namespace default_args_from_ctor {
>> + template <class A> struct S { S(A = 0) {} };
>> + S s(0);
>> +
>> + template <class A> struct T { template<typename B> T(A = 0, B = 0) {}
>> };
>> + T t(0, 0);
>> +}
>>
>>
>> _______________________________________________
>> cfe-commits mailing list
>> cfe-commits at lists.llvm.org
>> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
>>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20170216/7c7df26f/attachment-0001.html>
More information about the cfe-commits
mailing list