PR python/14387:

* python/py-bpevent.c (create_breakpoint_event_object): Update
	comment.
	* python/py-event.c (evpy_add_attribute): Update comment.
	* python/py-exitedevent.c (create_exited_event_object): Fix
	reference counting and error handling.
	* python/py-newobjfileevent.c (create_new_objfile_event_object):
	Fix reference counting.
	* python/py-signalevent.c (create_signal_event_object): Fix
	reference counting and error handling.
	* python/py-stopevent.c (emit_stop_event): Fix reference
	counting.
	* python/py-threadevent.c (get_event_thread): Return a
	borrowed reference.
	* python/py-type.c (convert_field): Fix reference counting.
This commit is contained in:
Tom Tromey 2012-08-15 14:22:02 +00:00
parent a036ba48ef
commit db6573d664
9 changed files with 63 additions and 19 deletions

View File

@ -1,3 +1,21 @@
2012-08-15 Tom Tromey <tromey@redhat.com>
PR python/14387:
* python/py-bpevent.c (create_breakpoint_event_object): Update
comment.
* python/py-event.c (evpy_add_attribute): Update comment.
* python/py-exitedevent.c (create_exited_event_object): Fix
reference counting and error handling.
* python/py-newobjfileevent.c (create_new_objfile_event_object):
Fix reference counting.
* python/py-signalevent.c (create_signal_event_object): Fix
reference counting and error handling.
* python/py-stopevent.c (emit_stop_event): Fix reference
counting.
* python/py-threadevent.c (get_event_thread): Return a
borrowed reference.
* python/py-type.c (convert_field): Fix reference counting.
2012-08-15 Tom Tromey <tromey@redhat.com>
* dwarf2read.c (dwarf_decode_macro_bytes)

View File

@ -21,7 +21,8 @@
static PyTypeObject breakpoint_event_object_type;
/* Create and initialize a BreakpointEvent object. */
/* Create and initialize a BreakpointEvent object. This acquires new
references to BREAKPOINT_LIST and FIRST_BP. */
PyObject *
create_breakpoint_event_object (PyObject *breakpoint_list, PyObject *first_bp)

View File

@ -48,7 +48,8 @@ create_event_object (PyTypeObject *py_type)
/* Add the attribute ATTR to the event object EVENT. In
python this attribute will be accessible by the name NAME.
returns 0 if the operation succeeds and -1 otherwise. */
returns 0 if the operation succeeds and -1 otherwise. This
function acquires a new reference to ATTR. */
int
evpy_add_attribute (PyObject *event, char *name, PyObject *attr)

View File

@ -25,30 +25,41 @@ static PyObject *
create_exited_event_object (const LONGEST *exit_code, struct inferior *inf)
{
PyObject *exited_event;
PyObject *inf_obj;
PyObject *inf_obj = NULL;
exited_event = create_event_object (&exited_event_object_type);
if (!exited_event)
goto fail;
if (exit_code
&& evpy_add_attribute (exited_event,
"exit_code",
PyLong_FromLongLong (*exit_code)) < 0)
goto fail;
if (exit_code)
{
PyObject *exit_code_obj = PyLong_FromLongLong (*exit_code);
int failed;
if (exit_code_obj == NULL)
goto fail;
failed = evpy_add_attribute (exited_event, "exit_code",
exit_code_obj) < 0;
Py_DECREF (exit_code_obj);
if (failed)
goto fail;
}
inf_obj = inferior_to_inferior_object (inf);
if (!inf_obj || evpy_add_attribute (exited_event,
"inferior",
inf_obj) < 0)
goto fail;
Py_DECREF (inf_obj);
return exited_event;
fail:
Py_XDECREF (exited_event);
return NULL;
fail:
Py_XDECREF (inf_obj);
Py_XDECREF (exited_event);
return NULL;
}
/* Callback that is used when an exit event occurs. This function

View File

@ -25,7 +25,7 @@ static PyObject *
create_new_objfile_event_object (struct objfile *objfile)
{
PyObject *objfile_event;
PyObject *py_objfile;
PyObject *py_objfile = NULL;
objfile_event = create_event_object (&new_objfile_event_object_type);
if (!objfile_event)
@ -36,10 +36,12 @@ create_new_objfile_event_object (struct objfile *objfile)
"new_objfile",
py_objfile) < 0)
goto fail;
Py_DECREF (py_objfile);
return objfile_event;
fail:
Py_XDECREF (py_objfile);
Py_XDECREF (objfile_event);
return NULL;
}

View File

@ -25,6 +25,7 @@ PyObject *
create_signal_event_object (enum gdb_signal stop_signal)
{
const char *signal_name;
PyObject *signal_name_obj = NULL;
PyObject *signal_event_obj =
create_stop_event_object (&signal_event_object_type);
@ -33,16 +34,21 @@ create_signal_event_object (enum gdb_signal stop_signal)
signal_name = gdb_signal_to_name (stop_signal);
signal_name_obj = PyString_FromString (signal_name);
if (signal_name_obj == NULL)
goto fail;
if (evpy_add_attribute (signal_event_obj,
"stop_signal",
PyString_FromString (signal_name)) < 0)
signal_name_obj) < 0)
goto fail;
Py_DECREF (signal_name_obj);
return signal_event_obj;
fail:
Py_XDECREF (signal_event_obj);
return NULL;
fail:
Py_XDECREF (signal_name_obj);
Py_XDECREF (signal_event_obj);
return NULL;
}
GDBPY_NEW_EVENT_TYPE (signal,

View File

@ -81,6 +81,7 @@ emit_stop_event (struct bpstats *bs, enum gdb_signal stop_signal)
stop_event_obj = create_breakpoint_event_object (list, first_bp);
if (!stop_event_obj)
goto fail;
Py_DECREF (list);
}
/* Check if the signal is "Signal 0" or "Trace/breakpoint trap". */

View File

@ -21,7 +21,7 @@
running in non-stop mode then the event is thread specific, otherwise
it is process wide.
This function returns the currently stopped thread in non-stop mode and
Py_None otherwise. */
Py_None otherwise. In each case it returns a borrowed reference. */
static PyObject *
get_event_thread (void)
@ -39,8 +39,6 @@ get_event_thread (void)
return NULL;
}
Py_INCREF (thread);
return thread;
}

View File

@ -186,6 +186,7 @@ convert_field (struct type *type, int field)
/* At least python-2.4 had the second parameter non-const. */
if (PyObject_SetAttrString (result, (char *) attrstring, arg) < 0)
goto failarg;
Py_DECREF (arg);
}
if (TYPE_FIELD_NAME (type, field))
@ -199,11 +200,13 @@ convert_field (struct type *type, int field)
goto fail;
if (PyObject_SetAttrString (result, "name", arg) < 0)
goto failarg;
Py_DECREF (arg);
arg = TYPE_FIELD_ARTIFICIAL (type, field) ? Py_True : Py_False;
Py_INCREF (arg);
if (PyObject_SetAttrString (result, "artificial", arg) < 0)
goto failarg;
Py_DECREF (arg);
if (TYPE_CODE (type) == TYPE_CODE_CLASS)
arg = field < TYPE_N_BASECLASSES (type) ? Py_True : Py_False;
@ -212,12 +215,14 @@ convert_field (struct type *type, int field)
Py_INCREF (arg);
if (PyObject_SetAttrString (result, "is_base_class", arg) < 0)
goto failarg;
Py_DECREF (arg);
arg = PyLong_FromLong (TYPE_FIELD_BITSIZE (type, field));
if (!arg)
goto fail;
if (PyObject_SetAttrString (result, "bitsize", arg) < 0)
goto failarg;
Py_DECREF (arg);
/* A field can have a NULL type in some situations. */
if (TYPE_FIELD_TYPE (type, field) == NULL)
@ -231,6 +236,7 @@ convert_field (struct type *type, int field)
goto fail;
if (PyObject_SetAttrString (result, "type", arg) < 0)
goto failarg;
Py_DECREF (arg);
return result;