diff options
author | Richard Henderson <rth@redhat.com> | 2004-06-15 18:21:38 -0700 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2004-06-15 18:21:38 -0700 |
commit | 325c36911589375105e5437c513bf880aeffdc75 (patch) | |
tree | fd045b9b0d56d6e00876348ae58483539fd0ec02 /gcc/objc | |
parent | aaab7bb6d7660df0773a444bd6a4a20f586f1a98 (diff) | |
download | gcc-325c36911589375105e5437c513bf880aeffdc75.zip gcc-325c36911589375105e5437c513bf880aeffdc75.tar.gz gcc-325c36911589375105e5437c513bf880aeffdc75.tar.bz2 |
c-common.c (lang_gimplify_stmt): Remove next_p argument.
* c-common.c (lang_gimplify_stmt): Remove next_p argument.
(if_elt, if_stack, if_stack_space, c_expand_start_cond, c_finish_then,
c_expand_end_cond, c_expand_start_else, c_finish_else, c_begin_if_stmt,
c_begin_while_stmt, c_finish_while_stmt_cond): Move to c-typeck.c.
(finish_fname_decls, fname_decl): Use statement_lists.
(c_expand_expr_stmt): Don't set last_expr_type.
(c_type_hash): Fix indentation.
(c_safe_from_p): Don't follow TREE_CHAIN.
(c_tree_chain_matters_p): Remove.
* c-common.def (SCOPE_STMT): Remove.
(CLEANUP_STMT): Redefine to contain its own body.
* c-common.h (struct stmt_tree_s): Remove x_last_stmt,
x_last_expr_type, x_last_expr_filename, x_scope_stmt_stack.
Add x_cur_stmt_list.
(last_tree, last_expr_type, last_expr_filename, RECHAIN_STMTS): Remove.
(cur_stmt_list): New.
(STATEMENT_LIST_STMT_EXPR): New.
(SCOPE_BEGIN_P, SCOPE_END_P, SCOPE_STMT_BLOCK, SCOPE_NULLIFIED_P,
SCOPE_NO_CLEANUPS_P, SCOPE_PARTIAL_P, NEW_FOR_SCOPE_P): Remove.
(CLEANUP_BODY): New.
(CLEANUP_DECL): Move to operand 2.
(c_common_stmt_codes): Remove SCOPE_STMT.
(COMPOUND_STMT_NO_SCOPE, COMPOUND_STMT_BODY_BLOCK): Remove.
* c-decl.c (c_scope_stmt_stack, current_scope_stmt_stack): Remove.
(c_push_function_context, c_pop_function_context): Don't save it.
(finish_decl): Set TREE_USED on the decl for a cleanup.
Use push_cleanup.
(store_parm_decls): Use statement lists.
(finish_function): Remove compstmt rule workaround. Use statement
lists. Call finish_fname_decls after finalizing the body.
(c_begin_compound_stmt): Move to c-typeck.c.
* c-dump.c (c_dump_tree): Remove SCOPE_STMT.
* c-gimplify.c (gimplify_cleanup_stmt, gimplify_cleanup_stmts): New.
(c_genericize): Invoke them.
(c_gimplify_stmt): Don't look through TREE_CHAIN. Kill SCOPE_STMT.
(c_build_bind_expr): Export.
(gimplify_block, gimplify_cleanup): Remove.
(gimplify_condition): Use gimplify_stmt.
(gimplify_for_stmt): Remove FOR_INIT_STMT chaining hack.
(gimplify_if_stmt): Remove recursion hack.
(c_gimplify_expr): Remove STMT_EXPR handling.
(stmt_expr_last_stmt, gimplify_stmt_expr): Remove.
(is_last_stmt_of_scope): Remove.
* c-lang.c (LANG_HOOKS_TREE_INLINING_TREE_CHAIN_MATTERS_P): Remove.
* c-mudflap.c (mflang_flush_calls): Use c_begin_compound_stmt,
c_end_compound_stmt.
* c-objc-common.c (build_cdtor): Likewise.
* c-parse.in (primary): Use c_finish_stmt_expr.
(push_scope, pop_scope): Remove.
(c99_block_start, compstmt_start): Use c_begin_compound_stmt.
(c99_block_end, compstmt): Use c_end_compound_stmt.
(c99_block_lineno_labeled_stmt): Likewise.
(compstmt_primary_start): Use c_begin_stmt_expr.
(simple_if, select_or_iter_stmt): Update calls to stmt builders.
(do_stmt_start): Fill in body directly.
(lineno_stmt): Avoid setting lineno on constants.
* c-pretty-print.c (pp_c_statement): Handle STATEMENT_LIST.
Remove SCOPE_STMT.
* c-semantics.c (begin_stmt_tree): Remove.
(push_stmt_list, re_push_stmt_list, pop_stmt_list): New.
(add_stmt): Use statement lists.
(add_scope_stmt, finish_stmt_tree): Remove.
(push_cleanup): New.
* c-tree.h: Move some decls from c-common.h.
* c-typeck.c (c_tree_expr_nonnegative_p): Simplify for statement lists.
(do_case, c_finish_case): Likewise.
(c_finish_then): Take body for then as argument.
(c_finish_else): Similarly.
(c_begin_for_stmt, c_finish_for_stmt_init, c_finish_for_stmt_cond,
c_finish_for_stmt_incr, c_finish_for_stmt): New.
(c_begin_stmt_expr, c_finish_stmt_expr): New.
(c_begin_compound_stmt): Do scope management.
(c_end_compound_stmt): New.
* fold-const.c (tree_expr_nonnegative_p): Fix BIND_EXPR.
* gimplify.c (voidify_wrapper_expr): Accept temporary argument.
Look through exception handling constructs.
(gimplify_bind_expr): Accept temporary argument.
(gimplify_target_expr): Special case BIND_EXPR bodies.
(gimplify_expr): Handle fallback == fb_none like a statement.
* langhooks-def.h (LANG_HOOKS_TREE_INLINING_TREE_CHAIN_MATTERS_P): Kill.
* langhooks.c (lhd_tree_inlining_tree_chain_matters_p): Remove.
* langhooks.h (tree_chain_matters_p): Remove.
* stub-objc.c (objc_clear_super_receiver): New.
* tree-gimple.h (voidify_wrapper_expr): Update decl.
(append_to_statement_list, append_to_statement_list_force): Move
to tree-iterator.h.
* tree-inline.c (expand_call_inline): Update call.
(clone_body): Use statement lists.
(walk_tree): Don't check tree_chain_matters_p.
(copy_tree_r): Likewise.
* tree-iterator.c (alloc_stmt_list): Clear lang bits.
(tsi_link_before, tsi_link_after): Set TREE_SIDE_EFFECTS properly.
* tree-iterator.h (append_to_statement_list,
append_to_statement_list_force): Moved from tree-gimple.h.
* tree-pretty-print.c (dump_generic_node): Clean up TARGET_EXPR dump.
* objc/objc-act.c (build_module_descriptor): Use c_begin_compound_stmt.
(objc_enter_block): Likewise.
(objc_exit_block): Use c_end_compound_stmt.
(objc_build_try_enter_fragment): Add #error and comment for
rewriting for OBJCPLUS.
(objc_build_extract_fragment, objc_build_try_epilogue,
objc_build_catch_stmt, objc_build_finally_prologue,
objc_build_finally_epilogue): Update for C statement builders.
* objc/objc-lang.c (LANG_HOOKS_TREE_INLINING_TREE_CHAIN_MATTERS_P):
Remove.
cp/
* call.c (initialize_reference): Don't build CLEANUP_STMT here.
* cp-gimplify.c (cp_gimplify_stmt): Remove next_p argument.
(genericize_try_block): Use gimplify_stmt.
(genericize_catch_block, genericize_eh_spec_block): Likewise.
(cp_gimplify_init_expr): Remove STMT_EXPR special case.
(gimplify_must_not_throw_expr): Update voidify_wrapper_expr call.
* cp-lang.c (LANG_HOOKS_TREE_INLINING_TREE_CHAIN_MATTERS_P): Remove.
(cp_tree_chain_matters_p): Remove.
* cp-tree.h (COMPOUND_STMT_TRY_BLOCK): New.
(COMPOUND_STMT_BODY_BLOCK): New.
(STATEMENT_LIST_NO_SCOPE, STATEMENT_LIST_TRY_BLOCK): New.
(EXPR_STMT_STMT_EXPR_RESULT): New.
(building_stmt_tree): Check cur_stmt_list.
(tf_stmt_expr_cmpd, tf_stmt_expr_body): Remove.
(BCS_NO_SCOPE, BCS_TRY_BLOCK, BCS_FN_BODY): New.
* decl.c (poplevel): Use pop_stmt_list for minding cleanups.
(cp_finish_decl): Use push_cleanup.
(start_function, finish_function): Use statement lists.
(finish_stmt): Do nothing.
* except.c (begin_eh_spec_block): Use statement lists.
(check_handlers_1, check_handlers): Likewise.
* init.c (construct_virtual_base): Don't add extra compound stmts.
(build_vec_init): Likewise.
* name-lookup.c (maybe_push_cleanup_level): Use statement lists.
* name-lookup.h (struct cp_binding_level): Add statement_list.
* parser.c (cp_parser_statement): Take the STMT_EXPR node, not a bool.
(cp_parser_labeled_statement, cp_parser_expression_statement,
cp_parser_statement_seq_opt): Likewise.
(cp_parser_compound_statement): Likewise. Take bool for try block.
(cp_parser_selection_statement): Tidy if processing.
(cp_parser_already_scoped_statement): Rewrite to do what it says.
* pt.c (tsubst_copy): Move STMT_EXPR to tsubst_expr.
(tsubst_expr): Rewrite STMT_EXPR processing. Handle STATEMENT_LIST.
Mind COMPOUND_STMT_TRY_BLOCK, EXPR_STMT_STMT_EXPR_RESULT.
* semantics.c (do_poplevel, do_pushlevel): Use statement lists.
(finish_cond): New, rewritten from FINISH_COND.
(simplify_loop_decl_cond): New.
(finish_expr_stmt): Avoid nested EXPR_STMTs.
(begin_if_stmt, finish_if_stmt_cond, finish_then_clause,
begin_else_clause, finish_else_clause, finish_if_stmt,
begin_while_stmt, finish_while_stmt_cond, finish_while_stmt,
begin_do_stmt, finish_do_body, begin_for_stmt, finish_for_init_stmt,
finish_for_cond, finish_for_stmt, begin_switch_stmt,
finish_switch_cond, finish_switch_stmt, begin_try_block,
finish_try_block, finish_cleanup_try_block, finish_function_try_block,
finish_handler_sequence, finish_function_handler_sequence,
begin_handler, finish_handler_parms, finish_handler,
begin_stmt_expr, finish_stmt_expr_expr, finish_stmt_expr): Rewrite
using statement lists.
(begin_compound_stmt): Replace has_no_scope argument with flags.
Update all callers. Use statement lists.
(finish_compound_stmt): Likewise.
(finish_decl_cleanup, finish_eh_cleanup): Use push_cleanup.
(current_scope_stmt_stack): Remove.
(simplify_aggr_init_expr): Don't muck with TREE_CHAIN.
* typeck2.c (split_nonconstant_init_1, split_nonconstant_init):
Rewrite with statement lists.
testsuite/
* g++.dg/ext/stmtexpr1.C: XFAIL.
* gcc.dg/20030612-1.c: XFAIL.
From-SVN: r83221
Diffstat (limited to 'gcc/objc')
-rw-r--r-- | gcc/objc/objc-act.c | 61 | ||||
-rw-r--r-- | gcc/objc/objc-lang.c | 3 |
2 files changed, 26 insertions, 38 deletions
diff --git a/gcc/objc/objc-act.c b/gcc/objc/objc-act.c index 97a36a0..971520e 100644 --- a/gcc/objc/objc-act.c +++ b/gcc/objc/objc-act.c @@ -1875,7 +1875,7 @@ build_module_descriptor (void) { tree parms, execclass_decl, decelerator, void_list_node_1; - tree init_function_name, init_function_decl; + tree init_function_name, init_function_decl, compound; /* Declare void __objc_execClass (void *); */ @@ -1903,6 +1903,7 @@ build_module_descriptor (void) NULL_TREE), NULL_TREE); store_parm_decls (); + compound = c_begin_compound_stmt (true); init_function_decl = current_function_decl; TREE_PUBLIC (init_function_decl) = ! targetm.have_ctors_dtors; @@ -1917,6 +1918,7 @@ build_module_descriptor (void) decelerator = build_function_call (execclass_decl, parms); c_expand_expr_stmt (decelerator); + add_stmt (c_end_compound_stmt (compound, true)); finish_function (); @@ -2687,10 +2689,7 @@ objc_enter_block (void) #ifdef OBJCPLUS block = begin_compound_stmt (0); #else - block = c_begin_compound_stmt (); - push_scope (); - clear_last_expr (); - add_scope_stmt (/*begin_p=*/1, /*partial_p=*/0); + block = c_begin_compound_stmt (1); #endif objc_exception_block_stack = tree_cons (NULL_TREE, block, @@ -2704,24 +2703,14 @@ static tree objc_exit_block (void) { tree block = TREE_VALUE (objc_exception_block_stack); -#ifndef OBJCPLUS - tree scope_stmt, inner; -#endif + objc_exception_block_stack = TREE_CHAIN (objc_exception_block_stack); objc_clear_super_receiver (); #ifdef OBJCPLUS - finish_compound_stmt (0, block); + finish_compound_stmt (block); #else - scope_stmt = add_scope_stmt (/*begin_p=*/0, /*partial_p=*/0); - inner = pop_scope (); - - SCOPE_STMT_BLOCK (TREE_PURPOSE (scope_stmt)) - = SCOPE_STMT_BLOCK (TREE_VALUE (scope_stmt)) - = inner; - RECHAIN_STMTS (block, COMPOUND_BODY (block)); + block = c_end_compound_stmt (block, 1); #endif - last_expr_type = NULL_TREE; - objc_exception_block_stack = TREE_CHAIN (objc_exception_block_stack); blk_nesting_count--; return block; @@ -2804,6 +2793,15 @@ objc_build_try_enter_fragment (void) c_expand_expr_stmt (build_function_call (objc_exception_try_enter_decl, func_params)); +#ifdef OBJCPLUS + /* Um, C and C++ have very different statement construction functions. + Partly because different scoping rules are in effect, but partly + because of how their parsers are constructed. I highly recommend + simply constructing the statements by hand here. You don't need + any of the ancilliary tracking necessary for user parsing bits anyway. */ +#error +#endif + if_stmt = c_begin_if_stmt (); if_nesting_count++; /* If <setjmp.h> has been included, the _setjmp prototype has @@ -2865,8 +2863,7 @@ objc_build_extract_fragment (void) _rethrowException = objc_exception_extract(&_stackExceptionData); } */ - objc_exit_block (); - c_finish_then (); + c_finish_then (objc_exit_block ()); c_expand_start_else (); objc_enter_block (); @@ -2874,8 +2871,7 @@ objc_build_extract_fragment (void) (TREE_VALUE (objc_rethrow_exception), NOP_EXPR, objc_build_extract_expr ())); - objc_exit_block (); - c_finish_else (); + c_finish_else (objc_exit_block ()); c_expand_end_cond (); if_nesting_count--; } @@ -2934,8 +2930,7 @@ objc_build_try_epilogue (int also_catch_prologue) tree if_stmt; - objc_exit_block (); - c_finish_then (); + c_finish_then (objc_exit_block ()); c_expand_start_else (); objc_enter_block (); @@ -3017,8 +3012,7 @@ objc_build_catch_stmt (tree catch_expr) objc_catch_type = tree_cons (NULL_TREE, var_type, objc_catch_type); - objc_exit_block (); - c_finish_then (); + c_finish_then (objc_exit_block ()); c_expand_start_else (); catch_count_stack->val++; @@ -3061,8 +3055,7 @@ objc_build_catch_epilogue (void) } // end TRY-CATCH scope */ - objc_exit_block (); - c_finish_then (); + c_finish_then (objc_exit_block ()); c_expand_start_else (); objc_enter_block (); @@ -3075,7 +3068,8 @@ objc_build_catch_epilogue (void) objc_exit_block (); while (catch_count_stack->val--) { - c_finish_else (); /* close off all the nested ifs ! */ + /* FIXME. Need to have the block of each else that was opened. */ + c_finish_else ((abort (), NULL)); /* close off all the nested ifs ! */ c_expand_end_cond (); if_nesting_count--; } @@ -3084,8 +3078,7 @@ objc_build_catch_epilogue (void) objc_build_extract_fragment (); - objc_exit_block (); - c_finish_else (); + c_finish_else (objc_exit_block ()); c_expand_end_cond (); if_nesting_count--; objc_exit_block (); @@ -3116,8 +3109,7 @@ objc_build_finally_prologue (void) 0, if_stmt); objc_enter_block (); objc_build_try_exit_fragment (); - objc_exit_block (); - c_finish_then (); + c_finish_then (objc_exit_block ()); c_expand_end_cond (); if_nesting_count--; @@ -3141,8 +3133,7 @@ objc_build_finally_epilogue (void) 0, if_stmt); objc_enter_block (); objc_build_throw_stmt (TREE_VALUE (objc_rethrow_exception)); - objc_exit_block (); - c_finish_then (); + c_finish_then (objc_exit_block ()); c_expand_end_cond (); if_nesting_count--; diff --git a/gcc/objc/objc-lang.c b/gcc/objc/objc-lang.c index cdc5453..f786369 100644 --- a/gcc/objc/objc-lang.c +++ b/gcc/objc/objc-lang.c @@ -112,9 +112,6 @@ enum c_language_kind c_language = clk_objc; #undef LANG_HOOKS_TREE_INLINING_CONVERT_PARM_FOR_INLINING #define LANG_HOOKS_TREE_INLINING_CONVERT_PARM_FOR_INLINING \ c_convert_parm_for_inlining -#undef LANG_HOOKS_TREE_INLINING_TREE_CHAIN_MATTERS_P -#define LANG_HOOKS_TREE_INLINING_TREE_CHAIN_MATTERS_P \ - c_tree_chain_matters_p #undef LANG_HOOKS_CALLGRAPH_EXPAND_FUNCTION #define LANG_HOOKS_CALLGRAPH_EXPAND_FUNCTION c_expand_body |