This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[PATCH 4/7] [python] API for macros: Add methods to get a gdb.Macro.


2011-08-23  Matt Rice  <ratmice@gmail.com>

	PR python/10807
	* py-symtab.c (stpy_dealloc): Call super's tp_free.
	(salpy_macros, stpy_macros, stpy_macro_named): New methods.
	(sal_object_methods, stpy_object_methods): Add new methods to method list.
---
 gdb/python/py-symtab.c |  112 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 112 insertions(+), 0 deletions(-)

diff --git a/gdb/python/py-symtab.c b/gdb/python/py-symtab.c
index 107cdec..1bceeb6 100644
--- a/gdb/python/py-symtab.c
+++ b/gdb/python/py-symtab.c
@@ -22,6 +22,8 @@
 #include "symtab.h"
 #include "source.h"
 #include "python-internal.h"
+#include "py-macro.h"
+#include "macroscope.h"
 #include "objfiles.h"
 
 typedef struct stpy_symtab_object {
@@ -138,6 +140,35 @@ stpy_fullname (PyObject *self, PyObject *args)
   Py_RETURN_NONE;
 }
 
+static PyObject *
+stpy_macros (PyObject *self, PyObject *args)
+{
+  struct symtab *st = symtab_object_to_symtab (self);
+  PyObject *result;
+  enum macro_walk_result walk_result;
+  struct macropy_user_data mud;
+
+  STPY_REQUIRE_VALID (self, st);
+
+  result = PyList_New (0);
+  if (result == NULL)
+    return NULL;
+
+  mud.list = result;
+  mud.objfile = macro_table_objfile (st->macro_table);
+  walk_result = macro_for_each (st->macro_table,
+				pymacro_add_macro_to_list,
+				&mud);
+
+  if (walk_result == macro_walk_aborted)
+    {
+      Py_DECREF (result);
+      return NULL;
+    }
+
+  return result;
+}
+
 /* Implementation of gdb.Symtab.is_valid (self) -> Boolean.
    Returns True if this Symbol table still exists in GDB.  */
 
@@ -191,6 +222,7 @@ stpy_dealloc (PyObject *obj)
   if (symtab->next)
     symtab->next->prev = symtab->prev;
   symtab->symtab = NULL;
+  obj->ob_type->tp_free (obj);
 }
 
 
@@ -242,6 +274,75 @@ salpy_is_valid (PyObject *self, PyObject *args)
   Py_RETURN_TRUE;
 }
 
+static PyObject *
+salpy_macros (PyObject *self, PyObject *args)
+{
+  struct symtab_and_line *sal;
+  PyObject *result;
+  enum macro_walk_result walk_result;
+  struct macropy_user_data mud;
+  struct macro_scope *ms;
+
+  SALPY_REQUIRE_VALID (self, sal);
+
+  ms = sal_macro_scope (*sal);
+
+  result = PyList_New (0);
+  if (result == NULL)
+    return NULL;
+
+  mud.list = result;
+  mud.objfile = macro_table_objfile (ms->file->table);
+  walk_result = macro_for_each_in_scope (ms->file, ms->line,
+					 pymacro_add_macro_to_list, &mud);
+
+  if (walk_result == macro_walk_aborted)
+    {
+      Py_DECREF (result);
+      return NULL;
+    }
+
+  return result;
+}
+
+static PyObject *
+salpy_macro_named (PyObject *self, PyObject *args)
+{
+  struct symtab_and_line *sal;
+  struct macro_scope *ms;
+  const struct macro_definition *mdef;
+  char *macro_name;
+  struct cleanup *cleanup_chain;
+  struct macro_source_file *file;
+  struct objfile *objfile;
+  PyObject *result;
+  int line;
+
+  if (!PyArg_ParseTuple (args, "s", &macro_name))
+    return NULL;
+
+  SALPY_REQUIRE_VALID (self, sal);
+
+  ms = sal_macro_scope (*sal);
+  cleanup_chain = make_cleanup (free_current_contents, &ms);
+  if (ms == NULL)
+    goto none_exit;
+
+  mdef = macro_lookup_definition (ms->file, ms->line, macro_name);
+  if (mdef == NULL)
+    goto none_exit;
+
+  file = macro_definition_location(ms->file, ms->line, macro_name, &line);
+  objfile = macro_table_objfile(ms->file->table);
+  result = macropy_object_create (objfile, macro_name, mdef, file, line);
+  do_cleanups (cleanup_chain);
+  return result;
+
+  none_exit:
+    do_cleanups (cleanup_chain);
+    return Py_None;
+}
+
 static void
 salpy_dealloc (PyObject *self)
 {
@@ -477,6 +578,9 @@ Return true if this symbol table is valid, false if not." },
   { "fullname", stpy_fullname, METH_NOARGS,
     "fullname () -> String.\n\
 Return the symtab's full source filename." },
+  { "macros", stpy_macros, METH_NOARGS,
+    "macros () -> List.\n\
+Return a list of macros in the symtab." },
   {NULL}  /* Sentinel */
 };
 
@@ -526,6 +630,14 @@ static PyMethodDef sal_object_methods[] = {
   { "is_valid", salpy_is_valid, METH_NOARGS,
     "is_valid () -> Boolean.\n\
 Return true if this symbol table and line is valid, false if not." },
+  { "macro_named", salpy_macro_named, METH_VARARGS,
+    "macro_named (name) -> Macro.\n\
+Return the macro object for the given name, or None if the \
+macro cannot be found." },
+  { "macros", salpy_macros, METH_NOARGS,
+    "macros () -> List.\n\
+Return all the macros which are available at the symbol table and line \
+object's location." },
   {NULL}  /* Sentinel */
 };
 
-- 
1.7.4.4


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]