]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
Add gdbpy_call_method overloads for gdbpy_ref<>
authorTom Tromey <tromey@adacore.com>
Tue, 11 Jun 2024 20:12:09 +0000 (14:12 -0600)
committerTom Tromey <tromey@adacore.com>
Thu, 13 Jun 2024 16:13:37 +0000 (10:13 -0600)
This adds an overload of gdbpy_call_method that accepts a gdbpy_ref<>.
This is just a small convenience.

Reviewed-By: Tom de Vries <tdevries@suse.de>
gdb/python/py-tui.c
gdb/python/python-internal.h

index 901f6fe67434538f30574a05b4eda5fcf329d994..984fa9b6b45642bfa6028e558969fcb688587e54 100644 (file)
@@ -164,7 +164,7 @@ tui_py_window::~tui_py_window ()
   if (m_window != nullptr
       && PyObject_HasAttrString (m_window.get (), "close"))
     {
-      gdbpy_ref<> result = gdbpy_call_method (m_window.get (), "close");
+      gdbpy_ref<> result = gdbpy_call_method (m_window, "close");
       if (result == nullptr)
        gdbpy_print_stack ();
     }
@@ -197,7 +197,7 @@ tui_py_window::rerender ()
 
   if (PyObject_HasAttrString (m_window.get (), "render"))
     {
-      gdbpy_ref<> result = gdbpy_call_method (m_window.get (), "render");
+      gdbpy_ref<> result = gdbpy_call_method (m_window, "render");
       if (result == nullptr)
        gdbpy_print_stack ();
     }
@@ -210,7 +210,7 @@ tui_py_window::do_scroll_horizontal (int num_to_scroll)
 
   if (PyObject_HasAttrString (m_window.get (), "hscroll"))
     {
-      gdbpy_ref<> result = gdbpy_call_method (m_window.get(), "hscroll",
+      gdbpy_ref<> result = gdbpy_call_method (m_window, "hscroll",
                                              num_to_scroll);
       if (result == nullptr)
        gdbpy_print_stack ();
@@ -224,7 +224,7 @@ tui_py_window::do_scroll_vertical (int num_to_scroll)
 
   if (PyObject_HasAttrString (m_window.get (), "vscroll"))
     {
-      gdbpy_ref<> result = gdbpy_call_method (m_window.get (), "vscroll",
+      gdbpy_ref<> result = gdbpy_call_method (m_window, "vscroll",
                                              num_to_scroll);
       if (result == nullptr)
        gdbpy_print_stack ();
@@ -246,7 +246,7 @@ tui_py_window::click (int mouse_x, int mouse_y, int mouse_button)
 
   if (PyObject_HasAttrString (m_window.get (), "click"))
     {
-      gdbpy_ref<> result = gdbpy_call_method (m_window.get (), "click",
+      gdbpy_ref<> result = gdbpy_call_method (m_window, "click",
                                              mouse_x, mouse_y, mouse_button);
       if (result == nullptr)
        gdbpy_print_stack ();
index caf85f5f9b997f668203d6913d215984c536bdcf..f4c35babe46f00b1f59e141fa692dc27b4b3cfc0 100644 (file)
@@ -207,6 +207,15 @@ gdbpy_call_method (PyObject *o, const char *method,
                                           arg, args...));
 }
 
+/* An overload that takes a gdbpy_ref<> rather than a raw 'PyObject *'.  */
+
+template<typename... Args>
+static inline gdbpy_ref<>
+gdbpy_call_method (const gdbpy_ref<> &o, const char *method, Args... args)
+{
+  return gdbpy_call_method (o.get (), method, args...);
+}
+
 /* Poison PyObject_CallMethod.  The typesafe wrapper gdbpy_call_method should be
    used instead.  */
 #undef PyObject_CallMethod