diff options
author | Tom Tromey <tromey@adacore.com> | 2020-06-30 07:57:35 -0600 |
---|---|---|
committer | Tom Tromey <tromey@adacore.com> | 2020-06-30 07:57:35 -0600 |
commit | a1520ad8fc5c5c1932d69e4685836cc1375bd850 (patch) | |
tree | 1f7e23e59779033b49c9522ec38d179353b81f3e | |
parent | 5ac588997c3c2d032d5d5145d9245eb37354c23b (diff) | |
download | gdb-a1520ad8fc5c5c1932d69e4685836cc1375bd850.zip gdb-a1520ad8fc5c5c1932d69e4685836cc1375bd850.tar.gz gdb-a1520ad8fc5c5c1932d69e4685836cc1375bd850.tar.bz2 |
Fix bug in quirk_rust_enum
Tom de Vries pointed out that some Rust tests were failing after the
variant part rewrite. He sent an executable, which helped track down
this bug.
quirk_rust_enum was passing 1 to alloc_rust_variant in one case.
However, a comment earlier says:
/* We don't need a range entry for the discriminant, but we do
need one for every other field, as there is no default
variant. */
In this case, we must pass -1 for this parameter. That is what this
patch implements.
gdb/ChangeLog
2020-06-30 Tom Tromey <tromey@adacore.com>
* dwarf2/read.c (quirk_rust_enum): Correctly call
alloc_rust_variant for default-less enum.
-rw-r--r-- | gdb/ChangeLog | 5 | ||||
-rw-r--r-- | gdb/dwarf2/read.c | 2 |
2 files changed, 6 insertions, 1 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index ddd831e..d64f572 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,10 @@ 2020-06-30 Tom Tromey <tromey@adacore.com> + * dwarf2/read.c (quirk_rust_enum): Correctly call + alloc_rust_variant for default-less enum. + +2020-06-30 Tom Tromey <tromey@adacore.com> + PR build/26183: * ada-lang.c (ada_lookup_name_info::ada_lookup_name_info): Use gdb::to_string. diff --git a/gdb/dwarf2/read.c b/gdb/dwarf2/read.c index 4dc9ad6..b097f62 100644 --- a/gdb/dwarf2/read.c +++ b/gdb/dwarf2/read.c @@ -9691,7 +9691,7 @@ quirk_rust_enum (struct type *type, struct objfile *objfile) } /* Indicate that this is a variant type. */ - alloc_rust_variant (&objfile->objfile_obstack, type, 0, 1, + alloc_rust_variant (&objfile->objfile_obstack, type, 0, -1, gdb::array_view<discriminant_range> (ranges, n_fields - 1)); } |