aboutsummaryrefslogtreecommitdiff
path: root/gdb/rust-lang.c
diff options
context:
space:
mode:
authorTom Tromey <tom@tromey.com>2022-03-27 15:29:28 -0600
committerTom Tromey <tom@tromey.com>2022-04-15 10:34:03 -0600
commit1c9cc05244f67c4e5a888394b2c9a309164ca02d (patch)
tree4793ceaf045ebb1302482a69c75e0e913275bd45 /gdb/rust-lang.c
parent506ec52e8805d8edd538d6bd11750489a8c8bbee (diff)
downloadgdb-1c9cc05244f67c4e5a888394b2c9a309164ca02d.zip
gdb-1c9cc05244f67c4e5a888394b2c9a309164ca02d.tar.gz
gdb-1c9cc05244f67c4e5a888394b2c9a309164ca02d.tar.bz2
Implement value_print for Rust
This adds an implementation of the value_print method to Rust. As described in PR rust/22254, this removes a bit of weird-looking output from some "print"s -- because c_value_print is bypassed. I don't have a test for the bug that inspired this patch, because I only know how to reproduce it when using a relatively old Rust compiler. However, the new "cast-printing" code in value_print is required, because omitting this causes some existing tests to fail. Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=22254
Diffstat (limited to 'gdb/rust-lang.c')
-rw-r--r--gdb/rust-lang.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/gdb/rust-lang.c b/gdb/rust-lang.c
index d4a221a..bf8dba9 100644
--- a/gdb/rust-lang.c
+++ b/gdb/rust-lang.c
@@ -624,6 +624,27 @@ rust_language::value_print_inner
}
}
+/* See language.h. */
+
+void
+rust_language::value_print
+ (struct value *val, struct ui_file *stream,
+ const struct value_print_options *options) const
+{
+ value_print_options opts = *options;
+ opts.deref_ref = true;
+
+ struct type *type = check_typedef (value_type (val));
+ if (type->is_pointer_or_reference ())
+ {
+ gdb_printf (stream, "(");
+ type_print (value_type (val), "", stream, -1);
+ gdb_printf (stream, ") ");
+ }
+
+ return common_val_print (val, stream, 0, &opts, this);
+}
+
static void