Only respawn if gnome-shell exits abnormally

If Mutter exits with an exit status of 0, then that most likely
means that it was replaced by another window manager and we shoudln't
try to start the previous window manager and the panel.

(We don't actually know about the panel, but assume that if someone
is replacing us they know what they are doing.)

When Mutter exits with a signal, we know we want to restart.

When Mutter exits with a non-signal non-zero exit status, it's
ambiguous - we could be exiting because we lost the connection to
the X server, or because of a assertion failure in gnome-shell.
We assume the latter; if the X server is gone, all that will happen
is a bit of noise.

To know why Mutter exited accurately, we always wait() and
kill() the Mutter process, and then, if running in Xephyr, clean up
Xephyr afterwards. This has the nice side effect of exiting when
gnome-shell does and not forcing the user to close Xephyr manually.

http://bugzilla.gnome.org/show_bug.cgi?id=591171
This commit is contained in:
Owen W. Taylor 2009-08-23 20:48:52 -04:00
parent 3486fcc89a
commit af9ab5dbb6

View File

@ -268,13 +268,19 @@ if options.debug:
# later, in case we kill gdb at a bad time # later, in case we kill gdb at a bad time
termattrs = termios.tcgetattr(0); termattrs = termios.tcgetattr(0);
# We only respawn the previous environment on abnormal exit;
# for a clean exit, we assume that gnome-shell was replaced with
# something else.
normal_exit = False
try: try:
if run_in_xephyr: if run_in_xephyr:
shell = start_xephyr() xephyr = start_xephyr()
# This makes us not grab the org.gnome.Panel name # This makes us not grab the org.gnome.Panel name
os.environ['GNOME_SHELL_NO_REPLACE_PANEL'] = '1' os.environ['GNOME_SHELL_NO_REPLACE_PANEL'] = '1'
start_shell() shell = start_shell()
else: else:
xephyr = None
if gnome_panel_pid is not None: if gnome_panel_pid is not None:
kill_gnome_panel(gnome_panel_pid) kill_gnome_panel(gnome_panel_pid)
shell = start_shell() shell = start_shell()
@ -283,8 +289,6 @@ try:
if options.verbose: if options.verbose:
print "Waiting for shell to exit" print "Waiting for shell to exit"
shell.wait() shell.wait()
if options.verbose:
print "Shell is dead"
except KeyboardInterrupt, e: except KeyboardInterrupt, e:
try: try:
@ -292,14 +296,31 @@ except KeyboardInterrupt, e:
except: except:
pass pass
shell.wait() shell.wait()
if options.verbose:
print "Shell killed"
finally: finally:
# Clean up Xephyr if it outlived the shell
if xephyr:
try:
os.kill(xephyr.pid, signal.SIGKILL)
except OSError:
pass
if shell.returncode == 0:
normal_exit = True
if options.verbose:
print "Shell exited normally"
elif shell.returncode < 0:
# Python has no mapping for strsignal; not worth using
# ctypes for this.
print "Shell killed with signal %d" % - shell.returncode
else:
# Normal reason here would be losing connection the X server
if options.verbose:
print "Shell exited with return code %d" % shell.returncode
if options.debug: if options.debug:
termios.tcsetattr(0, termios.TCSANOW, termattrs); termios.tcsetattr(0, termios.TCSANOW, termattrs);
if not run_in_xephyr: if not run_in_xephyr and not normal_exit:
# Restart gnome-panel and window manager # Restart gnome-panel and window manager
# We don't want to start the new gnome-panel in the current # We don't want to start the new gnome-panel in the current