From 8cb5e385d66a8b194bca83c97db3dc010d73470b Mon Sep 17 00:00:00 2001 From: Jason Merrill Date: Wed, 29 Mar 2000 15:56:57 -0500 Subject: [PATCH] up From-SVN: r32818 --- .../g++.old-deja/g++.other/badopt1.C | 2 + .../g++.old-deja/g++.other/crash15.C | 43 +++++++++++++++++++ 2 files changed, 45 insertions(+) create mode 100644 gcc/testsuite/g++.old-deja/g++.other/crash15.C diff --git a/gcc/testsuite/g++.old-deja/g++.other/badopt1.C b/gcc/testsuite/g++.old-deja/g++.other/badopt1.C index 096770e77ad..fbc4b126cd5 100644 --- a/gcc/testsuite/g++.old-deja/g++.other/badopt1.C +++ b/gcc/testsuite/g++.old-deja/g++.other/badopt1.C @@ -1,6 +1,8 @@ // Based on a testcase by Bryan Weston // egcs 1.1 fails to increment count +// Special g++ Options: -O2 + #include struct Base { Base() {} }; // removing the constructor fixes the problem diff --git a/gcc/testsuite/g++.old-deja/g++.other/crash15.C b/gcc/testsuite/g++.old-deja/g++.other/crash15.C new file mode 100644 index 00000000000..f863350897b --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.other/crash15.C @@ -0,0 +1,43 @@ +// g++ crashed because we unsaved the TARGET_EXPR for the return value +// for get_allocator without first expanding it, because it was part of the +// cleanup for the temporary string. + +// Derived from libstdc++ v3 code. + +// Special g++ Options: -O2 +// Build don't link: + +class AA {}; + +void fee (const AA&); + +class basic_string +{ +public: + basic_string(const char*); + + ~basic_string() + { fee (this->get_allocator()); } + + AA get_allocator(); +}; + +class failure +{ +public: + failure(const basic_string& __str); +}; + +class foo +{ +public: + foo(int x) + { + throw failure (""); + } +}; + +void test05() +{ + foo ofs(0); +}