]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
gdb/python: accept gdbpy_ref in init helpers and return bool
authorMatthieu Longo <matthieu.longo@arm.com>
Fri, 27 Feb 2026 10:28:34 +0000 (10:28 +0000)
committerMatthieu Longo <matthieu.longo@arm.com>
Mon, 9 Mar 2026 13:09:18 +0000 (13:09 +0000)
Passing 'gdbpy_ref<> &' instead of raw 'PyObject *' to init helpers
makes ownership of PyObject clearer at call sites, and removes
unnecessary '.get()' calls.
Changing the return type from 'int' to 'bool' improves readability
and better expresses the success/failure semantics.

Approved-By: Tom Tromey <tom@tromey.com>
gdb/python/py-objfile.c
gdb/python/py-progspace.c

index 5d7cfe83ec263092012f3675e1152ca4ecbdb697..bbe21d325490d5e47ecdded59768f4be54c21860 100644 (file)
@@ -198,36 +198,36 @@ objfpy_dealloc (PyObject *o)
 /* Initialize an objfile_object.
    The result is a boolean indicating success.  */
 
-static int
-objfpy_initialize (objfile_object *self)
+static bool
+objfpy_initialize (gdbpy_ref<objfile_object> &self)
 {
   self->objfile = NULL;
 
   self->dict = PyDict_New ();
   if (self->dict == NULL)
-    return 0;
+    return false;
 
   self->printers = PyList_New (0);
   if (self->printers == NULL)
-    return 0;
+    return false;
 
   self->frame_filters = PyDict_New ();
   if (self->frame_filters == NULL)
-    return 0;
+    return false;
 
   self->frame_unwinders = PyList_New (0);
   if (self->frame_unwinders == NULL)
-    return 0;
+    return false;
 
   self->type_printers = PyList_New (0);
   if (self->type_printers == NULL)
-    return 0;
+    return false;
 
   self->xmethods = PyList_New (0);
   if (self->xmethods == NULL)
-    return 0;
+    return false;
 
-  return 1;
+  return true;
 }
 
 static PyObject *
@@ -235,11 +235,8 @@ objfpy_new (PyTypeObject *type, PyObject *args, PyObject *keywords)
 {
   gdbpy_ref<objfile_object> self ((objfile_object *) type->tp_alloc (type, 0));
 
-  if (self != NULL)
-    {
-      if (!objfpy_initialize (self.get ()))
-       return NULL;
-    }
+  if (self != nullptr && !objfpy_initialize (self))
+    return nullptr;
 
   return (PyObject *) self.release ();
 }
@@ -682,7 +679,7 @@ objfile_to_objfile_object (struct objfile *objfile)
        ((objfile_object *) PyObject_New (objfile_object, &objfile_object_type));
       if (object == NULL)
        return NULL;
-      if (!objfpy_initialize (object.get ()))
+      if (!objfpy_initialize (object))
        return NULL;
 
       object->objfile = objfile;
index baab3be5ee60a7ca7a053ce5719e118fcac45bf5..5a23c4c71776eded481f12a412ac5625f608527e 100644 (file)
@@ -166,40 +166,40 @@ pspy_dealloc (PyObject *self)
 /* Initialize a pspace_object.
    The result is a boolean indicating success.  */
 
-static int
-pspy_initialize (pspace_object *self)
+static bool
+pspy_initialize (gdbpy_ref<pspace_object> &self)
 {
   self->pspace = NULL;
 
   self->dict = PyDict_New ();
   if (self->dict == NULL)
-    return 0;
+    return false;
 
   self->printers = PyList_New (0);
   if (self->printers == NULL)
-    return 0;
+    return false;
 
   self->frame_filters = PyDict_New ();
   if (self->frame_filters == NULL)
-    return 0;
+    return false;
 
   self->frame_unwinders = PyList_New (0);
   if (self->frame_unwinders == NULL)
-    return 0;
+    return false;
 
   self->type_printers = PyList_New (0);
   if (self->type_printers == NULL)
-    return 0;
+    return false;
 
   self->xmethods = PyList_New (0);
   if (self->xmethods == NULL)
-    return 0;
+    return false;
 
   self->missing_file_handlers = PyList_New (0);
   if (self->missing_file_handlers == nullptr)
-    return 0;
+    return false;
 
-  return 1;
+  return true;
 }
 
 PyObject *
@@ -591,7 +591,7 @@ pspace_to_pspace_object (struct program_space *pspace)
        ((pspace_object *) PyObject_New (pspace_object, &pspace_object_type));
       if (object == NULL)
        return NULL;
-      if (!pspy_initialize (object.get ()))
+      if (!pspy_initialize (object))
        return NULL;
 
       object->pspace = pspace;