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 | 5aff811336360ed88000ed0827c8d6bda8f07cf4 (patch) | |
tree | cf1dfe81b6bfb3ebab9d8176141d245be861d993 /bus | |
parent | 6e8be8f6b21ddf1f304a7d0c5d28aacd88041f10 (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.
Diffstat (limited to 'bus')
-rw-r--r-- | bus/.cvsignore | 3 | ||||
-rw-r--r-- | bus/Makefile.am | 15 | ||||
-rw-r--r-- | bus/print-introspect.c | 104 | ||||
-rwxr-xr-x | bus/run-with-tmp-session-bus.sh | 65 |
4 files changed, 2 insertions, 185 deletions
diff --git a/bus/.cvsignore b/bus/.cvsignore index 2c6c9b7..e522ea2 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 a1fb76a..5677065 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/bus/print-introspect.c b/bus/print-introspect.c deleted file mode 100644 index c040af4..0000000 --- a/bus/print-introspect.c +++ /dev/null @@ -1,104 +0,0 @@ -/* -*- mode: C; c-file-style: "gnu" -*- */ -/* gather-introspect.c Dump introspection data from service to stdout - * - * Copyright (C) 2005 Red Hat, Inc. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - * - */ - -#include <stdio.h> -#include <stdlib.h> -#include <string.h> - -#include <dbus/dbus.h> - -static void -usage (char *name, int ecode) -{ - fprintf (stderr, "Usage: %s <service> <destination object path>\n", name); - exit (ecode); -} - -int -main (int argc, char *argv[]) -{ - DBusConnection *connection; - DBusError error; - DBusMessage *message; - DBusMessage *reply; - const char *service; - const char *path; - const char *introspect_data; - - if (argc != 3) - usage (argv[0], 1); - - service = argv[1]; - path = argv[2]; - - dbus_error_init (&error); - connection = dbus_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); - exit (1); - } - - if (!dbus_message_get_args (reply, &error, - DBUS_TYPE_STRING, - &introspect_data, - DBUS_TYPE_INVALID)) - { - fprintf (stderr, "Error: %s\n", error.message); - exit (1); - } - printf ("%s", introspect_data); - - dbus_message_unref (reply); - - dbus_connection_disconnect (connection); - - exit (0); -} diff --git a/bus/run-with-tmp-session-bus.sh b/bus/run-with-tmp-session-bus.sh deleted file mode 100755 index ce077d7..0000000 --- a/bus/run-with-tmp-session-bus.sh +++ /dev/null @@ -1,65 +0,0 @@ -#! /bin/bash - -SCRIPTNAME=$0 -WRAPPED_SCRIPT=$1 -shift - -function die() -{ - if ! test -z "$DBUS_SESSION_BUS_PID" ; then - echo "killing message bus "$DBUS_SESSION_BUS_PID >&2 - kill -9 $DBUS_SESSION_BUS_PID - fi - echo $SCRIPTNAME: $* >&2 - exit 1 -} - -if test -z "$DBUS_TOP_BUILDDIR" ; then - die "Must set DBUS_TOP_BUILDDIR" -fi - -## convenient to be able to ctrl+C without leaking the message bus process -trap 'die "Received SIGINT"' SIGINT - -CONFIG_FILE=./run-with-tmp-session-bus.conf -SERVICE_DIR="$DBUS_TOP_BUILDDIR/test/data/valid-service-files" -ESCAPED_SERVICE_DIR=`echo $SERVICE_DIR | sed -e 's/\//\\\\\\//g'` -echo "escaped service dir is: $ESCAPED_SERVICE_DIR" >&2 - -## create a configuration file based on the standard session.conf -cat $DBUS_TOP_BUILDDIR/bus/session.conf | \ - sed -e 's/<servicedir>.*$/<servicedir>'$ESCAPED_SERVICE_DIR'<\/servicedir>/g' | \ - sed -e 's/<include.*$//g' \ - > $CONFIG_FILE - -echo "Created configuration file $CONFIG_FILE" >&2 - -export PATH=$DBUS_TOP_BUILDDIR/bus:$PATH -## the libtool script found by the path search should already do this, but -export LD_LIBRARY_PATH=$DBUS_TOP_BUILDDIR/dbus/.libs:$LD_LIBRARY_PATH - -unset DBUS_SESSION_BUS_ADDRESS -unset DBUS_SESSION_BUS_PID - -echo "Running $DBUS_TOP_BUILDDIR/tools/dbus-launch --sh-syntax --config-file=$CONFIG_FILE" >&2 - -eval `$DBUS_TOP_BUILDDIR/tools/dbus-launch --sh-syntax --config-file=$CONFIG_FILE` - -if test -z "$DBUS_SESSION_BUS_PID" ; then - die "Failed to launch message bus for introspection generation to run" -fi - -echo "Started bus pid $DBUS_SESSION_BUS_PID at $DBUS_SESSION_BUS_ADDRESS" >&2 - -# Execute wrapped script -echo "Running $WRAPPED_SCRIPT $@" >&2 -$WRAPPED_SCRIPT "$@" || die "script \"$WRAPPED_SCRIPT\" failed" - -kill -TERM $DBUS_SESSION_BUS_PID || die "Message bus vanished! should not have happened" && echo "Killed daemon $DBUS_SESSION_BUS_PID" >&2 - -sleep 2 - -## be sure it really died -kill -9 $DBUS_SESSION_BUS_PID > /dev/null 2>&1 || true - -exit 0 |