diff options
author | Jason Merrill <jason@gcc.gnu.org> | 2002-01-18 08:23:23 -0500 |
---|---|---|
committer | Jason Merrill <jason@gcc.gnu.org> | 2002-01-18 08:23:23 -0500 |
commit | 4ffbff5906ce6291c39852f0856b5f6a60a3d3e1 (patch) | |
tree | de62a7ffd9e1ccdbb6bca0943f03d7fb326127a6 /gcc | |
parent | 1c556b2274cfd0e18f8a350f3e385bb857d56856 (diff) | |
download | gcc-4ffbff5906ce6291c39852f0856b5f6a60a3d3e1.zip gcc-4ffbff5906ce6291c39852f0856b5f6a60a3d3e1.tar.gz gcc-4ffbff5906ce6291c39852f0856b5f6a60a3d3e1.tar.bz2 |
C++ ABI change: destroy value arguments in caller.
* calls.c (initialize_argument_information): Pass the address of
the TARGET_EXPR temporary rather than storing it into another.
From-SVN: r48983
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/testsuite/g++.dg/init/elide1.C | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.dg/init/elide1.C b/gcc/testsuite/g++.dg/init/elide1.C new file mode 100644 index 0000000..24e81e3 --- /dev/null +++ b/gcc/testsuite/g++.dg/init/elide1.C @@ -0,0 +1,38 @@ +// { dg-do run } + +// Test that the destructor for a temporary passed by value isn't run +// until end of full-expression, as per [class.copy]: + +// Whenever a temporary class object is copied using a copy constructor, +// and this object and the copy have the same cv-unqualified type, an +// implementation is permitted to treat the original and the copy as two +// different ways of referring to the same object and not perform a copy +// at all, even if the class copy constructor or destructor have side +// effects.... In these cases, the +// object is destroyed at the later of times when the original and the +// copy would have been destroyed without the optimization. + +// Here, the temporary would be destroyed later than the parm, so either we +// must suppress the optimization in this case or destroy value parms in the +// caller. + +int d; + +struct A { + A () { } + A (const A&) { } + ~A() { ++d; } +}; + +void f (A a) { } + +int main () +{ + int r; + f (A ()), r = d; + + if (r < d && d) + return 0; + else + return 1; +} |