From b963592585c05fcfd6817584a9f4e10d038c043a Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Thu, 30 May 2013 17:04:47 +0000 Subject: [PATCH] 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. --- gdb/ChangeLog | 4 ++++ gdb/mi/mi-main.c | 5 ++++- 2 files changed, 8 insertions(+), 1 deletion(-) 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 -- 2.30.2