diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 53778d8e8bc66fc4e709caeba350a6de7122cdd7..a80da3940908fd702d6bad56c28c63d31b8c2fd7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2000-09-06 Nathan Sidwell <nathan@codesourcery.com> + + * g++.old-deja/g++.pt/crash58.C: New test. + 2000-09-06 Greg McGary <greg@mcgary.org> * gcc.c-torture/20000906.c: New test. diff --git a/gcc/testsuite/g++.old-deja/g++.pt/crash58.C b/gcc/testsuite/g++.old-deja/g++.pt/crash58.C new file mode 100644 index 0000000000000000000000000000000000000000..6a2f109ac188a33b014ade0ad1d60646897dc651 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.pt/crash58.C @@ -0,0 +1,33 @@ +// Build don't link: +// +// Copyright (C) 2000 Free Software Foundation, Inc. +// Contributed by Nathan Sidwell 5 Sept 2000 <nathan@codesourcery.com> + +// bug 147. We ICE'd on an unprocessed LOOKUP_EXPR during tsubsting + +namespace EManip { + template <class T> void do_assign(T* d); // ERROR - candidate +}; +template <class T> void do_assign(T* d); // ERROR - candidate + +template <class T> +struct MatrixC +{ + void foo () { + EManip::do_assign<T> (0); + &EManip::do_assign<T>; + &do_assign<T>; + EManip::do_assign<T>; // WARNING - not a call + do_assign<T>; // WARNING - not a call + } +}; +void foo(MatrixC <double> *ptr) +{ + EManip::do_assign<double>; // WARNING - not a call + &EManip::do_assign<double>; + ptr->foo (); + void (*p1) (int *) = &do_assign<double>; // ERROR - cannot convert + void (*p2) (int *) = &EManip::do_assign<double>; // ERROR - cannot convert + void (*p3) (int *) = &do_assign; + void (*p4) (int *) = &EManip::do_assign; +}