From: Tom Tromey Date: Mon, 8 Mar 2021 14:27:57 +0000 (-0700) Subject: Split out fortran_require_array X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3c18c49c63f8dcdacbb33c2e8f2582789e39487b;p=binutils-gdb.git Split out fortran_require_array This splits out a helper function, fortran_require_array, that will be used in a later patch. gdb/ChangeLog 2021-03-08 Tom Tromey * f-lang.c (fortran_require_array): New function. (evaluate_subexp_f): Use it. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 0958f593c91..6450bbe05f5 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2021-03-08 Tom Tromey + + * f-lang.c (fortran_require_array): New function. + (evaluate_subexp_f): Use it. + 2021-03-08 Tom Tromey * f-lang.c (eval_op_f_kind): New function. diff --git a/gdb/f-lang.c b/gdb/f-lang.c index 659b0c84fa8..0ee2806f1a1 100644 --- a/gdb/f-lang.c +++ b/gdb/f-lang.c @@ -130,6 +130,23 @@ const struct op_print f_language::op_print_tab[] = }; +/* A helper function for the "bound" intrinsics that checks that TYPE + is an array. LBOUND_P is true for lower bound; this is used for + the error message, if any. */ + +static void +fortran_require_array (struct type *type, bool lbound_p) +{ + type = check_typedef (type); + if (type->code () != TYPE_CODE_ARRAY) + { + if (lbound_p) + error (_("LBOUND can only be applied to arrays")); + else + error (_("UBOUND can only be applied to arrays")); + } +} + /* Create an array containing the lower bounds (when LBOUND_P is true) or the upper bounds (when LBOUND_P is false) of ARRAY (which must be of array type). GDBARCH is the current architecture. */ @@ -1228,14 +1245,7 @@ evaluate_subexp_f (struct type *expect_type, struct expression *exp, /* Check that the first argument is array like. */ arg1 = evaluate_subexp (nullptr, exp, pos, noside); - type = check_typedef (value_type (arg1)); - if (type->code () != TYPE_CODE_ARRAY) - { - if (lbound_p) - error (_("LBOUND can only be applied to arrays")); - else - error (_("UBOUND can only be applied to arrays")); - } + fortran_require_array (value_type (arg1), lbound_p); if (nargs == 1) return fortran_bounds_all_dims (lbound_p, exp->gdbarch, arg1);