diff options
author | Tom Tromey <tom@tromey.com> | 2021-03-08 07:27:57 -0700 |
---|---|---|
committer | Tom Tromey <tom@tromey.com> | 2021-03-08 07:28:27 -0700 |
commit | 11dd3dce4427792a89a851b8ed290b3c8124f282 (patch) | |
tree | 0f1ad5bed3c9bb0d431254120da71bbb62608b6c /gdb | |
parent | 6fab435953629ec50e2c367a0fbe305e4e5abf3f (diff) | |
download | gdb-11dd3dce4427792a89a851b8ed290b3c8124f282.zip gdb-11dd3dce4427792a89a851b8ed290b3c8124f282.tar.gz gdb-11dd3dce4427792a89a851b8ed290b3c8124f282.tar.bz2 |
Introduce rust_unop_ind_operation
This adds class rust_unop_ind_operation, which implements UNOP_IND for
Rust. Rust requires a special case here to handle trait objects.
gdb/ChangeLog
2021-03-08 Tom Tromey <tom@tromey.com>
* rust-lang.c (eval_op_rust_ind): No longer static. Add "opcode"
parameter.
(rust_evaluate_subexp): Update.
* rust-exp.h (class rust_unop_ind_operation): New.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 7 | ||||
-rw-r--r-- | gdb/rust-exp.h | 25 | ||||
-rw-r--r-- | gdb/rust-lang.c | 5 |
3 files changed, 35 insertions, 2 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 06be5b9..397a606 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,12 @@ 2021-03-08 Tom Tromey <tom@tromey.com> + * rust-lang.c (eval_op_rust_ind): No longer static. Add "opcode" + parameter. + (rust_evaluate_subexp): Update. + * rust-exp.h (class rust_unop_ind_operation): New. + +2021-03-08 Tom Tromey <tom@tromey.com> + * rust-lang.c (eval_op_rust_complement, eval_op_rust_array): No longer static. Add "opcode" parameter. (rust_evaluate_subexp): Update. diff --git a/gdb/rust-exp.h b/gdb/rust-exp.h index cce1fd9..d16f921 100644 --- a/gdb/rust-exp.h +++ b/gdb/rust-exp.h @@ -33,6 +33,11 @@ extern struct value *eval_op_rust_array (struct type *expect_type, enum exp_opcode opcode, struct value *ncopies, struct value *elt); +extern struct value *eval_op_rust_ind (struct type *expect_type, + struct expression *exp, + enum noside noside, + enum exp_opcode opcode, + struct value *value); namespace expr { @@ -42,6 +47,26 @@ using rust_unop_compl_operation = unop_operation<UNOP_COMPLEMENT, using rust_array_operation = binop_operation<OP_RUST_ARRAY, eval_op_rust_array>; +/* The Rust indirection operation. */ +class rust_unop_ind_operation + : public unop_ind_operation +{ +public: + + using unop_ind_operation::unop_ind_operation; + + value *evaluate (struct type *expect_type, + struct expression *exp, + enum noside noside) override + { + if (noside != EVAL_NORMAL) + return unop_ind_operation::evaluate (expect_type, exp, noside); + + value *arg1 = std::get<0> (m_storage)->evaluate (nullptr, exp, noside); + return eval_op_rust_ind (expect_type, exp, noside, UNOP_IND, arg1); + } +}; + } /* namespace expr */ #endif /* RUST_EXP_H */ diff --git a/gdb/rust-lang.c b/gdb/rust-lang.c index 63ea21b..f1f4cd3 100644 --- a/gdb/rust-lang.c +++ b/gdb/rust-lang.c @@ -1325,9 +1325,10 @@ rust_subscript (struct type *expect_type, struct expression *exp, /* A helper function for UNOP_IND. */ -static struct value * +struct value * eval_op_rust_ind (struct type *expect_type, struct expression *exp, enum noside noside, + enum exp_opcode opcode, struct value *value) { gdb_assert (noside == EVAL_NORMAL); @@ -1521,7 +1522,7 @@ rust_evaluate_subexp (struct type *expect_type, struct expression *exp, ++*pos; struct value *value = evaluate_subexp (expect_type, exp, pos, noside); - result = eval_op_rust_ind (expect_type, exp, noside, value); + result = eval_op_rust_ind (expect_type, exp, noside, op, value); } } break; |