diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 62c71b7c53..57d083c350 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2021-03-08 Tom Tromey + + * ada-lang.c (ada_ternop_slice): No longer static. + * ada-exp.h (class ada_ternop_slice_operation): New. + 2021-03-08 Tom Tromey * ada-exp.h (ada_bitwise_operation): New template class. diff --git a/gdb/ada-exp.h b/gdb/ada-exp.h index d8f18b9c61..96e3c407b6 100644 --- a/gdb/ada-exp.h +++ b/gdb/ada-exp.h @@ -50,6 +50,11 @@ extern struct value *ada_equal_binop (struct type *expect_type, struct expression *exp, enum noside noside, enum exp_opcode op, struct value *arg1, struct value *arg2); +extern struct value *ada_ternop_slice (struct expression *exp, + enum noside noside, + struct value *array, + struct value *low_bound_val, + struct value *high_bound_val); namespace expr { @@ -213,6 +218,28 @@ using ada_bitwise_and_operation = ada_bitwise_operation; using ada_bitwise_ior_operation = ada_bitwise_operation; using ada_bitwise_xor_operation = ada_bitwise_operation; +/* Ada array- or string-slice operation. */ +class ada_ternop_slice_operation + : public maybe_constant_operation +{ +public: + + using maybe_constant_operation::maybe_constant_operation; + + value *evaluate (struct type *expect_type, + struct expression *exp, + enum noside noside) override + { + value *array = std::get<0> (m_storage)->evaluate (nullptr, exp, noside); + value *low = std::get<1> (m_storage)->evaluate (nullptr, exp, noside); + value *high = std::get<2> (m_storage)->evaluate (nullptr, exp, noside); + return ada_ternop_slice (exp, noside, array, low, high); + } + + enum exp_opcode opcode () const override + { return TERNOP_SLICE; } +}; + } /* namespace expr */ #endif /* ADA_EXP_H */ diff --git a/gdb/ada-lang.c b/gdb/ada-lang.c index 7ae3343a63..3f14922e18 100644 --- a/gdb/ada-lang.c +++ b/gdb/ada-lang.c @@ -10156,7 +10156,7 @@ ada_equal_binop (struct type *expect_type, /* A helper function for TERNOP_SLICE. */ -static value * +value * ada_ternop_slice (struct expression *exp, enum noside noside, struct value *array, struct value *low_bound_val,