diff options
| author | jsm28 <jsm28@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-12-04 22:55:40 +0000 |
|---|---|---|
| committer | jsm28 <jsm28@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-12-04 22:55:40 +0000 |
| commit | ec11e38eda98d7259002eebd58291990beacda84 (patch) | |
| tree | 47e4fa29a6462438cb5aea8ae3e2c690243e3f52 /gcc/c-typeck.c | |
| parent | f1833f1bf639955df2ff48caa738ed0cffb0af8d (diff) | |
| download | ppe42-gcc-ec11e38eda98d7259002eebd58291990beacda84.tar.gz ppe42-gcc-ec11e38eda98d7259002eebd58291990beacda84.zip | |
* c-common.def (COMPOUND_LITERAL_EXPR): New.
* c-common.c (c_expand_expr): Handle COMPOUND_LITERAL_EXPR.
(c_staticp): New function.
* c-common.h (COMPOUND_LITERAL_EXPR_DECL): New.
(c_staticp): Declare.
* c-typeck.c (default_function_array_conversion, build_unary_op):
Don't handle CONSTRUCTOR specially.
(lvalue_p, mark_addressable): Handle COMPOUND_LITERAL_EXPR.
* c-decl.c (build_compound_literal): New function.
* c-tree.h (build_compound_literal): Declare.
* c-parse.in (primary): Use build_compound_literal.
* c-lang.c (LANG_HOOKS_STATICP): Define.
* objc/objc-lang.c (LANG_HOOKS_STATICP): Likewise.
* doc/c-tree.texi: Document COMPOUND_LITERAL_EXPR.
* doc/extend.texi: Update documentation of compound literals.
Fixes PR c/4787.
testsuite:
* gcc.c-torture/execute/20000722-1.x,
gcc.c-torture/execute/20010123-1.x: Remove.
* gcc.c-torture/compile/init-3.c: Don't use a compound literal.
* gcc.dg/c90-complit-1.c, gcc.dg/c99-complit-1.c,
gcc.dg/c99-complit-2.c: New tests.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@47629 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/c-typeck.c')
| -rw-r--r-- | gcc/c-typeck.c | 9 |
1 files changed, 3 insertions, 6 deletions
diff --git a/gcc/c-typeck.c b/gcc/c-typeck.c index ff504dc1d05..297afad8ce8 100644 --- a/gcc/c-typeck.c +++ b/gcc/c-typeck.c @@ -910,8 +910,7 @@ default_function_array_conversion (exp) } lvalue_array_p = !not_lvalue && lvalue_p (exp); - if (!flag_isoc99 && !lvalue_array_p - && !(TREE_CODE (exp) == CONSTRUCTOR && TREE_STATIC (exp))) + if (!flag_isoc99 && !lvalue_array_p) { /* Before C99, non-lvalue arrays do not decay to pointers. Normally, using such an array would be invalid; but it can @@ -3141,10 +3140,6 @@ build_unary_op (code, xarg, flag) } #endif - /* Allow the address of a constructor if all the elements - are constant. */ - if (TREE_CODE (arg) == CONSTRUCTOR && TREE_CONSTANT (arg)) - ; /* Anything not already handled and not a true memory reference or a non-lvalue array is an error. */ else if (typecode != FUNCTION_TYPE && !flag @@ -3256,6 +3251,7 @@ lvalue_p (ref) case COMPONENT_REF: return lvalue_p (TREE_OPERAND (ref, 0)); + case COMPOUND_LITERAL_EXPR: case STRING_CST: return 1; @@ -3411,6 +3407,7 @@ mark_addressable (exp) x = TREE_OPERAND (x, 0); break; + case COMPOUND_LITERAL_EXPR: case CONSTRUCTOR: TREE_ADDRESSABLE (x) = 1; return 1; |

