+2010-08-20 Pedro Alves <pedro@codesourcery.com>
+
+ * python/python.c: Include "serial.h".
+ (gdbpy_event_fds): Change type to `struct serial *' a array from
+ int array.
+ (gdbpy_run_events): Change parameters. Use serial_readchar in
+ place of read.
+ (gdbpy_post_event): Use serial_write in place of write.
+ (gdbpy_initialize_events): Use serial_pipe instead of pipe, and
+ serial_async in place of add_file_handler.
+
2010-08-20 Pedro Alves <pedro@codesourcery.com>
* serial.h (gdb_pipe, serial_pipe): Declare.
#include "language.h"
#include "exceptions.h"
#include "event-loop.h"
+#include "serial.h"
#include <ctype.h>
/* We use a file handler, and not an async handler, so that we can
wake up the main thread even when it is blocked in poll(). */
-static int gdbpy_event_fds[2];
+static struct serial *gdbpy_event_fds[2];
/* The file handler callback. This reads from the internal pipe, and
then processes the Python event queue. This will always be run in
the main gdb thread. */
+
static void
-gdbpy_run_events (int err, gdb_client_data ignore)
+gdbpy_run_events (struct serial *scb, void *context)
{
struct cleanup *cleanup;
- char buffer[100];
int r;
cleanup = ensure_python_env (get_current_arch (), current_language);
- /* Just read whatever is available on the fd. It is relatively
- harmless if there are any bytes left over. */
- r = read (gdbpy_event_fds[0], buffer, sizeof (buffer));
+ /* Flush the fd. Do this before flushing the events list, so that
+ any new event post afterwards is sure to re-awake the event
+ loop. */
+ while (serial_readchar (gdbpy_event_fds[0], 0) >= 0)
+ ;
while (gdbpy_event_list)
{
if (wakeup)
{
char c = 'q'; /* Anything. */
- if (write (gdbpy_event_fds[1], &c, 1) != 1)
+
+ if (serial_write (gdbpy_event_fds[1], &c, 1))
return PyErr_SetFromErrno (PyExc_IOError);
}
static void
gdbpy_initialize_events (void)
{
- if (!pipe (gdbpy_event_fds))
+ if (serial_pipe (gdbpy_event_fds) == 0)
{
gdbpy_event_list_end = &gdbpy_event_list;
- add_file_handler (gdbpy_event_fds[0], gdbpy_run_events, NULL);
+ serial_async (gdbpy_event_fds[0], gdbpy_run_events, NULL);
}
}