diff options
author | Bob Rossi <bob@brasko.net> | 2004-07-08 11:18:27 +0000 |
---|---|---|
committer | Bob Rossi <bob@brasko.net> | 2004-07-08 11:18:27 +0000 |
commit | 1ece78f05dafa3f623f4b585652166bb28449995 (patch) | |
tree | a3508f9891374c7fce111106c13bb5db8bb33c18 | |
parent | 8351ea3f01c3cb249fce85f0e6bfba2121786757 (diff) | |
download | gdb-1ece78f05dafa3f623f4b585652166bb28449995.tar.gz |
Fix crash in symtab.c.
-rw-r--r-- | gdb/ChangeLog | 4 | ||||
-rw-r--r-- | gdb/symtab.c | 26 |
2 files changed, 19 insertions, 11 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 8f694501ce4..5d84bf7f5d6 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,7 @@ +2004-07-08 Bob Rossi <bob@brasko.net> + + * symtab.c (lookup_symtab): check return value of symtab_to_fullname + 2004-07-06 Jeff Johnston <jjohnstn@redhat.com> * language.h (struct_language_defn): Add new function pointer: diff --git a/gdb/symtab.c b/gdb/symtab.c index 8fa7cecb7a5..cd6dd5dd838 100644 --- a/gdb/symtab.c +++ b/gdb/symtab.c @@ -181,21 +181,25 @@ got_symtab: if (full_path != NULL) { - const char *fp = symtab_to_fullname (s); - if (FILENAME_CMP (full_path, fp) == 0) - { - return s; - } + const char *fp = symtab_to_fullname (s); + if (fp != NULL && FILENAME_CMP (full_path, fp) == 0) + { + return s; + } } if (real_path != NULL) { - char *rp = gdb_realpath (symtab_to_fullname (s)); - make_cleanup (xfree, rp); - if (FILENAME_CMP (real_path, rp) == 0) - { - return s; - } + char *fullname = symtab_to_fullname (s); + if (fullname != NULL) + { + char *rp = gdb_realpath (fullname); + make_cleanup (xfree, rp); + if (FILENAME_CMP (real_path, rp) == 0) + { + return s; + } + } } } |