718691432855bb62ba408823d4953d2a9bdb4397
1 /* General python/gdb code
3 Copyright (C) 2008 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/>. */
23 #include "cli/cli-script.h"
28 /* True if we should print the stack when catching a Python error,
30 static int gdbpy_should_print_stack
= 1;
35 #include "libiberty.h"
36 #include "cli/cli-decode.h"
39 #include "exceptions.h"
40 #include "python-internal.h"
43 #include "gdbthread.h"
48 static PyObject
*get_parameter (PyObject
*, PyObject
*);
49 static PyObject
*execute_gdb_command (PyObject
*, PyObject
*);
50 static PyObject
*gdbpy_write (PyObject
*, PyObject
*);
51 static PyObject
*gdbpy_flush (PyObject
*, PyObject
*);
53 static PyMethodDef GdbMethods
[] =
55 { "execute", execute_gdb_command
, METH_VARARGS
,
56 "Execute a gdb command" },
57 { "get_parameter", get_parameter
, METH_VARARGS
,
58 "Return a gdb parameter's value" },
60 { "write", gdbpy_write
, METH_VARARGS
,
61 "Write a string using gdb's filtered stream." },
62 { "flush", gdbpy_flush
, METH_NOARGS
,
63 "Flush gdb's filtered stdout stream." },
68 /* Given a command_line, return a command string suitable for passing
69 to Python. Lines in the string are separated by newlines. The
70 return value is allocated using xmalloc and the caller is
71 responsible for freeing it. */
74 compute_python_string (struct command_line
*l
)
76 struct command_line
*iter
;
81 for (iter
= l
; iter
; iter
= iter
->next
)
82 size
+= strlen (iter
->line
) + 1;
84 script
= xmalloc (size
+ 1);
86 for (iter
= l
; iter
; iter
= iter
->next
)
88 int len
= strlen (iter
->line
);
89 strcpy (&script
[here
], iter
->line
);
91 script
[here
++] = '\n';
97 /* Take a command line structure representing a 'python' command, and
98 evaluate its body using the Python interpreter. */
101 eval_python_from_control_command (struct command_line
*cmd
)
105 if (cmd
->body_count
!= 1)
106 error (_("Invalid \"python\" block structure."));
108 script
= compute_python_string (cmd
->body_list
[0]);
109 PyRun_SimpleString (script
);
111 if (PyErr_Occurred ())
113 gdbpy_print_stack ();
114 error (_("error while executing Python code"));
118 /* Implementation of the gdb "python" command. */
121 python_command (char *arg
, int from_tty
)
123 while (arg
&& *arg
&& isspace (*arg
))
127 PyRun_SimpleString (arg
);
128 if (PyErr_Occurred ())
130 gdbpy_print_stack ();
131 error (_("error while executing Python code"));
136 struct command_line
*l
= get_command_line (python_control
, "");
137 struct cleanup
*cleanups
= make_cleanup_free_command_lines (&l
);
138 execute_control_command_untraced (l
);
139 do_cleanups (cleanups
);
145 /* Transform a gdb parameters's value into a Python value. May return
146 NULL (and set a Python exception) on error. Helper function for
150 parameter_to_python (struct cmd_list_element
*cmd
)
152 switch (cmd
->var_type
)
155 case var_string_noescape
:
156 case var_optional_filename
:
160 char *str
= * (char **) cmd
->var
;
163 return PyString_Decode (str
, strlen (str
), host_charset (), NULL
);
168 if (* (int *) cmd
->var
)
174 case var_auto_boolean
:
176 enum auto_boolean ab
= * (enum auto_boolean
*) cmd
->var
;
177 if (ab
== AUTO_BOOLEAN_TRUE
)
179 else if (ab
== AUTO_BOOLEAN_FALSE
)
186 if ((* (int *) cmd
->var
) == INT_MAX
)
190 return PyLong_FromLong (* (int *) cmd
->var
);
194 unsigned int val
= * (unsigned int *) cmd
->var
;
197 return PyLong_FromUnsignedLong (val
);
201 return PyErr_Format (PyExc_RuntimeError
, "programmer error: unhandled type");
204 /* A Python function which returns a gdb parameter's value as a Python
208 get_parameter (PyObject
*self
, PyObject
*args
)
210 struct cmd_list_element
*alias
, *prefix
, *cmd
;
212 volatile struct gdb_exception except
;
214 if (! PyArg_ParseTuple (args
, "s", &arg
))
217 newarg
= concat ("show ", arg
, (char *) NULL
);
219 TRY_CATCH (except
, RETURN_MASK_ALL
)
221 if (! lookup_cmd_composition (newarg
, &alias
, &prefix
, &cmd
))
224 return PyErr_Format (PyExc_RuntimeError
,
225 "could not find variable `%s'", arg
);
229 GDB_PY_HANDLE_EXCEPTION (except
);
232 return PyErr_Format (PyExc_RuntimeError
, "`%s' is not a variable", arg
);
233 return parameter_to_python (cmd
);
236 /* A Python function which evaluates a string using the gdb CLI. */
239 execute_gdb_command (PyObject
*self
, PyObject
*args
)
241 struct cmd_list_element
*alias
, *prefix
, *cmd
;
243 volatile struct gdb_exception except
;
244 struct cleanup
*old_chain
;
246 if (! PyArg_ParseTuple (args
, "s", &arg
))
249 old_chain
= make_cleanup (null_cleanup
, 0);
251 TRY_CATCH (except
, RETURN_MASK_ALL
)
253 execute_command (arg
, 0);
255 GDB_PY_HANDLE_EXCEPTION (except
);
257 /* Do any commands attached to breakpoint we stopped at. Only if we
258 are always running synchronously. Or if we have just executed a
259 command that doesn't start the target. */
260 if (!target_can_async_p () || !is_running (inferior_ptid
))
262 bpstat_do_actions (&stop_bpstat
);
263 do_cleanups (old_chain
);
273 /* A python function to write a single string using gdb's filtered
276 gdbpy_write (PyObject
*self
, PyObject
*args
)
279 if (! PyArg_ParseTuple (args
, "s", &arg
))
281 printf_filtered ("%s", arg
);
285 /* A python function to flush gdb's filtered output stream. */
287 gdbpy_flush (PyObject
*self
, PyObject
*args
)
289 gdb_flush (gdb_stdout
);
293 /* Print a python exception trace, or print nothing and clear the
294 python exception, depending on gdbpy_should_print_stack. Only call
295 this if a python exception is set. */
297 gdbpy_print_stack (void)
299 if (gdbpy_should_print_stack
)
305 #else /* HAVE_PYTHON */
307 /* Dummy implementation of the gdb "python" command. */
310 python_command (char *arg
, int from_tty
)
312 while (arg
&& *arg
&& isspace (*arg
))
315 error (_("Python scripting is not supported in this copy of GDB."));
318 struct command_line
*l
= get_command_line (python_control
, "");
319 struct cleanup
*cleanups
= make_cleanup_free_command_lines (&l
);
320 execute_control_command_untraced (l
);
321 do_cleanups (cleanups
);
326 eval_python_from_control_command (struct command_line
*cmd
)
328 error (_("Python scripting is not supported in this copy of GDB."));
331 #endif /* HAVE_PYTHON */
335 /* Lists for 'maint set python' commands. */
337 static struct cmd_list_element
*set_python_list
;
338 static struct cmd_list_element
*show_python_list
;
340 /* Function for use by 'maint set python' prefix command. */
343 set_python (char *args
, int from_tty
)
345 help_list (set_python_list
, "maintenance set python ", -1, gdb_stdout
);
348 /* Function for use by 'maint show python' prefix command. */
351 show_python (char *args
, int from_tty
)
353 cmd_show_list (show_python_list
, from_tty
, "");
356 /* Initialize the Python code. */
359 _initialize_python (void)
361 add_com ("python", class_obscure
, python_command
,
364 Evaluate a Python command.\n\
366 The command can be given as an argument, for instance:\n\
370 If no argument is given, the following lines are read and used\n\
371 as the Python commands. Type a line containing \"end\" to indicate\n\
372 the end of the command.")
373 #else /* HAVE_PYTHON */
375 Evaluate a Python command.\n\
377 Python scripting is not supported in this copy of GDB.\n\
378 This command is only a placeholder.")
379 #endif /* HAVE_PYTHON */
382 add_prefix_cmd ("python", no_class
, show_python
,
383 _("Prefix command for python maintenance settings."),
384 &show_python_list
, "maintenance show python ", 0,
385 &maintenance_show_cmdlist
);
386 add_prefix_cmd ("python", no_class
, set_python
,
387 _("Prefix command for python maintenance settings."),
388 &set_python_list
, "maintenance set python ", 0,
389 &maintenance_set_cmdlist
);
391 add_setshow_boolean_cmd ("print-stack", class_maintenance
,
392 &gdbpy_should_print_stack
, _("\
393 Enable or disable printing of Python stack dump on error."), _("\
394 Show whether Python stack will be printed on error."), _("\
395 Enables or disables printing of Python stack traces."),
403 gdb_module
= Py_InitModule ("gdb", GdbMethods
);
405 /* The casts to (char*) are for python 2.4. */
406 PyModule_AddStringConstant (gdb_module
, "VERSION", (char*) version
);
407 PyModule_AddStringConstant (gdb_module
, "HOST_CONFIG", (char*) host_name
);
408 PyModule_AddStringConstant (gdb_module
, "TARGET_CONFIG", (char*) target_name
);
410 PyRun_SimpleString ("import gdb");
412 /* Create a couple objects which are used for Python's stdout and
414 PyRun_SimpleString ("\
416 class GdbOutputFile:\n\
424 def write(self, s):\n\
427 def writelines(self, iterable):\n\
428 for line in iterable:\n\
434 sys.stderr = GdbOutputFile()\n\
435 sys.stdout = GdbOutputFile()\n\
437 #endif /* HAVE_PYTHON */
This page took 0.039614 seconds and 3 git commands to generate.