diff options
author | Tom Tromey <tom@tromey.com> | 2020-12-11 09:33:36 -0700 |
---|---|---|
committer | Tom Tromey <tom@tromey.com> | 2020-12-11 09:33:42 -0700 |
commit | 1345dee2805220742355b331934c2cdedf7669c6 (patch) | |
tree | e35f362c3cc938b7ea21f204393ae1f02a78456c /gdb/varobj.c | |
parent | 446d2c032d387a75020ecb41b5d89dd93158beb0 (diff) | |
download | fsf-binutils-gdb-1345dee2805220742355b331934c2cdedf7669c6.zip fsf-binutils-gdb-1345dee2805220742355b331934c2cdedf7669c6.tar.gz fsf-binutils-gdb-1345dee2805220742355b331934c2cdedf7669c6.tar.bz2 |
Use gdbpy_ref in instantiate_pretty_printer
This changes instantiate_pretty_printer to use gdbpy_ref, removing a
call to Py_DECREF.
gdb/ChangeLog
2020-12-11 Tom Tromey <tom@tromey.com>
* varobj.c (instantiate_pretty_printer): Use gdbpy_ref.
Diffstat (limited to 'gdb/varobj.c')
-rw-r--r-- | gdb/varobj.c | 11 |
1 files changed, 3 insertions, 8 deletions
diff --git a/gdb/varobj.c b/gdb/varobj.c index 941c38c..ba0e135 100644 --- a/gdb/varobj.c +++ b/gdb/varobj.c @@ -459,16 +459,11 @@ varobj_delete (struct varobj *var, bool only_children) static PyObject * instantiate_pretty_printer (PyObject *constructor, struct value *value) { - PyObject *val_obj = NULL; - PyObject *printer; - - val_obj = value_to_value_object (value); - if (! val_obj) + gdbpy_ref<> val_obj (value_to_value_object (value)); + if (val_obj == nullptr) return NULL; - printer = PyObject_CallFunctionObjArgs (constructor, val_obj, NULL); - Py_DECREF (val_obj); - return printer; + return PyObject_CallFunctionObjArgs (constructor, val_obj.get (), NULL); } #endif |