summaryrefslogtreecommitdiffstats
path: root/toolchain/gdb/6.3/690-debian_member-field-symtab.patch
diff options
context:
space:
mode:
Diffstat (limited to 'toolchain/gdb/6.3/690-debian_member-field-symtab.patch')
-rw-r--r--toolchain/gdb/6.3/690-debian_member-field-symtab.patch35
1 files changed, 35 insertions, 0 deletions
diff --git a/toolchain/gdb/6.3/690-debian_member-field-symtab.patch b/toolchain/gdb/6.3/690-debian_member-field-symtab.patch
new file mode 100644
index 000000000..4f5fb45c3
--- /dev/null
+++ b/toolchain/gdb/6.3/690-debian_member-field-symtab.patch
@@ -0,0 +1,35 @@
+Status: unsubmitted
+
+This patch was for Debian bug #239535. It needs to be tested, and
+submitted.
+
+Index: gdb-6.3/gdb/valops.c
+===================================================================
+--- gdb-6.3.orig/gdb/valops.c 2004-11-09 22:51:07.000000000 -0500
++++ gdb-6.3/gdb/valops.c 2004-11-10 00:43:54.036837699 -0500
+@@ -2314,8 +2314,10 @@ check_field_in (struct type *type, const
+ return 1;
+ }
+
++ /* Check each baseclass. Call check_typedef, which will follow typedefs
++ and do opaque/stub type resolution. */
+ for (i = TYPE_N_BASECLASSES (type) - 1; i >= 0; i--)
+- if (check_field_in (TYPE_BASECLASS (type, i), name))
++ if (check_field_in (check_typedef (TYPE_BASECLASS (type, i)), name))
+ return 1;
+
+ return 0;
+Index: gdb-6.3/gdb/dwarf2read.c
+===================================================================
+--- gdb-6.3.orig/gdb/dwarf2read.c 2004-10-15 20:41:00.000000000 -0400
++++ gdb-6.3/gdb/dwarf2read.c 2004-11-10 00:46:21.970935829 -0500
+@@ -2099,8 +2099,8 @@ guess_structure_name (struct partial_die
+ strlen (actual_class_name),
+ &cu->comp_unit_obstack);
+ xfree (actual_class_name);
++ break;
+ }
+- break;
+ }
+
+ child_pdi = child_pdi->die_sibling;