re PR c++/3471 (gcc 3.01 reports error about a private copy constructor that shouldn't get called.)

PR c++/3471
	* call.c (convert_like_real): Do not build additional temporaries
	for rvalues of class type.

From-SVN: r47451
This commit is contained in:
Mark Mitchell 2001-11-29 20:19:41 +00:00 committed by Mark Mitchell
parent 004249997b
commit b67db52985
5 changed files with 36 additions and 7 deletions

View File

@ -1,3 +1,9 @@
2001-11-29 Mark Mitchell <mark@codesourcery.com>
PR c++/3471
* call.c (convert_like_real): Do not build additional temporaries
for rvalues of class type.
2001-11-28 Nathan Sidwell <nathan@codesourcery.com>
* cp-tree.h (UNIQUELY_DERIVED_FROM_P): Use lookup base.

View File

@ -3820,7 +3820,7 @@ convert_like_real (convs, expr, fn, argnum, inner)
If the target is a class, that means call a ctor. */
if (IS_AGGR_TYPE (totype)
&& (inner >= 0 || !real_lvalue_p (expr)))
&& (inner >= 0 || !lvalue_p (expr)))
{
savew = warningcount, savee = errorcount;
expr = build_new_method_call

View File

@ -10,8 +10,8 @@
class A
{
public:
A(int j) { i = j; } // ERROR - candidate
A(A& a) { i = a.i; } // ERROR - candidate
A(int j) { i = j; }
A(A& a) { i = a.i; }
operator int() { return i; }
void assign(int v) { i = v; }
@ -37,10 +37,10 @@ B::run()
// Replacing above with "switch (int(in))" removes the error.
{
case 0:
out = 1; // ERROR - no usable copy ctor
out = 1;
break;
default:
out = 0; // ERROR - no usable copy ctor
out = 0;
break;
}
}

View File

@ -4,7 +4,7 @@ int count;
class A {
A();
A(const A&); // ERROR - referenced below
A(const A&);
public:
A(int) { ++count; }
~A() { --count; }
@ -14,7 +14,7 @@ public:
int main() {
{
A a (1);
if (a == 2 && a == 1) // ERROR - private copy ctor
if (a == 2 && a == 1)
;
}
return count;

View File

@ -0,0 +1,23 @@
// Build don't run:
// Origin: ericp@mit.edu
class bar {
};
class foo {
foo (const foo &f);
public:
foo (bar x) {}
foo () {}
void test (const foo &f) {}
};
int main (void) {
foo f;
bar b;
f.test (b);
}