aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Tromey <tom@tromey.com>2018-05-27 09:31:26 -0600
committerTom Tromey <tom@tromey.com>2018-06-18 13:26:32 -0600
commit668eb2f045ea535976cf484355831a8808b5ff35 (patch)
tree21ffd343038c1d86f25be92c5286c25975f6e782
parent309822ca289d602b9f9baf4760329ddd08b1d204 (diff)
downloadgdb-668eb2f045ea535976cf484355831a8808b5ff35.zip
gdb-668eb2f045ea535976cf484355831a8808b5ff35.tar.gz
gdb-668eb2f045ea535976cf484355831a8808b5ff35.tar.bz2
Use unique_xmalloc_ptr in darwin_current_sos
This changes darwin_current_sos to use unique_xmalloc_ptr rather than a cleanup. gdb/ChangeLog 2018-06-18 Tom Tromey <tom@tromey.com> * solib-darwin.c (darwin_current_sos): Use unique_xmalloc_ptr.
-rw-r--r--gdb/ChangeLog4
-rw-r--r--gdb/solib-darwin.c13
2 files changed, 8 insertions, 9 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 9c83a4a..c6112d2 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,9 @@
2018-06-18 Tom Tromey <tom@tromey.com>
+ * solib-darwin.c (darwin_current_sos): Use unique_xmalloc_ptr.
+
+2018-06-18 Tom Tromey <tom@tromey.com>
+
* solib-frv.c (frv_relocate_main_executable): Use
unique_xmalloc_ptr.
* solib-dsbt.c (dsbt_relocate_main_executable): Use
diff --git a/gdb/solib-darwin.c b/gdb/solib-darwin.c
index e655110..ed8e0c1 100644
--- a/gdb/solib-darwin.c
+++ b/gdb/solib-darwin.c
@@ -263,8 +263,6 @@ darwin_current_sos (void)
unsigned long hdr_val;
gdb::unique_xmalloc_ptr<char> file_path;
int errcode;
- struct so_list *newobj;
- struct cleanup *old_chain;
/* Read image info from inferior. */
if (target_read_memory (iinfo, buf, image_info_size))
@@ -293,8 +291,7 @@ darwin_current_sos (void)
break;
/* Create and fill the new so_list element. */
- newobj = XCNEW (struct so_list);
- old_chain = make_cleanup (xfree, newobj);
+ gdb::unique_xmalloc_ptr<struct so_list> newobj (XCNEW (struct so_list));
lm_info_darwin *li = new lm_info_darwin;
newobj->lm_info = li;
@@ -305,12 +302,10 @@ darwin_current_sos (void)
li->lm_addr = load_addr;
if (head == NULL)
- head = newobj;
+ head = newobj.get ();
else
- tail->next = newobj;
- tail = newobj;
-
- discard_cleanups (old_chain);
+ tail->next = newobj.get ();
+ tail = newobj.release ();
}
return head;