From: Jakub Jelinek Date: Tue, 30 Jun 2009 22:04:36 +0000 (+0200) Subject: re PR c++/40566 (rejects promoted throw) X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5ccde5a06a28e4d1a2bed1db333f1876690c634c;p=platform%2Fupstream%2Fgcc.git re PR c++/40566 (rejects promoted throw) PR c++/40566 * convert.c (convert_to_integer) : Don't convert to type arguments that have void type. * g++.dg/parse/cond5.C: New test. From-SVN: r149121 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1b13273..8d0688b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ 2009-06-30 Jakub Jelinek + PR c++/40566 + * convert.c (convert_to_integer) : Don't convert + to type arguments that have void type. + PR debug/40573 * dwarf2out.c (gen_formal_parameter_die): Call equate_decl_number_to_die if node is different from origin. diff --git a/gcc/convert.c b/gcc/convert.c index 8245e16..706dc41 100644 --- a/gcc/convert.c +++ b/gcc/convert.c @@ -772,10 +772,16 @@ convert_to_integer (tree type, tree expr) case COND_EXPR: /* It is sometimes worthwhile to push the narrowing down through - the conditional and never loses. */ + the conditional and never loses. A COND_EXPR may have a throw + as one operand, which then has void type. Just leave void + operands as they are. */ return fold_build3 (COND_EXPR, type, TREE_OPERAND (expr, 0), - convert (type, TREE_OPERAND (expr, 1)), - convert (type, TREE_OPERAND (expr, 2))); + VOID_TYPE_P (TREE_TYPE (TREE_OPERAND (expr, 1))) + ? TREE_OPERAND (expr, 1) + : convert (type, TREE_OPERAND (expr, 1)), + VOID_TYPE_P (TREE_TYPE (TREE_OPERAND (expr, 2))) + ? TREE_OPERAND (expr, 2) + : convert (type, TREE_OPERAND (expr, 2))); default: break; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ebdf601..513a973 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-06-30 Jakub Jelinek + + PR c++/40566 + * g++.dg/parse/cond5.C: New test. + 2009-06-30 Nathan Froyd * gcc.dg/tree-ssa/gen-vect-25.c (n): New variable. diff --git a/gcc/testsuite/g++.dg/parse/cond5.C b/gcc/testsuite/g++.dg/parse/cond5.C new file mode 100644 index 0000000..7ed9fbe --- /dev/null +++ b/gcc/testsuite/g++.dg/parse/cond5.C @@ -0,0 +1,10 @@ +// PR c++/40566 + +void +f (int x, int y) +{ + int c = x ? 23 : throw "bla"; + short d = y ? throw "bla" : 23; + char e = x ? 23 : throw "bla"; + long f = x ? 23 : throw "bla"; +}