diff options
author | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-11-21 19:09:38 +0000 |
---|---|---|
committer | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-11-21 19:09:38 +0000 |
commit | c63e27d8308a92ef01fefc139e574d9d2c3e1108 (patch) | |
tree | 7b19327f6425471460eda074c9f38f18c4323d1a /gcc/tree.c | |
parent | a3e81daf1b7df5e43e052733fb91fd90b4b10042 (diff) | |
download | gcc-c63e27d8308a92ef01fefc139e574d9d2c3e1108.tar.gz |
* c-common.c (c_unsafe_for_reeval): New function.
(add_c_tree_codes): Register it.
* c-common.h: Declare it.
* tree.c (lang_unsafe_for_reeval): New hook.
(unsafe_for_reeval): Call it.
* tree.h: Declare it.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@37623 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree.c')
-rw-r--r-- | gcc/tree.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/gcc/tree.c b/gcc/tree.c index 7910449bd34..dcacdaf1d39 100644 --- a/gcc/tree.c +++ b/gcc/tree.c @@ -179,6 +179,9 @@ static void finish_vector_type PARAMS((tree)); void (*lang_unsave) PARAMS ((tree *)); void (*lang_unsave_expr_now) PARAMS ((tree)); +/* If non-null, these are language-specific helper functions for + unsafe_for_reeval. Return negative to not handle some tree. */ +int (*lang_unsafe_for_reeval) PARAMS ((tree)); tree global_trees[TI_MAX]; tree integer_types[itk_none]; @@ -1778,7 +1781,12 @@ unsafe_for_reeval (expr) break; default: - /* ??? Add a lang hook if it becomes necessary. */ + if (lang_unsafe_for_reeval != 0) + { + tmp = (*lang_unsafe_for_reeval) (expr); + if (tmp >= 0) + return tmp; + } break; } |