aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorThiago Jung Bauermann <bauerman@br.ibm.com>2011-05-11 18:29:01 +0000
committerThiago Jung Bauermann <bauerman@br.ibm.com>2011-05-11 18:29:01 +0000
commit1f84b6196ba7218766be02547881a5c2165be3ae (patch)
tree5ce01d2ca27394b385c6948b33d6acf47cfe2ce3 /gdb
parent74ac6d431ca65ec3441c392e3467e3d3bf404f8b (diff)
downloadgdb-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/ChangeLog4
-rw-r--r--gdb/symtab.c21
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