From: Tom Tromey Date: Thu, 30 May 2013 17:04:47 +0000 (+0000) Subject: fix list_available_thread_groups X-Git-Tag: cygwin-1_7_19-release~42 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=b963592585c05fcfd6817584a9f4e10d038c043a;p=thirdparty%2Fbinutils-gdb.git fix list_available_thread_groups list_available_thread_groups, in mi-main.c, leaks a cleanup. This changes it to call do_cleanups. * mi/mi-main.c (list_available_thread_groups): Call do_cleanups. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index c3303ea78dd..53a3eb711ab 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,7 @@ +2013-05-30 Tom Tromey + + * mi/mi-main.c (list_available_thread_groups): Call do_cleanups. + 2013-05-30 Tom Tromey * inf-ptrace.c (inf_ptrace_create_inferior): Unconditionally diff --git a/gdb/mi/mi-main.c b/gdb/mi/mi-main.c index 9428e8c8df4..f69cd8d62d7 100644 --- a/gdb/mi/mi-main.c +++ b/gdb/mi/mi-main.c @@ -681,6 +681,7 @@ list_available_thread_groups (VEC (int) *ids, int recurse) struct osdata_item *item; int ix_items; struct ui_out *uiout = current_uiout; + struct cleanup *cleanup; /* This keeps a map from integer (pid) to VEC (struct osdata_item *)* The vector contains information about all threads for the given pid. @@ -690,7 +691,7 @@ list_available_thread_groups (VEC (int) *ids, int recurse) /* get_osdata will throw if it cannot return data. */ data = get_osdata ("processes"); - make_cleanup_osdata_free (data); + cleanup = make_cleanup_osdata_free (data); if (recurse) { @@ -793,6 +794,8 @@ list_available_thread_groups (VEC (int) *ids, int recurse) do_cleanups (back_to); } + + do_cleanups (cleanup); } void