diff options
author | Giovanni Bajo <giovannibajo@gcc.gnu.org> | 2004-01-10 01:22:06 +0000 |
---|---|---|
committer | Giovanni Bajo <giovannibajo@gcc.gnu.org> | 2004-01-10 01:22:06 +0000 |
commit | 731bd3ae02401f802d57e686814594ae4139a334 (patch) | |
tree | e7ab4e31ac294b08c30411b19de19a87b4d61f31 /gcc | |
parent | cfb91b67b887d59ba1d9fff08fcd38f8b16d766f (diff) | |
download | gcc-731bd3ae02401f802d57e686814594ae4139a334.zip gcc-731bd3ae02401f802d57e686814594ae4139a334.tar.gz gcc-731bd3ae02401f802d57e686814594ae4139a334.tar.bz2 |
DR 337 PR c++/9256
DR 337
PR c++/9256
* g++.dg/other/abstract1.C: New test.
From-SVN: r75619
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/other/abstract1.C | 59 |
2 files changed, 65 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a9276de..0d4b3d6 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2004-01-10 Giovanni Bajo <giovannibajo@gcc.gnu.org> + + DR 337 + PR c++/9256 + * g++.dg/other/abstract1.C: New test. + 2004-01-09 Alexandre Oliva <aoliva@redhat.com> * g++.dg/lookup/strong-using-1.C: New. diff --git a/gcc/testsuite/g++.dg/other/abstract1.C b/gcc/testsuite/g++.dg/other/abstract1.C new file mode 100644 index 0000000..86962c7 --- /dev/null +++ b/gcc/testsuite/g++.dg/other/abstract1.C @@ -0,0 +1,59 @@ +// { dg-do compile } +// Contributed by <giovannibajo at gcc dot gnu dot org>, +// <pavel_vozenilek at hotmail dot com>, +// <bangerth at dealii dot org> +// 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-error "" } +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 <class T> struct K { + T (*a)[2]; // { dg-error "abstract class type" } +}; + +template struct K<Abstract>; // { dg-error "from here" } + + + +/* + * TEST 3 + * Deducing an array of abstract elements during type deduction is a silent + * failure (rejects overload). + */ + +template <bool> struct StaticAssert; +template <> struct StaticAssert<true> {}; + +typedef char Yes; +typedef struct { char x[2]; } No; + +template<typename U> No is_abstract(U (*k)[1]); +template<typename U> Yes is_abstract(...); + +StaticAssert<sizeof(is_abstract<Abstract>(0)) == sizeof(Yes)> b1; +StaticAssert<sizeof(is_abstract<Complete>(0)) == sizeof(No)> b2; +StaticAssert<sizeof(is_abstract<int>(0)) == sizeof(No)> b3; |