1 |
#!@PERL@ |
2 |
$crossname = "/madhatter/bin/crossfire"; |
3 |
$playerdir = "/madhatter/lib/X11/crossfire/players"; |
4 |
$logcount = 0; |
5 |
$logdir= "/tmp/crosslog"; |
6 |
|
7 |
if (! -d $logdir) { |
8 |
mkdir($logdir,0775) || die("Unable to mkdir $logdir\n"); |
9 |
} |
10 |
system("rm $logdir/*"); |
11 |
|
12 |
$badcount = 0; |
13 |
while(1) { |
14 |
++$logcount; |
15 |
$starttime = time; |
16 |
&doserver; |
17 |
system("rm /tmp/*$crosspid.o?"); |
18 |
system("rmdir $playerdir/*.lock"); |
19 |
$badcount = 0 if ((time-$startime)<300); |
20 |
++$badcount; |
21 |
die("Crossfire really unhappy\n") |
22 |
if $badcount>10; |
23 |
} |
24 |
|
25 |
sub doserver { |
26 |
open(LOGFILE,">$logdir/$logcount") |
27 |
|| die("Unable to open $logdir/$logcount for write\n"); |
28 |
$oldfh = select(LOGFILE);$|=1;select(LOGFILE); |
29 |
pipe(READ,WRITE); |
30 |
if (($crosspid=fork)>0) { |
31 |
# Parent |
32 |
close(WRITE); |
33 |
$now = time; |
34 |
$toomuch =0; |
35 |
while(<READ>) { |
36 |
if ((time-$now)<5) { |
37 |
++$toomuch; |
38 |
if ($toomuch>500) { |
39 |
print LOGFILE "Crossfire Talks too much\n"; |
40 |
kill 'HUP', $crosspid; |
41 |
sleep(5); |
42 |
kill 'TERM', $crosspid; |
43 |
sleep(5); |
44 |
kill 'INT', $crosspid; |
45 |
sleep(5); |
46 |
kill 9, $crosspid; |
47 |
last; |
48 |
} |
49 |
} else { |
50 |
$toomuch = 0; |
51 |
} |
52 |
print LOGFILE $_; |
53 |
} |
54 |
} elsif ($crosspid==0) { |
55 |
close(READ); |
56 |
open(STDOUT,">&WRITE") || die("Can't redirect stdout\n"); |
57 |
open(STDERR,">&WRITE") || die("Can't redirect stderr\n"); |
58 |
exec "$crossname","-server"; |
59 |
die("Exec Failed\n"); |
60 |
} else { |
61 |
die("can't fork\n"); |
62 |
} |
63 |
close(LOGFILE); |
64 |
} |