From 88b6faea9953505e9e8a7a77995c7db5dfb6ac19 Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Wed, 11 Jan 2017 16:28:43 -0700 Subject: Use gdbpy_ref to simplify some logic This uses the new gdbpy_ref template to simplify logic in various parts of the Python layer; for example removing repeated error code or removing gotos. gdb/ChangeLog 2017-02-10 Tom Tromey * python/py-cmd.c (cmdpy_destroyer): Use gdbpy_ref. * python/py-breakpoint.c (gdbpy_breakpoint_deleted): Use gdbpy_ref. * python/py-type.c (field_new): Use gdbpy_ref. * python/py-symtab.c (symtab_and_line_to_sal_object): Use gdbpy_ref. * python/py-progspace.c (pspy_new): Use gdbpy_ref. (py_free_pspace): Likewise. (pspace_to_pspace_object): Likewise. * python/py-objfile.c (objfpy_new): Use gdbpy_ref. (py_free_objfile): Likewise. (objfile_to_objfile_object): Likewise. * python/py-inferior.c (delete_thread_object): Use gdbpy_ref. (infpy_read_memory): Likewise. (py_free_inferior): Likewise. * python/py-evtregistry.c (create_eventregistry_object): Use gdbpy_ref. * python/py-event.c (create_event_object): Use gdbpy_ref. --- gdb/python/py-event.c | 16 +++++----------- 1 file changed, 5 insertions(+), 11 deletions(-) (limited to 'gdb/python/py-event.c') diff --git a/gdb/python/py-event.c b/gdb/python/py-event.c index 161a5e1..127dcc7 100644 --- a/gdb/python/py-event.c +++ b/gdb/python/py-event.c @@ -30,21 +30,15 @@ evpy_dealloc (PyObject *self) PyObject * create_event_object (PyTypeObject *py_type) { - event_object *event_obj; - - event_obj = PyObject_New (event_object, py_type); - if (!event_obj) - goto fail; + gdbpy_ref event_obj (PyObject_New (event_object, py_type)); + if (event_obj == NULL) + return NULL; event_obj->dict = PyDict_New (); if (!event_obj->dict) - goto fail; - - return (PyObject*) event_obj; + return NULL; - fail: - Py_XDECREF (event_obj); - return NULL; + return (PyObject*) event_obj.release (); } /* Add the attribute ATTR to the event object EVENT. In -- cgit v1.1