From: Michael Albinus Date: Sat, 15 Aug 2009 18:27:58 +0000 (+0000) Subject: * dbusbind.c (xd_get_dispatch_status, xd_pending_messages): New functions. X-Git-Tag: emacs-pretest-23.1.90~1846 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=f573d5886c10d1312e77c6d7e8bee35b15840d85;p=emacs.git * dbusbind.c (xd_get_dispatch_status, xd_pending_messages): New functions. --- diff --git a/src/dbusbind.c b/src/dbusbind.c index 8100c754399..aa4efa7ca33 100644 --- a/src/dbusbind.c +++ b/src/dbusbind.c @@ -1414,6 +1414,41 @@ usage: (dbus-send-signal BUS SERVICE PATH INTERFACE SIGNAL &rest ARGS) */) return Qt; } +/* Check, whether there is pending input in the message queue of the + D-Bus BUS. BUS is a Lisp symbol, either :system or :session. */ +int +xd_get_dispatch_status (bus) + Lisp_Object bus; +{ + DBusConnection *connection; + + /* Open a connection to the bus. */ + connection = xd_initialize (bus); + + /* Non blocking read of the next available message. */ + dbus_connection_read_write (connection, 0); + + /* Return. */ + return + (dbus_connection_get_dispatch_status (connection) + == DBUS_DISPATCH_DATA_REMAINS) + ? TRUE : FALSE; +} + +/* Check for queued incoming messages from the system and session buses. */ +int +xd_pending_messages () +{ + + /* Vdbus_registered_functions_table will be initialized as hash + table in dbus.el. When this package isn't loaded yet, it doesn't + make sense to handle D-Bus messages. */ + return (HASH_TABLE_P (Vdbus_registered_functions_table) + ? ((xd_get_dispatch_status (QCdbus_system_bus) + || (xd_get_dispatch_status (QCdbus_session_bus)))) + : FALSE); +} + /* Read queued incoming message of the D-Bus BUS. BUS is a Lisp symbol, either :system or :session. */ static Lisp_Object