From 11192b58aa0053df80faebe224e3cf7f83d822cb Mon Sep 17 00:00:00 2001 From: Guillaume Cottenceau Date: Wed, 26 Nov 2003 13:01:01 +0000 Subject: allow X to restart after dying through X_move script, startkde also through startkde_move script --- move/tree/X_move | 7 +++++++ move/tree/startkde_move | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 39 insertions(+) create mode 100755 move/tree/X_move create mode 100755 move/tree/startkde_move (limited to 'move/tree') diff --git a/move/tree/X_move b/move/tree/X_move new file mode 100755 index 000000000..df085fcd8 --- /dev/null +++ b/move/tree/X_move @@ -0,0 +1,7 @@ +#!/bin/bash + +ok=0 +while [ "$ok" == 0 ]; do + X $@ + ok=$? +done diff --git a/move/tree/startkde_move b/move/tree/startkde_move new file mode 100755 index 000000000..a9d1d53ce --- /dev/null +++ b/move/tree/startkde_move @@ -0,0 +1,32 @@ +#!/usr/bin/perl + +use MDK::Common; +use lib qw(/usr/lib/libDrakX); +use c; + +sub wait4x() { + my $nb = 0; + foreach (1..30) { + sleep 1; + print("no X server :("), exit 1 if !fuzzy_pidofs(qr/\bX_move\b/); + $nb++ if c::Xtest(':0'); + if ($nb > 2) { #- one succeeded test is not enough :-( + return; + } + } + exit 1; +} + +my ($kde_ok, $xwait); + +while (1) { + wait4x(); + if (!($xwait = fork())) { + exec 'xwait', '-permanent'; #- so that server doesn't blink when startkde finishes + } + my ($xdim) = `xdpyinfo` =~ /dimensions:\s*(\d+)/; + system("qiv --root /image/move/BOOT-$xdim-MOVE.jpg"); + system('startkde'); + system('sudo killall X'); + waitpid $xwait, 0; +} -- cgit v1.2.1