diff options
author | Thiago Jung Bauermann <bauerman@br.ibm.com> | 2011-05-11 18:29:01 +0000 |
---|---|---|
committer | Thiago Jung Bauermann <bauerman@br.ibm.com> | 2011-05-11 18:29:01 +0000 |
commit | 1f84b6196ba7218766be02547881a5c2165be3ae (patch) | |
tree | 5ce01d2ca27394b385c6948b33d6acf47cfe2ce3 /gdb | |
parent | 74ac6d431ca65ec3441c392e3467e3d3bf404f8b (diff) | |
download | gdb-1f84b6196ba7218766be02547881a5c2165be3ae.zip gdb-1f84b6196ba7218766be02547881a5c2165be3ae.tar.gz gdb-1f84b6196ba7218766be02547881a5c2165be3ae.tar.bz2 |
* symtab.c (lookup_symtab): Run cleanup before returning.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 4 | ||||
-rw-r--r-- | gdb/symtab.c | 21 |
2 files changed, 22 insertions, 3 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 2ee0b31..ef7a45f 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,7 @@ +2011-05-11 Thiago Jung Bauermann <bauerman@br.ibm.com> + + * symtab.c (lookup_symtab): Run cleanup before returning. + 2011-05-11 Tom Tromey <tromey@redhat.com> * dwarf2read.c (handle_data_member_location): New function. diff --git a/gdb/symtab.c b/gdb/symtab.c index 84e01a6..439bb78 100644 --- a/gdb/symtab.c +++ b/gdb/symtab.c @@ -158,6 +158,9 @@ lookup_symtab (const char *name) struct objfile *objfile; char *real_path = NULL; char *full_path = NULL; + struct cleanup *cleanup; + + cleanup = make_cleanup (null_cleanup, NULL); /* Here we are interested in canonicalizing an absolute path, not absolutizing a relative path. */ @@ -177,6 +180,7 @@ got_symtab: { if (FILENAME_CMP (name, s->filename) == 0) { + do_cleanups (cleanup); return s; } @@ -189,6 +193,7 @@ got_symtab: if (fp != NULL && FILENAME_CMP (full_path, fp) == 0) { + do_cleanups (cleanup); return s; } } @@ -204,6 +209,7 @@ got_symtab: make_cleanup (xfree, rp); if (FILENAME_CMP (real_path, rp) == 0) { + do_cleanups (cleanup); return s; } } @@ -216,7 +222,10 @@ got_symtab: ALL_SYMTABS (objfile, s) { if (FILENAME_CMP (lbasename (s->filename), name) == 0) - return s; + { + do_cleanups (cleanup); + return s; + } } /* Same search rules as above apply here, but now we look thru the @@ -235,9 +244,15 @@ got_symtab: } if (s != NULL) - return s; + { + do_cleanups (cleanup); + return s; + } if (!found) - return NULL; + { + do_cleanups (cleanup); + return NULL; + } /* At this point, we have located the psymtab for this file, but the conversion to a symtab has failed. This usually happens |