aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gdb/ChangeLog5
-rw-r--r--gdb/ax-gdb.c5
-rw-r--r--gdb/expop.h36
3 files changed, 46 insertions, 0 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index fb0eea2..1998e48 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,10 @@
2021-03-08 Tom Tromey <tom@tromey.com>
+ * expop.h (class unop_addr_operation): New.
+ * ax-gdb.c (gen_expr_unop) <case UNOP_ADDR>: New.
+
+2021-03-08 Tom Tromey <tom@tromey.com>
+
* expop.h (class typeid_operation): New.
2021-03-08 Tom Tromey <tom@tromey.com>
diff --git a/gdb/ax-gdb.c b/gdb/ax-gdb.c
index f7ab50f..6471088 100644
--- a/gdb/ax-gdb.c
+++ b/gdb/ax-gdb.c
@@ -2744,6 +2744,11 @@ gen_expr_unop (struct expression *exp,
gen_deref (value);
break;
+ case UNOP_ADDR:
+ lhs->generate_ax (exp, ax, value);
+ gen_address_of (value);
+ break;
+
default:
gdb_assert_not_reached ("invalid case in gen_expr_unop");
}
diff --git a/gdb/expop.h b/gdb/expop.h
index 804f516..a09be96 100644
--- a/gdb/expop.h
+++ b/gdb/expop.h
@@ -1546,6 +1546,42 @@ public:
{ return OP_TYPEID; }
};
+/* Implement the address-of operation. */
+class unop_addr_operation
+ : public maybe_constant_operation<operation_up>
+{
+public:
+
+ using maybe_constant_operation::maybe_constant_operation;
+
+ value *evaluate (struct type *expect_type,
+ struct expression *exp,
+ enum noside noside) override
+ {
+ /* C++: check for and handle pointer to members. */
+ if (noside == EVAL_SKIP)
+ return eval_skip_value (exp);
+ else
+ return std::get<0> (m_storage)->evaluate_for_address (exp, noside);
+ }
+
+ enum exp_opcode opcode () const override
+ { return UNOP_ADDR; }
+
+protected:
+
+ void do_generate_ax (struct expression *exp,
+ struct agent_expr *ax,
+ struct axs_value *value,
+ struct type *cast_type)
+ override
+ {
+ gen_expr_unop (exp, UNOP_ADDR,
+ std::get<0> (this->m_storage).get (),
+ ax, value);
+ }
+};
+
} /* namespace expr */
#endif /* EXPOP_H */