diff options
author | Colin Walters <walters@verbum.org> | 2005-03-17 17:48:29 +0000 |
---|---|---|
committer | Colin Walters <walters@verbum.org> | 2005-03-17 17:48:29 +0000 |
commit | a65587676f6791ff6a7c9ed98bbc53d740f51fa8 (patch) | |
tree | 1e5fb5030cf55dc63dc388e6da4a7918dfa9251f | |
parent | 6180ae6941aea083f5b8f3c4d3f16c928935bcaf (diff) |
2005-03-17 Colin Walters <walters@verbum.org>
* bus/print-introspect.c: Move to tools/.
* bus/run-with-tmp-session-bus.sh: Ditto.
* glib/Makefile.am (dbus-glib-bindings.h): Move
generation to tools/Makefile.am.
* test/glib/run-test.sh: Update to handle move
of run-with-tmp-session-bus.sh.
* test/glib/test-service-glib.c: Update to handle
move of dbus-glib-bindings.h.
* tools/print-introspect.c: Moved here
from bus/, and ported to GLib bindings.
* tools/run-with-tmp-session-bus.sh: Moved here
from bus/.
* tools/Makefile.am: Generate dbus-glib-bindings.h
and dbus-bus-introspect.xml here.
* tools/.cvsignore, glib/.cvsignore, bus/.cvsignore:
Update.
-rw-r--r-- | ChangeLog | 26 | ||||
-rw-r--r-- | bus/.cvsignore | 3 | ||||
-rw-r--r-- | bus/Makefile.am | 15 | ||||
-rw-r--r-- | glib/.cvsignore | 1 | ||||
-rw-r--r-- | glib/Makefile.am | 8 | ||||
-rwxr-xr-x | test/glib/run-test.sh | 2 | ||||
-rw-r--r-- | test/glib/test-service-glib.c | 2 | ||||
-rw-r--r-- | tools/.cvsignore | 4 | ||||
-rw-r--r-- | tools/Makefile.am | 21 | ||||
-rw-r--r-- | tools/print-introspect.c (renamed from bus/print-introspect.c) | 67 | ||||
-rwxr-xr-x | tools/run-with-tmp-session-bus.sh (renamed from bus/run-with-tmp-session-bus.sh) | 0 |
11 files changed, 77 insertions, 72 deletions
@@ -1,3 +1,29 @@ +2005-03-17 Colin Walters <walters@verbum.org> + + * bus/print-introspect.c: Move to tools/. + * bus/run-with-tmp-session-bus.sh: Ditto. + + * glib/Makefile.am (dbus-glib-bindings.h): Move + generation to tools/Makefile.am. + + * test/glib/run-test.sh: Update to handle move + of run-with-tmp-session-bus.sh. + + * test/glib/test-service-glib.c: Update to handle + move of dbus-glib-bindings.h. + + * tools/print-introspect.c: Moved here + from bus/, and ported to GLib bindings. + + * tools/run-with-tmp-session-bus.sh: Moved here + from bus/. + + * tools/Makefile.am: Generate dbus-glib-bindings.h + and dbus-bus-introspect.xml here. + + * tools/.cvsignore, glib/.cvsignore, bus/.cvsignore: + Update. + 2005-03-14 Colin Walters <walters@verbum.org> * bus/driver.c (write_args_for_direction): Use diff --git a/bus/.cvsignore b/bus/.cvsignore index 2c6c9b7e..e522ea23 100644 --- a/bus/.cvsignore +++ b/bus/.cvsignore @@ -14,7 +14,4 @@ rc.messagebus messagebus session.conf system.conf -run-with-tmp-session-bus.conf dbus-daemon.1 -print-introspect -dbus-bus-introspect.xml diff --git a/bus/Makefile.am b/bus/Makefile.am index a1fb76a0..56770656 100644 --- a/bus/Makefile.am +++ b/bus/Makefile.am @@ -77,7 +77,7 @@ endif ## we use noinst_PROGRAMS not check_PROGRAMS so that we build ## even when not doing "make check" -noinst_PROGRAMS=$(TESTS) print-introspect +noinst_PROGRAMS=$(TESTS) bus_test_SOURCES= \ $(BUS_SOURCES) \ @@ -85,20 +85,9 @@ bus_test_SOURCES= \ bus_test_LDADD=$(top_builddir)/dbus/libdbus-convenience.la $(DBUS_BUS_LIBS) -print_introspect_SOURCES = print-introspect.c -print_introspect_LDADD = $(top_builddir)/dbus/libdbus-convenience.la $(DBUS_BUS_LIBS) - -run-with-tmp-session-bus.sh: dbus-daemon - -all-local: dbus-bus-introspect.xml - -dbus-bus-introspect.xml: $(srcdir)/run-with-tmp-session-bus.sh dbus-daemon - DBUS_TOP_BUILDDIR=$(top_builddir) $(srcdir)/run-with-tmp-session-bus.sh ./print-introspect org.freedesktop.DBus /org/freedesktop/DBus > dbus-bus-introspect.xml.tmp && mv dbus-bus-introspect.xml.tmp dbus-bus-introspect.xml - ## mop up the gcov files clean-local: /bin/rm *.bb *.bbg *.da *.gcov || true - /bin/rm -f run-with-tmp-session-bus.conf install-data-hook: $(mkinstalldirs) $(DESTDIR)/$(localstatedir)/run/dbus @@ -136,4 +125,4 @@ man_MANS = dbus-daemon.1 #### Extra dist -EXTRA_DIST=$(CONFIG_IN_FILES) $(SCRIPT_IN_FILES) $(man_MANS) $(MAN_IN_FILES) run-with-tmp-session-bus.sh +EXTRA_DIST=$(CONFIG_IN_FILES) $(SCRIPT_IN_FILES) $(man_MANS) $(MAN_IN_FILES) diff --git a/glib/.cvsignore b/glib/.cvsignore index e1a6372c..4e197a9f 100644 --- a/glib/.cvsignore +++ b/glib/.cvsignore @@ -6,7 +6,6 @@ Makefile.in *.la dbus-glib-test dbus-binding-tool -dbus-glib-bindings.h *.bb *.bbg *.da diff --git a/glib/Makefile.am b/glib/Makefile.am index b4256fac..6d81e7d1 100644 --- a/glib/Makefile.am +++ b/glib/Makefile.am @@ -2,9 +2,6 @@ INCLUDES=-I$(top_srcdir) $(DBUS_CLIENT_CFLAGS) $(DBUS_GLIB_CFLAGS) $(DBUS_GLIB_T lib_LTLIBRARIES=libdbus-glib-1.la -libdbus_glib_HEADERS = dbus-glib-bindings.h -libdbus_glibdir = $(includedir)/dbus-1.0/dbus - libdbus_glib_1_la_SOURCES = \ dbus-glib.c \ dbus-gmain.c \ @@ -50,11 +47,6 @@ dbus_binding_tool_SOURCES = \ dbus_binding_tool_LDADD= -lexpat libdbus-gtool.la -dbus-glib-bindings.h: $(top_builddir)/bus/dbus-bus-introspect.xml dbus-binding-tool - ./dbus-binding-tool --ignore-unsupported --mode=glib-client --output=dbus-glib-bindings.h $(top_builddir)/bus/dbus-bus-introspect.xml # FIXME - remove --ignore-unsupported when we can do arrays - -BUILT_SOURCES = dbus-glib-bindings.h - ## we just rebuilt these manually and check them into cvs; easier than ## convincing automake/make to do this properly regenerate-built-sources: diff --git a/test/glib/run-test.sh b/test/glib/run-test.sh index 51d4a713..86f1aee8 100755 --- a/test/glib/run-test.sh +++ b/test/glib/run-test.sh @@ -10,7 +10,7 @@ export DBUS_TEST_GLIB_RUN_TEST_SCRIPT=1 if test -z "$DBUS_TEST_GLIB_IN_RUN_TEST"; then DBUS_TEST_GLIB_IN_RUN_TEST=1 export DBUS_TEST_GLIB_IN_RUN_TEST - exec $DBUS_TOP_BUILDDIR/bus/run-with-tmp-session-bus.sh $SCRIPTNAME $MODE + exec $DBUS_TOP_BUILDDIR/tools/run-with-tmp-session-bus.sh $SCRIPTNAME $MODE fi if test x$MODE = xprofile ; then diff --git a/test/glib/test-service-glib.c b/test/glib/test-service-glib.c index fef8a9da..d929999d 100644 --- a/test/glib/test-service-glib.c +++ b/test/glib/test-service-glib.c @@ -3,7 +3,7 @@ /* NOTE - outside of D-BUS core this would be * include <dbus/dbus-glib-bindings.h> */ -#include "glib/dbus-glib-bindings.h" +#include "tools/dbus-glib-bindings.h" #include <stdio.h> #include <stdlib.h> #include <string.h> diff --git a/tools/.cvsignore b/tools/.cvsignore index c9dffa00..ae3996bd 100644 --- a/tools/.cvsignore +++ b/tools/.cvsignore @@ -13,3 +13,7 @@ dbus-launch *.gcov *.da dbus-viewer +dbus-glib-bindings.h +run-with-tmp-session-bus.conf +print-introspect +dbus-bus-introspect.xml diff --git a/tools/Makefile.am b/tools/Makefile.am index 7cc6cadf..aeb6d6ce 100644 --- a/tools/Makefile.am +++ b/tools/Makefile.am @@ -2,6 +2,15 @@ INCLUDES=-I$(top_srcdir) $(DBUS_CLIENT_CFLAGS) $(DBUS_GLIB_CFLAGS) $(DBUS_X_CFLA if HAVE_GLIB GLIB_TOOLS=dbus-monitor + +libdbus_glib_HEADERS = dbus-glib-bindings.h +libdbus_glibdir = $(includedir)/dbus-1.0/dbus + +dbus-glib-bindings.h: dbus-bus-introspect.xml $(top_builddir)/glib/dbus-binding-tool + $(top_builddir)/glib/dbus-binding-tool --ignore-unsupported --mode=glib-client --output=dbus-glib-bindings.h dbus-bus-introspect.xml # FIXME - remove --ignore-unsupported when we can do arrays + +BUILT_SOURCES = dbus-glib-bindings.h + else GLIB_TOOLS= endif @@ -12,6 +21,16 @@ else GTK_TOOLS= endif +noinst_PROGRAMS = print-introspect + +print_introspect_SOURCES = print-introspect.c +print_introspect_LDADD = $(top_builddir)/glib/libdbus-glib-1.la + +run-with-tmp-session-bus.sh: $(top_builddir)/bus/dbus-daemon dbus-launch + +dbus-bus-introspect.xml: $(srcdir)/run-with-tmp-session-bus.sh print-introspect $(top_builddir)/bus/dbus-daemon + DBUS_TOP_BUILDDIR=$(top_builddir) $(srcdir)/run-with-tmp-session-bus.sh ./print-introspect org.freedesktop.DBus /org/freedesktop/DBus > dbus-bus-introspect.xml.tmp && mv dbus-bus-introspect.xml.tmp dbus-bus-introspect.xml + bin_PROGRAMS=dbus-send $(GLIB_TOOLS) dbus-launch dbus-cleanup-sockets $(GTK_TOOLS) dbus_send_SOURCES= \ @@ -43,6 +62,6 @@ dbus_launch_LDADD= $(DBUS_X_LIBS) dbus_viewer_LDADD= $(DBUS_GLIB_TOOL_LIBS) $(top_builddir)/glib/libdbus-gtool.la $(DBUS_GTK_THREADS_LIBS) man_MANS = dbus-send.1 dbus-monitor.1 dbus-launch.1 dbus-cleanup-sockets.1 -EXTRA_DIST = $(man_MANS) +EXTRA_DIST = $(man_MANS) run-with-tmp-session-bus.sh diff --git a/bus/print-introspect.c b/tools/print-introspect.c index c040af41..9784af00 100644 --- a/bus/print-introspect.c +++ b/tools/print-introspect.c @@ -23,7 +23,7 @@ #include <stdlib.h> #include <string.h> -#include <dbus/dbus.h> +#include <dbus/dbus-glib.h> static void usage (char *name, int ecode) @@ -35,10 +35,10 @@ usage (char *name, int ecode) int main (int argc, char *argv[]) { - DBusConnection *connection; - DBusError error; - DBusMessage *message; - DBusMessage *reply; + DBusGConnection *connection; + DBusGProxy *proxy; + DBusGPendingCall *call; + GError *error; const char *service; const char *path; const char *introspect_data; @@ -49,56 +49,35 @@ main (int argc, char *argv[]) service = argv[1]; path = argv[2]; - dbus_error_init (&error); - connection = dbus_bus_get (DBUS_BUS_SESSION, &error); + g_type_init (); + + error = NULL; + connection = dbus_g_bus_get (DBUS_BUS_SESSION, &error); if (connection == NULL) { fprintf (stderr, "Failed to open connection to session bus: %s\n", - error.message); - dbus_error_free (&error); - exit (1); - } - - message = dbus_message_new_method_call (NULL, - path, - DBUS_INTERFACE_INTROSPECTABLE, - "Introspect"); - if (message == NULL) - { - fprintf (stderr, "Couldn't allocate D-BUS message\n"); - exit (1); - } - - if (!dbus_message_set_destination (message, service)) - { - fprintf (stderr, "Not enough memory\n"); - exit (1); - } - - reply = dbus_connection_send_with_reply_and_block (connection, - message, - -1, - &error); - dbus_message_unref (message); - if (dbus_error_is_set (&error)) - { - fprintf (stderr, "Error: %s\n", error.message); + error->message); + g_clear_error (&error); exit (1); } - if (!dbus_message_get_args (reply, &error, - DBUS_TYPE_STRING, - &introspect_data, - DBUS_TYPE_INVALID)) + proxy = dbus_g_proxy_new_for_name (connection, + service, path, + DBUS_INTERFACE_INTROSPECTABLE); + call = dbus_g_proxy_begin_call (proxy, "Introspect", DBUS_TYPE_INVALID); + if (!dbus_g_proxy_end_call (proxy, call, &error, DBUS_TYPE_STRING, + &introspect_data, DBUS_TYPE_INVALID)) { - fprintf (stderr, "Error: %s\n", error.message); + fprintf (stderr, "Failed to get introspection data: %s\n", + error->message); + g_clear_error (&error); exit (1); } + printf ("%s", introspect_data); - dbus_message_unref (reply); - - dbus_connection_disconnect (connection); + dbus_g_pending_call_unref (call); + g_object_unref (proxy); exit (0); } diff --git a/bus/run-with-tmp-session-bus.sh b/tools/run-with-tmp-session-bus.sh index ce077d72..ce077d72 100755 --- a/bus/run-with-tmp-session-bus.sh +++ b/tools/run-with-tmp-session-bus.sh |