From: Jakub Jelinek Date: Fri, 16 Feb 2001 22:30:06 +0000 (+0100) Subject: call.c (convert_like_real): Create a temporary for non-lvalue. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=2c1be3223f5bbc9e2238d15e8a48d37b1f02fdbe;p=gcc.git call.c (convert_like_real): Create a temporary for non-lvalue. * call.c (convert_like_real): Create a temporary for non-lvalue. * g++.old-deja/g++.other/init16.C: Update the test so that it does not need and also tests the initialization at runtime. From-SVN: r39776 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 6341bbedfb4..d79146c010a 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,7 @@ +2001-02-16 Jakub Jelinek + + * call.c (convert_like_real): Create a temporary for non-lvalue. + 2001-02-16 Jeffrey Oldham * cp-tree.h: Fix typos in comments. diff --git a/gcc/cp/call.c b/gcc/cp/call.c index 11cb6404054..7e2124fe8d0 100644 --- a/gcc/cp/call.c +++ b/gcc/cp/call.c @@ -3850,7 +3850,7 @@ convert_like_real (convs, expr, fn, argnum, inner) tree ref_type = totype; /* If necessary, create a temporary. */ - if (NEED_TEMPORARY_P (convs)) + if (NEED_TEMPORARY_P (convs) || !lvalue_p (expr)) { tree type = TREE_TYPE (TREE_OPERAND (convs, 0)); expr = build_target_expr_with_type (expr, type); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 09576beec2f..3d93933e54a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2001-02-16 Jakub Jelinek + + * g++.old-deja/g++.other/init16.C: Update the test so that it does + not need and also tests the initialization at runtime. + 2001-02-16 Neil Booth * gcc.c-torture/execute/longlong.c: New test. diff --git a/gcc/testsuite/g++.old-deja/g++.other/init16.C b/gcc/testsuite/g++.old-deja/g++.other/init16.C index 8d7c1af3b10..83d5a4eb5c5 100644 --- a/gcc/testsuite/g++.old-deja/g++.other/init16.C +++ b/gcc/testsuite/g++.old-deja/g++.other/init16.C @@ -1,11 +1,28 @@ -// Build don't link: // Origin: Jakub Jelinek -// excess errors test - XFAIL *-*-* - -#include +struct bar { + char c; + bar (const char *); + bar (const bar &); +}; struct foo { - string x; + bar x; }; + extern const struct foo y = { "foo" }; + +bar::bar (const bar &ref) +{ + c = ref.c; +} + +bar::bar (const char *p) +{ + c = p[2]; +} + +int main () +{ + return y.x.c != 'o'; +}