From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository. --- gcc/testsuite/g++.dg/other/abstract1.C | 59 ++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 gcc/testsuite/g++.dg/other/abstract1.C (limited to 'gcc/testsuite/g++.dg/other/abstract1.C') diff --git a/gcc/testsuite/g++.dg/other/abstract1.C b/gcc/testsuite/g++.dg/other/abstract1.C new file mode 100644 index 000000000..8406f8a25 --- /dev/null +++ b/gcc/testsuite/g++.dg/other/abstract1.C @@ -0,0 +1,59 @@ +// { dg-do compile } +// Contributed by , +// , +// +// c++/9256: Make sure that a pointer to an array of abstract elements +// cannot be created, not even during template substitution (DR337). + +struct Abstract { virtual void f() = 0; }; // { dg-message "note" } +struct Complete { void f(); }; + + +/* + * TEST 1 + * Arrays of abstract elements cannot be declared. + */ + +Abstract a0[2]; // { dg-error "" } +Abstract (*a1)[2]; // { dg-error "" } +Abstract (**a2)[2]; // { dg-error "" } +Abstract (***a3)[2]; // { dg-error "" } +Abstract *a4; +Abstract *a5[2]; +Abstract (*a6[2])[2]; // { dg-error "" } +Abstract **a7[2]; +Abstract *(*a8[2])[2]; +Abstract (**a9[2])[2]; // { dg-error "" } + +/* + * TEST 2 + * If a pointer to an array of abstract elements is created during template + * instantiation, an error should occur. + */ + +template struct K { + T (*a)[2]; // { dg-error "abstract class type" } +}; + +template struct K; // { dg-message "instantiated" } + + + +/* + * TEST 3 + * Deducing an array of abstract elements during type deduction is a silent + * failure (rejects overload). + */ + +template struct StaticAssert; +template <> struct StaticAssert {}; + +typedef char Yes; +typedef struct { char x[2]; } No; + +template No is_abstract(U (*k)[1]); +template Yes is_abstract(...); + +StaticAssert(0)) == sizeof(Yes)> b1; +StaticAssert(0)) == sizeof(No)> b2; +StaticAssert(0)) == sizeof(No)> b3; -- cgit v1.2.3