From 302e5c4601a8593b578f8af34036b631b53f94c7 Mon Sep 17 00:00:00 2001 From: Nathan Sidwell Date: Mon, 13 Mar 2000 11:12:13 +0000 Subject: [PATCH] * g++.old-deja/g++.warn/inline.C: New test. From-SVN: r32504 --- gcc/testsuite/ChangeLog | 4 ++ gcc/testsuite/g++.old-deja/g++.warn/inline.C | 69 ++++++++++++++++++++ 2 files changed, 73 insertions(+) create mode 100644 gcc/testsuite/g++.old-deja/g++.warn/inline.C diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d6d3feb7935..ace87e8952f 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2000-03-13 Nathan Sidwell + + * g++.old-deja/g++.warn/inline.C: New test. + 2000-03-08 Jason Merrill * lib/g++.exp (g++_init): Don't put { } around -fmessage-length=0. diff --git a/gcc/testsuite/g++.old-deja/g++.warn/inline.C b/gcc/testsuite/g++.old-deja/g++.warn/inline.C new file mode 100644 index 00000000000..f18f1a088e0 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.warn/inline.C @@ -0,0 +1,69 @@ +// Build don't link: +// Special g++ Options: -ansi -pedantic-errors -Winline -O1 + +// Copyright (C) 2000 Free Software Foundation, Inc. +// Contributed by Nathan Sidwell 9 Mar 2000 + +// derived from a bug report by Benjamin Kosnik + +// __FUNCTION__ was erroneously causing us to issue a `cannot inline' +// diagnostic, even though we'd (a) inlined it, (b) been forced to issue an +// out of line body by taking it's address, (c) not used __FUNCTION__. + +inline void wibble () +{} + +inline void wobble () +{} // gets bogus error - cannot inline + +void bar (void (*)()); + +void bar1 () +{ + wibble (); // can be inlined + void (*ptr) () = wobble; // force out of line issue + + bar (ptr); // make sure we make use of it +} + +struct B +{ + void mwibble () + {}; + void mwobble () + {}; // gets bogus error - cannot inline + + static void swibble () + {}; + static void swobble () + {}; // gets bogus error - cannot inline +}; + +void bar (void (B::*)()); + +void bar2 () +{ + B::swibble (); // can be inlined + void (*ptr) () = &B::swobble; // force out of line issue + + bar (ptr); // make sure we make use of it +} + +void bar3 (B *b) +{ + b->mwibble (); // can be inlined + void (B::*ptr) () = &B::mwobble; // force out of line issue + + bar (ptr); // make sure we make use of it +} + +struct C +{ + virtual void vwobble () + {}; // gets bogus error - cannot inline +}; + +void bar4 () +{ + C c; // force issue of C's vtable etc +} -- 2.30.2