From: Per Bothner Date: Tue, 5 Mar 1996 07:48:20 +0000 (+0000) Subject: * ch-lang.c (evaluate_subexp_chill case MULTI_SUBSCRIPT): Error X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=02e6e53d84b82102c7d86e0fe8d97f514231ba8f;p=binutils-gdb.git * ch-lang.c (evaluate_subexp_chill case MULTI_SUBSCRIPT): Error if "function" is pointer to non-function. Fixes PR chill/9095. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 5dfae3d0522..5684a43c1c1 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +Mon Mar 4 23:44:16 1996 Per Bothner + + * ch-lang.c (evaluate_subexp_chill case MULTI_SUBSCRIPT): Error + if "function" is pointer to non-function. + Mon Mar 4 17:47:03 1996 Stan Shebs * top.c (print_gdb_version): Update copyright year. diff --git a/gdb/ch-lang.c b/gdb/ch-lang.c index 904dc6b71f4..5c041d74f71 100644 --- a/gdb/ch-lang.c +++ b/gdb/ch-lang.c @@ -423,6 +423,10 @@ evaluate_subexp_chill (expect_type, exp, pos, noside) switch (TYPE_CODE (type)) { case TYPE_CODE_PTR: + type = check_typedef (TYPE_TARGET_TYPE (type)); + if (!type || TYPE_CODE (type) || TYPE_CODE_FUNC) + error ("reference value used as function"); + /* ... fall through ... */ case TYPE_CODE_FUNC: /* It's a function call. */ if (noside == EVAL_AVOID_SIDE_EFFECTS) @@ -433,16 +437,11 @@ evaluate_subexp_chill (expect_type, exp, pos, noside) argvec = (value_ptr *) alloca (sizeof (value_ptr) * (nargs + 2)); argvec[0] = arg1; tem = 1; - if (type && TYPE_CODE (type) == TYPE_CODE_PTR) - type = check_typedef (TYPE_TARGET_TYPE (type)); - if (type && TYPE_CODE (type) == TYPE_CODE_FUNC) + for (; tem <= nargs && tem <= TYPE_NFIELDS (type); tem++) { - for (; tem <= nargs && tem <= TYPE_NFIELDS (type); tem++) - { - argvec[tem] - = evaluate_subexp_chill (TYPE_FIELD_TYPE (type, tem-1), - exp, pos, noside); - } + argvec[tem] + = evaluate_subexp_chill (TYPE_FIELD_TYPE (type, tem-1), + exp, pos, noside); } for (; tem <= nargs; tem++) argvec[tem] = evaluate_subexp_with_coercion (exp, pos, noside);