dbus/tools dbus-launch.c,1.5,1.6
Havoc Pennington
hp@pdx.freedesktop.org
Wed, 15 Oct 2003 23:34:53 -0700
- Previous message: dbus/dbus dbus-bus.c,1.25,1.26 dbus-connection.c,1.70,1.71 dbus-internals.c,1.32,1.33 dbus-internals.h,1.37,1.38 dbus-message.c,1.109,1.110 dbus-message.h,1.45,1.46 dbus-pending-call.c,1.3,1.4 dbus-sysdeps.c,1.66,1.67
- Next message: dbus ChangeLog,1.427,1.428
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /cvs/dbus/dbus/tools
In directory pdx:/tmp/cvs-serv10532/tools
Modified Files:
dbus-launch.c
Log Message:
2003-10-16 Havoc Pennington <hp@redhat.com>
* bus/connection.c (bus_pending_reply_expired): either cancel or
execute, not both
(bus_connections_check_reply): use unlink, not remove_link, as we
don't want to free the link; fixes double free mess
* dbus/dbus-pending-call.c (dbus_pending_call_block): fix in case
where no reply was received
* dbus/dbus-connection.c (_dbus_pending_call_complete_and_unlock):
fix a refcount leak
* bus/signals.c (match_rule_matches): add special cases for the
bus driver, so you can match on sender/destination for it.
* dbus/dbus-sysdeps.c (_dbus_abort): print backtrace if
DBUS_PRINT_BACKTRACE is set
* dbus/dbus-internals.c: add pid to assertion failure messages
* dbus/dbus-connection.c: add message type code to the debug spew
* glib/dbus-gproxy.c (gproxy_get_match_rule): match rules want
sender=foo not service=foo
* dbus/dbus-bus.c (dbus_bus_get): if the activation bus is the
session bus but DBUS_SESSION_BUS_ADDRESS isn't set, use
DBUS_ACTIVATION_ADDRESS instead
* bus/activation.c: set DBUS_SESSION_BUS_ADDRESS,
DBUS_SYSTEM_BUS_ADDRESS if appropriate
* bus/bus.c (bus_context_new): handle OOM copying bus type into
context struct
* dbus/dbus-message.c (dbus_message_iter_get_object_path): new function
(dbus_message_iter_get_object_path_array): new function (half
finished, disabled for the moment)
* glib/dbus-gproxy.c (dbus_gproxy_end_call): properly handle
DBUS_MESSAGE_TYPE_ERROR
* tools/dbus-launch.c (babysit): support DBUS_DEBUG_OUTPUT to
avoid redirecting stderr to /dev/null
(babysit): close stdin if not doing the "exit_with_session" thing
* dbus/dbus-sysdeps.c (_dbus_become_daemon): delete some leftover
debug code; change DBUS_DEBUG_OUTPUT to only enable stderr, not
stdout/stdin, so things don't get confused
* bus/system.conf.in: fix to allow replies, I modified .conf
instead of .conf.in again.
Index: dbus-launch.c
===================================================================
RCS file: /cvs/dbus/dbus/tools/dbus-launch.c,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -d -r1.5 -r1.6
--- dbus-launch.c 12 Oct 2003 05:59:39 -0000 1.5
+++ dbus-launch.c 16 Oct 2003 06:34:51 -0000 1.6
@@ -239,7 +239,8 @@
goto again;
else
{
- fprintf (stderr, "Failed to write data to pipe!\n");
+ fprintf (stderr, "Failed to write data to pipe! %s\n",
+ strerror (errno));
exit (1); /* give up, we suck */
}
}
@@ -461,6 +462,10 @@
long val;
char *end;
int dev_null_fd;
+ const char *s;
+
+ verbose ("babysitting, exit_with_session = %d, child_pid = %ld, read_bus_pid_fd = %d, write_bus_pid_fd = %d\n",
+ exit_with_session, (long) child_pid, read_bus_pid_fd, write_bus_pid_fd);
/* We chdir ("/") since we are persistent and daemon-like, and fork
* again so dbus-launch can reap the parent. However, we don't
@@ -476,14 +481,19 @@
exit (1);
}
- /* Move stdout/stderr so we don't block an "eval" or otherwise
- * lock up.
+ /* Close stdout/stderr so we don't block an "eval" or otherwise
+ * lock up. stdout is still chaining through to dbus-launch
+ * and in turn to the parent shell.
*/
dev_null_fd = open ("/dev/null", O_RDWR);
if (dev_null_fd >= 0)
{
+ if (!exit_with_session)
+ dup2 (dev_null_fd, 0);
dup2 (dev_null_fd, 1);
- dup2 (dev_null_fd, 2);
+ s = getenv ("DBUS_DEBUG_OUTPUT");
+ if (s == NULL || *s == '\0')
+ dup2 (dev_null_fd, 2);
}
else
{
@@ -888,6 +898,11 @@
}
verbose ("dbus-launch exiting\n");
+
+ fflush (stdout);
+ fflush (stderr);
+ close (1);
+ close (2);
exit (0);
}
- Previous message: dbus/dbus dbus-bus.c,1.25,1.26 dbus-connection.c,1.70,1.71 dbus-internals.c,1.32,1.33 dbus-internals.h,1.37,1.38 dbus-message.c,1.109,1.110 dbus-message.h,1.45,1.46 dbus-pending-call.c,1.3,1.4 dbus-sysdeps.c,1.66,1.67
- Next message: dbus ChangeLog,1.427,1.428
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]