PR14291: KeyboardInterrupt not caught for Python output
This commit is contained in:
parent
944a90619c
commit
adb4fe3b30
2 changed files with 23 additions and 13 deletions
|
@ -1,3 +1,8 @@
|
|||
2012-06-25 Michael Eager <eager@eagercon.com>
|
||||
|
||||
PR python/14291
|
||||
* python/python.c (gdbpy_write): Check for interrupted output.
|
||||
|
||||
2012-06-25 Greta Yorsh <greta.yorsh@arm.com>
|
||||
|
||||
* arm-tdep.c (arm_in_function_epilogue_p): Recognize POP with a single
|
||||
|
|
|
@ -862,26 +862,31 @@ gdbpy_write (PyObject *self, PyObject *args, PyObject *kw)
|
|||
const char *arg;
|
||||
static char *keywords[] = {"text", "stream", NULL };
|
||||
int stream_type = 0;
|
||||
volatile struct gdb_exception except;
|
||||
|
||||
if (! PyArg_ParseTupleAndKeywords (args, kw, "s|i", keywords, &arg,
|
||||
&stream_type))
|
||||
return NULL;
|
||||
|
||||
switch (stream_type)
|
||||
TRY_CATCH (except, RETURN_MASK_ALL)
|
||||
{
|
||||
case 1:
|
||||
{
|
||||
fprintf_filtered (gdb_stderr, "%s", arg);
|
||||
break;
|
||||
}
|
||||
case 2:
|
||||
{
|
||||
fprintf_filtered (gdb_stdlog, "%s", arg);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
fprintf_filtered (gdb_stdout, "%s", arg);
|
||||
switch (stream_type)
|
||||
{
|
||||
case 1:
|
||||
{
|
||||
fprintf_filtered (gdb_stderr, "%s", arg);
|
||||
break;
|
||||
}
|
||||
case 2:
|
||||
{
|
||||
fprintf_filtered (gdb_stdlog, "%s", arg);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
fprintf_filtered (gdb_stdout, "%s", arg);
|
||||
}
|
||||
}
|
||||
GDB_PY_HANDLE_EXCEPTION (except);
|
||||
|
||||
Py_RETURN_NONE;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue