1 /* Python interface to objfiles.
3 Copyright (C) 2008-2013 Free Software Foundation, Inc.
5 This file is part of GDB.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
21 #include "python-internal.h"
30 /* The corresponding objfile. */
31 struct objfile
*objfile
;
33 /* The pretty-printer list of functions. */
36 /* The frame filter list of functions. */
37 PyObject
*frame_filters
;
38 /* The type-printer list. */
39 PyObject
*type_printers
;
42 static PyTypeObject objfile_object_type
;
44 static const struct objfile_data
*objfpy_objfile_data_key
;
48 /* An Objfile method which returns the objfile's file name, or None. */
50 objfpy_get_filename (PyObject
*self
, void *closure
)
52 objfile_object
*obj
= (objfile_object
*) self
;
55 return PyString_Decode (obj
->objfile
->name
, strlen (obj
->objfile
->name
),
56 host_charset (), NULL
);
61 objfpy_dealloc (PyObject
*o
)
63 objfile_object
*self
= (objfile_object
*) o
;
65 Py_XDECREF (self
->printers
);
66 Py_XDECREF (self
->frame_filters
);
67 Py_XDECREF (self
->type_printers
);
68 Py_TYPE (self
)->tp_free (self
);
72 objfpy_new (PyTypeObject
*type
, PyObject
*args
, PyObject
*keywords
)
74 objfile_object
*self
= (objfile_object
*) type
->tp_alloc (type
, 0);
80 self
->printers
= PyList_New (0);
87 self
->frame_filters
= PyDict_New ();
88 if (!self
->frame_filters
)
94 self
->type_printers
= PyList_New (0);
95 if (!self
->type_printers
)
101 return (PyObject
*) self
;
105 objfpy_get_printers (PyObject
*o
, void *ignore
)
107 objfile_object
*self
= (objfile_object
*) o
;
109 Py_INCREF (self
->printers
);
110 return self
->printers
;
114 objfpy_set_printers (PyObject
*o
, PyObject
*value
, void *ignore
)
117 objfile_object
*self
= (objfile_object
*) o
;
121 PyErr_SetString (PyExc_TypeError
,
122 _("Cannot delete the pretty_printers attribute."));
126 if (! PyList_Check (value
))
128 PyErr_SetString (PyExc_TypeError
,
129 _("The pretty_printers attribute must be a list."));
133 /* Take care in case the LHS and RHS are related somehow. */
134 tmp
= self
->printers
;
136 self
->printers
= value
;
142 /* Return the Python dictionary attribute containing frame filters for
145 objfpy_get_frame_filters (PyObject
*o
, void *ignore
)
147 objfile_object
*self
= (objfile_object
*) o
;
149 Py_INCREF (self
->frame_filters
);
150 return self
->frame_filters
;
153 /* Set this object file's frame filters dictionary to FILTERS. */
155 objfpy_set_frame_filters (PyObject
*o
, PyObject
*filters
, void *ignore
)
158 objfile_object
*self
= (objfile_object
*) o
;
162 PyErr_SetString (PyExc_TypeError
,
163 _("Cannot delete the frame filters attribute."));
167 if (! PyDict_Check (filters
))
169 PyErr_SetString (PyExc_TypeError
,
170 _("The frame_filters attribute must be a dictionary."));
174 /* Take care in case the LHS and RHS are related somehow. */
175 tmp
= self
->frame_filters
;
177 self
->frame_filters
= filters
;
183 /* Get the 'type_printers' attribute. */
186 objfpy_get_type_printers (PyObject
*o
, void *ignore
)
188 objfile_object
*self
= (objfile_object
*) o
;
190 Py_INCREF (self
->type_printers
);
191 return self
->type_printers
;
194 /* Set the 'type_printers' attribute. */
197 objfpy_set_type_printers (PyObject
*o
, PyObject
*value
, void *ignore
)
200 objfile_object
*self
= (objfile_object
*) o
;
204 PyErr_SetString (PyExc_TypeError
,
205 _("Cannot delete the type_printers attribute."));
209 if (! PyList_Check (value
))
211 PyErr_SetString (PyExc_TypeError
,
212 _("The type_printers attribute must be a list."));
216 /* Take care in case the LHS and RHS are related somehow. */
217 tmp
= self
->type_printers
;
219 self
->type_printers
= value
;
225 /* Implementation of gdb.Objfile.is_valid (self) -> Boolean.
226 Returns True if this object file still exists in GDB. */
229 objfpy_is_valid (PyObject
*self
, PyObject
*args
)
231 objfile_object
*obj
= (objfile_object
*) self
;
241 /* Clear the OBJFILE pointer in an Objfile object and remove the
244 py_free_objfile (struct objfile
*objfile
, void *datum
)
246 struct cleanup
*cleanup
;
247 objfile_object
*object
= datum
;
249 cleanup
= ensure_python_env (get_objfile_arch (objfile
), current_language
);
250 object
->objfile
= NULL
;
251 Py_DECREF ((PyObject
*) object
);
252 do_cleanups (cleanup
);
255 /* Return a borrowed reference to the Python object of type Objfile
256 representing OBJFILE. If the object has already been created,
257 return it. Otherwise, create it. Return NULL and set the Python
260 objfile_to_objfile_object (struct objfile
*objfile
)
262 objfile_object
*object
;
264 object
= objfile_data (objfile
, objfpy_objfile_data_key
);
267 object
= PyObject_New (objfile_object
, &objfile_object_type
);
270 object
->objfile
= objfile
;
272 object
->printers
= PyList_New (0);
273 if (!object
->printers
)
279 object
->frame_filters
= PyDict_New ();
280 if (!object
->frame_filters
)
286 object
->type_printers
= PyList_New (0);
287 if (!object
->type_printers
)
293 set_objfile_data (objfile
, objfpy_objfile_data_key
, object
);
297 return (PyObject
*) object
;
301 gdbpy_initialize_objfile (void)
303 objfpy_objfile_data_key
304 = register_objfile_data_with_cleanup (NULL
, py_free_objfile
);
306 if (PyType_Ready (&objfile_object_type
) < 0)
309 Py_INCREF (&objfile_object_type
);
310 PyModule_AddObject (gdb_module
, "Objfile",
311 (PyObject
*) &objfile_object_type
);
316 static PyMethodDef objfile_object_methods
[] =
318 { "is_valid", objfpy_is_valid
, METH_NOARGS
,
319 "is_valid () -> Boolean.\n\
320 Return true if this object file is valid, false if not." },
325 static PyGetSetDef objfile_getset
[] =
327 { "filename", objfpy_get_filename
, NULL
,
328 "The objfile's filename, or None.", NULL
},
329 { "pretty_printers", objfpy_get_printers
, objfpy_set_printers
,
330 "Pretty printers.", NULL
},
331 { "frame_filters", objfpy_get_frame_filters
,
332 objfpy_set_frame_filters
, "Frame Filters.", NULL
},
333 { "type_printers", objfpy_get_type_printers
, objfpy_set_type_printers
,
334 "Type printers.", NULL
},
338 static PyTypeObject objfile_object_type
=
340 PyVarObject_HEAD_INIT (NULL
, 0)
341 "gdb.Objfile", /*tp_name*/
342 sizeof (objfile_object
), /*tp_basicsize*/
344 objfpy_dealloc
, /*tp_dealloc*/
351 0, /*tp_as_sequence*/
359 Py_TPFLAGS_DEFAULT
, /*tp_flags*/
360 "GDB objfile object", /* tp_doc */
363 0, /* tp_richcompare */
364 0, /* tp_weaklistoffset */
367 objfile_object_methods
, /* tp_methods */
369 objfile_getset
, /* tp_getset */
372 0, /* tp_descr_get */
373 0, /* tp_descr_set */
374 0, /* tp_dictoffset */
377 objfpy_new
, /* tp_new */