diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 32e09ac247..cea722e101 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2008-06-30 Luis Machado + + * source.c (select_source_symtab): Make sure we skip namespace + symtabs when showing cpp source code. + 2008-06-30 Hans-Peter Nilsson * MAINTAINERS (Authorized committers): Fix my email address. diff --git a/gdb/source.c b/gdb/source.c index fc5fe0b0f1..e0ae0b179f 100644 --- a/gdb/source.c +++ b/gdb/source.c @@ -250,7 +250,8 @@ select_source_symtab (struct symtab *s) return; } - /* All right; find the last file in the symtab list (ignoring .h's). */ + /* Alright; find the last file in the symtab list (ignoring .h's + and namespace symtabs). */ current_source_line = 1; @@ -260,14 +261,15 @@ select_source_symtab (struct symtab *s) { const char *name = s->filename; int len = strlen (name); - if (!(len > 2 && strcmp(&name[len - 2], ".h") == 0)) + if (!(len > 2 && (strcmp (&name[len - 2], ".h") == 0 + || strcmp (name, "<>") == 0))) current_source_symtab = s; } } if (current_source_symtab) return; - /* Howabout the partial symbol tables? */ + /* How about the partial symbol tables? */ for (ofp = object_files; ofp != NULL; ofp = ofp->next) { @@ -275,7 +277,8 @@ select_source_symtab (struct symtab *s) { const char *name = ps->filename; int len = strlen (name); - if (!(len > 2 && strcmp (&name[len - 2], ".h") == 0)) + if (!(len > 2 && (strcmp (&name[len - 2], ".h") == 0 + || strcmp (name, "<>") == 0))) cs_pst = ps; } }