From: ibuclaw Date: Sun, 16 Jun 2019 07:47:57 +0000 (+0000) Subject: PR d/90661 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=28d90f3a13cb0fe17fc3c327e62d4449182120b1;p=thirdparty%2Fgcc.git PR d/90661 d/dmd: Merge upstream dmd c74e624c9 Fixes segmentation fault in AlignDeclaration::syntaxCopy. Reviewed-on: https://github.com/dlang/dmd/pull/10001 git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@272341 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/d/dmd/MERGE b/gcc/d/dmd/MERGE index e100264fed85..6edc63a20142 100644 --- a/gcc/d/dmd/MERGE +++ b/gcc/d/dmd/MERGE @@ -1,4 +1,4 @@ -78dc311524341a76008b341ff6427e5a16e285db +c74e624c9a0a9e7e39f96b2f005f86e123df56c9 The first line of this file holds the git revision number of the last merge done from the dlang/dmd repository. diff --git a/gcc/d/dmd/attrib.c b/gcc/d/dmd/attrib.c index a66863814859..6cd715ce08b6 100644 --- a/gcc/d/dmd/attrib.c +++ b/gcc/d/dmd/attrib.c @@ -667,7 +667,8 @@ Dsymbol *AlignDeclaration::syntaxCopy(Dsymbol *s) { assert(!s); return new AlignDeclaration(loc, - ealign->syntaxCopy(), Dsymbol::arraySyntaxCopy(decl)); + ealign ? ealign->syntaxCopy() : NULL, + Dsymbol::arraySyntaxCopy(decl)); } Scope *AlignDeclaration::newScope(Scope *sc) diff --git a/gcc/testsuite/gdc.test/compilable/aggr_alignment.d b/gcc/testsuite/gdc.test/compilable/aggr_alignment.d index 3a80a039e26e..bf602ff31a47 100644 --- a/gcc/testsuite/gdc.test/compilable/aggr_alignment.d +++ b/gcc/testsuite/gdc.test/compilable/aggr_alignment.d @@ -26,3 +26,16 @@ enum payloadOffset = C2.bytes.offsetof; static assert(C2.int1.offsetof == payloadOffset + 8); static assert(C2.alignof == size_t.sizeof); static assert(__traits(classInstanceSize, C2) == payloadOffset + 12); + + +/***************************************************/ +// https://issues.dlang.org/show_bug.cgi?id=19914 +// https://issues.dlang.org/show_bug.cgi?id=19915 + +class TemplatedClass(T) +{ + align T field; +} + +mixin TemplatedClass!(string); +alias TCint = TemplatedClass!(int); diff --git a/gcc/testsuite/gdc.test/fail_compilation/fail19914.d b/gcc/testsuite/gdc.test/fail_compilation/fail19914.d new file mode 100644 index 000000000000..a890d35e85b4 --- /dev/null +++ b/gcc/testsuite/gdc.test/fail_compilation/fail19914.d @@ -0,0 +1,10 @@ +// PERMUTE_ARGS: +/* +TEST_OUTPUT: +--- +fail_compilation/fail19914.d(9): Error: undefined identifier `c` in module `fail19914` +fail_compilation/fail19914.d(10): Error: mixin `fail19914.a!string` error instantiating +--- +*/ +class a(b) { align.c d; } +mixin a!(string); diff --git a/gcc/testsuite/gdc.test/fail_compilation/fail19915.d b/gcc/testsuite/gdc.test/fail_compilation/fail19915.d new file mode 100644 index 000000000000..17e05ee32c20 --- /dev/null +++ b/gcc/testsuite/gdc.test/fail_compilation/fail19915.d @@ -0,0 +1,10 @@ +// PERMUTE_ARGS: +/* +TEST_OUTPUT: +--- +fail_compilation/fail19915.d(9): Error: undefined identifier `c` in module `fail19915` +fail_compilation/fail19915.d(10): Error: template instance `fail19915.a!int` error instantiating +--- +*/ +class a (b) { align.c d; } +alias a!(int) e;