From 4a85d321b4516c6a663e8bdd530ba59018c974df Mon Sep 17 00:00:00 2001 From: Anders Carlsson Date: Tue, 21 Jan 2003 09:23:18 +0000 Subject: 2003-01-21 Anders Carlsson * dbus/dbus-connection.c: (dbus_connection_send_message): Add a new client_serial parameter. (dbus_connection_send_message_with_reply): Remove a @todo since we've implemented the blocking function. (dbus_connection_send_message_with_reply_and_block): New function that sends a message and waits for a reply and then returns the reply. * dbus/dbus-connection.h: Add new functions. * dbus/dbus-errors.c: (dbus_result_to_string): * dbus/dbus-errors.h: Add new DBUS_RESULT. * dbus/dbus-message-internal.h: * dbus/dbus-message.c: (_dbus_message_get_reply_serial), (_dbus_message_set_sender), (dbus_message_write_header), (dbus_message_new_reply), (decode_header_data), (_dbus_message_loader_return_buffer), (_dbus_message_test): * dbus/dbus-message.h: Add new functions that set the reply serial and sender. Also marshal and demarshal them correctly and add test. * dbus/dbus-protocol.h: Add new DBUS_MESSAGE_TYPE_SENDER. * glib/dbus-glib.h: * glib/dbus-gmain.c: (watch_callback), (free_callback_data), (add_watch), (remove_watch), (add_timeout), (remove_timeout), (dbus_connection_hookup_with_g_main): * glib/test-dbus-glib.c: (main): Rewrite to use GIOChannel and remove the GSource crack. * test/echo-client.c: (main): * test/watch.c: (check_messages): Update for changed APIs --- glib/test-dbus-glib.c | 48 ++++++++++++------------------------------------ 1 file changed, 12 insertions(+), 36 deletions(-) (limited to 'glib/test-dbus-glib.c') diff --git a/glib/test-dbus-glib.c b/glib/test-dbus-glib.c index cdce2899..ad147e50 100644 --- a/glib/test-dbus-glib.c +++ b/glib/test-dbus-glib.c @@ -1,37 +1,14 @@ #include "dbus-glib.h" #include -GMainLoop *loop; - -static void -message_handler (DBusConnection *connection, - DBusMessage *message, gpointer user_data) -{ - static int count = 0; - DBusMessage *reply; - - reply = dbus_message_new ("org.freedesktop.DBus.Test", "org.freedesktop.DBus.Test"); - dbus_connection_send_message (connection, - reply, - NULL); - dbus_message_unref (reply); - count += 1; - - if (count > 100) - { - printf ("Saw %d messages, exiting\n", count); - g_main_loop_quit (loop); - } -} - int main (int argc, char **argv) { - GSource *source; - DBusConnection *connection; DBusResultCode result; - DBusMessage *message; + DBusMessage *message, *reply; + + GMainLoop *loop; loop = g_main_loop_new (NULL, FALSE); @@ -43,16 +20,15 @@ main (int argc, char **argv) return 1; } - source = dbus_connection_gsource_new (connection); - g_source_attach (source, NULL); - g_source_set_callback (source, (GSourceFunc)message_handler, NULL, NULL); - - message = dbus_message_new ("org.freedesktop.DBus.Test", "org.freedesktop.DBus.Test"); - dbus_connection_send_message (connection, - message, - NULL); - dbus_message_unref (message); - + dbus_connection_hookup_with_g_main (connection); + + message = dbus_message_new ("org.freedesktop.DBus", "org.freedesktop.DBus.Hello"); + dbus_message_append_fields (message, + DBUS_TYPE_STRING, "glib-test", + 0); + + reply = dbus_connection_send_message_with_reply_and_block (connection, message, -1, &result); + g_print ("reply name: %s\n", dbus_message_get_name (reply)); g_main_loop_run (loop); -- cgit