From: Tom Tromey Date: Mon, 8 Mar 2021 14:27:57 +0000 (-0700) Subject: Introduce ada_var_msym_value_operation X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3f4a0053d9699d19a0251cd8c87871c65994e8e1;p=binutils-gdb.git Introduce ada_var_msym_value_operation This adds class ada_var_msym_value_operation, which implements OP_VAR_MSYM_VALUE for Ada. gdb/ChangeLog 2021-03-08 Tom Tromey * ada-lang.c (ada_var_msym_value_operation::evaluate_for_cast): New method. * ada-exp.h (class ada_var_msym_value_operation): New. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index adf910fddbd..34f80b44486 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2021-03-08 Tom Tromey + + * ada-lang.c (ada_var_msym_value_operation::evaluate_for_cast): + New method. + * ada-exp.h (class ada_var_msym_value_operation): New. + 2021-03-08 Tom Tromey * ada-lang.c (ada_var_value_operation::evaluate_for_cast) diff --git a/gdb/ada-exp.h b/gdb/ada-exp.h index 0f2f62f5978..0fe6ecf7e93 100644 --- a/gdb/ada-exp.h +++ b/gdb/ada-exp.h @@ -304,6 +304,23 @@ protected: using operation::do_generate_ax; }; +/* Variant of var_msym_value_operation for Ada. */ +class ada_var_msym_value_operation + : public var_msym_value_operation +{ +public: + + using var_msym_value_operation::var_msym_value_operation; + + value *evaluate_for_cast (struct type *expect_type, + struct expression *exp, + enum noside noside) override; + +protected: + + using operation::do_generate_ax; +}; + } /* namespace expr */ #endif /* ADA_EXP_H */ diff --git a/gdb/ada-lang.c b/gdb/ada-lang.c index ee8e8e12d0d..eb21748ef6a 100644 --- a/gdb/ada-lang.c +++ b/gdb/ada-lang.c @@ -10553,6 +10553,31 @@ ada_unop_atr_operation::evaluate (struct type *expect_type, val, type_arg, std::get<2> (m_storage)); } +value * +ada_var_msym_value_operation::evaluate_for_cast (struct type *expect_type, + struct expression *exp, + enum noside noside) +{ + if (noside == EVAL_AVOID_SIDE_EFFECTS) + return value_zero (expect_type, not_lval); + + value *val = evaluate_var_msym_value (noside, + std::get<1> (m_storage), + std::get<0> (m_storage)); + + val = ada_value_cast (expect_type, val); + + /* Follow the Ada language semantics that do not allow taking + an address of the result of a cast (view conversion in Ada). */ + if (VALUE_LVAL (val) == lval_memory) + { + if (value_lazy (val)) + value_fetch_lazy (val); + VALUE_LVAL (val) = not_lval; + } + return val; +} + value * ada_var_value_operation::evaluate_for_cast (struct type *expect_type, struct expression *exp,