| Index: gdb/python/py-progspace.c
|
| diff --git a/gdb/python/py-progspace.c b/gdb/python/py-progspace.c
|
| index 1cb82408ce6452f485290e20de102c89670ba9d5..910c6a3fcb32a65c394f5a08d016fe328f3b8fc4 100644
|
| --- a/gdb/python/py-progspace.c
|
| +++ b/gdb/python/py-progspace.c
|
| @@ -1,6 +1,6 @@
|
| /* Python interface to program spaces.
|
|
|
| - Copyright (C) 2010-2012 Free Software Foundation, Inc.
|
| + Copyright (C) 2010-2013 Free Software Foundation, Inc.
|
|
|
| This file is part of GDB.
|
|
|
| @@ -34,9 +34,15 @@ typedef struct
|
|
|
| /* The pretty-printer list of functions. */
|
| PyObject *printers;
|
| +
|
| + /* The frame filter list of functions. */
|
| + PyObject *frame_filters;
|
| + /* The type-printer list. */
|
| + PyObject *type_printers;
|
| } pspace_object;
|
|
|
| -static PyTypeObject pspace_object_type;
|
| +static PyTypeObject pspace_object_type
|
| + CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("pspace_object");
|
|
|
| static const struct program_space_data *pspy_pspace_data_key;
|
|
|
| @@ -54,7 +60,8 @@ pspy_get_filename (PyObject *self, void *closure)
|
| struct objfile *objfile = obj->pspace->symfile_object_file;
|
|
|
| if (objfile)
|
| - return PyString_Decode (objfile->name, strlen (objfile->name),
|
| + return PyString_Decode (objfile_name (objfile),
|
| + strlen (objfile_name (objfile)),
|
| host_charset (), NULL);
|
| }
|
| Py_RETURN_NONE;
|
| @@ -66,7 +73,9 @@ pspy_dealloc (PyObject *self)
|
| pspace_object *ps_self = (pspace_object *) self;
|
|
|
| Py_XDECREF (ps_self->printers);
|
| - self->ob_type->tp_free (self);
|
| + Py_XDECREF (ps_self->frame_filters);
|
| + Py_XDECREF (ps_self->type_printers);
|
| + Py_TYPE (self)->tp_free (self);
|
| }
|
|
|
| static PyObject *
|
| @@ -84,6 +93,20 @@ pspy_new (PyTypeObject *type, PyObject *args, PyObject *keywords)
|
| Py_DECREF (self);
|
| return NULL;
|
| }
|
| +
|
| + self->frame_filters = PyDict_New ();
|
| + if (!self->frame_filters)
|
| + {
|
| + Py_DECREF (self);
|
| + return NULL;
|
| + }
|
| +
|
| + self->type_printers = PyList_New (0);
|
| + if (!self->type_printers)
|
| + {
|
| + Py_DECREF (self);
|
| + return NULL;
|
| + }
|
| }
|
| return (PyObject *) self;
|
| }
|
| @@ -126,6 +149,89 @@ pspy_set_printers (PyObject *o, PyObject *value, void *ignore)
|
| return 0;
|
| }
|
|
|
| +/* Return the Python dictionary attribute containing frame filters for
|
| + this program space. */
|
| +PyObject *
|
| +pspy_get_frame_filters (PyObject *o, void *ignore)
|
| +{
|
| + pspace_object *self = (pspace_object *) o;
|
| +
|
| + Py_INCREF (self->frame_filters);
|
| + return self->frame_filters;
|
| +}
|
| +
|
| +/* Set this object file's frame filters dictionary to FILTERS. */
|
| +static int
|
| +pspy_set_frame_filters (PyObject *o, PyObject *frame, void *ignore)
|
| +{
|
| + PyObject *tmp;
|
| + pspace_object *self = (pspace_object *) o;
|
| +
|
| + if (! frame)
|
| + {
|
| + PyErr_SetString (PyExc_TypeError,
|
| + "cannot delete the frame filter attribute");
|
| + return -1;
|
| + }
|
| +
|
| + if (! PyDict_Check (frame))
|
| + {
|
| + PyErr_SetString (PyExc_TypeError,
|
| + "the frame filter attribute must be a dictionary");
|
| + return -1;
|
| + }
|
| +
|
| + /* Take care in case the LHS and RHS are related somehow. */
|
| + tmp = self->frame_filters;
|
| + Py_INCREF (frame);
|
| + self->frame_filters = frame;
|
| + Py_XDECREF (tmp);
|
| +
|
| + return 0;
|
| +}
|
| +
|
| +/* Get the 'type_printers' attribute. */
|
| +
|
| +static PyObject *
|
| +pspy_get_type_printers (PyObject *o, void *ignore)
|
| +{
|
| + pspace_object *self = (pspace_object *) o;
|
| +
|
| + Py_INCREF (self->type_printers);
|
| + return self->type_printers;
|
| +}
|
| +
|
| +/* Set the 'type_printers' attribute. */
|
| +
|
| +static int
|
| +pspy_set_type_printers (PyObject *o, PyObject *value, void *ignore)
|
| +{
|
| + PyObject *tmp;
|
| + pspace_object *self = (pspace_object *) o;
|
| +
|
| + if (! value)
|
| + {
|
| + PyErr_SetString (PyExc_TypeError,
|
| + "cannot delete the type_printers attribute");
|
| + return -1;
|
| + }
|
| +
|
| + if (! PyList_Check (value))
|
| + {
|
| + PyErr_SetString (PyExc_TypeError,
|
| + "the type_printers attribute must be a list");
|
| + return -1;
|
| + }
|
| +
|
| + /* Take care in case the LHS and RHS are related somehow. */
|
| + tmp = self->type_printers;
|
| + Py_INCREF (value);
|
| + self->type_printers = value;
|
| + Py_XDECREF (tmp);
|
| +
|
| + return 0;
|
| +}
|
| +
|
|
|
|
|
| /* Clear the PSPACE pointer in a Pspace object and remove the reference. */
|
| @@ -168,6 +274,20 @@ pspace_to_pspace_object (struct program_space *pspace)
|
| return NULL;
|
| }
|
|
|
| + object->frame_filters = PyDict_New ();
|
| + if (!object->frame_filters)
|
| + {
|
| + Py_DECREF (object);
|
| + return NULL;
|
| + }
|
| +
|
| + object->type_printers = PyList_New (0);
|
| + if (!object->type_printers)
|
| + {
|
| + Py_DECREF (object);
|
| + return NULL;
|
| + }
|
| +
|
| set_program_space_data (pspace, pspy_pspace_data_key, object);
|
| }
|
| }
|
| @@ -175,18 +295,17 @@ pspace_to_pspace_object (struct program_space *pspace)
|
| return (PyObject *) object;
|
| }
|
|
|
| -void
|
| +int
|
| gdbpy_initialize_pspace (void)
|
| {
|
| pspy_pspace_data_key
|
| - = register_program_space_data_with_cleanup (py_free_pspace);
|
| + = register_program_space_data_with_cleanup (NULL, py_free_pspace);
|
|
|
| if (PyType_Ready (&pspace_object_type) < 0)
|
| - return;
|
| + return -1;
|
|
|
| - Py_INCREF (&pspace_object_type);
|
| - PyModule_AddObject (gdb_module, "Progspace",
|
| - (PyObject *) &pspace_object_type);
|
| + return gdb_pymodule_addobject (gdb_module, "Progspace",
|
| + (PyObject *) &pspace_object_type);
|
| }
|
|
|
|
|
| @@ -197,13 +316,16 @@ static PyGetSetDef pspace_getset[] =
|
| "The progspace's main filename, or None.", NULL },
|
| { "pretty_printers", pspy_get_printers, pspy_set_printers,
|
| "Pretty printers.", NULL },
|
| + { "frame_filters", pspy_get_frame_filters, pspy_set_frame_filters,
|
| + "Frame filters.", NULL },
|
| + { "type_printers", pspy_get_type_printers, pspy_set_type_printers,
|
| + "Type printers.", NULL },
|
| { NULL }
|
| };
|
|
|
| static PyTypeObject pspace_object_type =
|
| {
|
| - PyObject_HEAD_INIT (NULL)
|
| - 0, /*ob_size*/
|
| + PyVarObject_HEAD_INIT (NULL, 0)
|
| "gdb.Progspace", /*tp_name*/
|
| sizeof (pspace_object), /*tp_basicsize*/
|
| 0, /*tp_itemsize*/
|
|
|