// { 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; }