X-Git-Url: http://dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2Fcluster.pl;h=5b3f64668cf2f10cd6a0c8238f6f78e7dc34a5f7;hb=602b16e109137598da1bb8a363c0bfb4028701b3;hp=f46ef82d80f20f7ad4f7ef3d19d2685f1ce101ae;hpb=84505457c5b3757715d97a63acd792b28fc1841a;p=spider.git diff --git a/perl/cluster.pl b/perl/cluster.pl index f46ef82d..5b3f6466 100755 --- a/perl/cluster.pl +++ b/perl/cluster.pl @@ -16,8 +16,8 @@ BEGIN { $root = "/spider"; $root = $ENV{'DXSPIDER_ROOT'} if $ENV{'DXSPIDER_ROOT'}; - unshift @INC, '$root/perl'; # this IS the right way round! - unshift @INC, '$root/local'; + unshift @INC, "$root/perl"; # this IS the right way round! + unshift @INC, "$root/local"; } use Msg; @@ -31,8 +31,11 @@ use DXProt; use DXMsg; use DXCluster; use DXDebug; +use DXCron; +use DXConnect; use Prefix; use Bands; +use Carp; package main; @@ -140,7 +143,10 @@ sub process_inqueue $dxchan->start($line); } elsif ($sort eq 'D') { die "\$user not defined for $call" if !defined $user; - $dxchan->normal($line); + + # normal input + $dxchan->normal($line); + disconnect($dxchan) if ($dxchan->{state} eq 'bye'); } elsif ($sort eq 'Z') { disconnect($dxchan); @@ -162,6 +168,9 @@ foreach(@debug) { } STDOUT->autoflush(1); +# banner +print "DXSpider DX Cluster Version $version\nCopyright (c) 1998 Dirk Koopman G1TLH\n"; + # load Prefixes print "loading prefixes ...\n"; Prefix::load(); @@ -189,6 +198,14 @@ DXProt->init(); # put in a DXCluster node for us here so we can add users and take them away DXNode->new(0, $mycall, 0, 1, $DXProt::myprot_version); +# read in any existing message headers +print "reading existing message headers\n"; +DXMsg->init(); + +# read in any cron jobs +print "reading cron jobs\n"; +DXCron->init(); + # this, such as it is, is the main loop! print "orft we jolly well go ...\n"; for (;;) { @@ -204,6 +221,8 @@ for (;;) { $ztime = &ztime(); DXCommandmode::process(); # process ongoing command mode stuff DXProt::process(); # process ongoing ak1a pcxx stuff + DXCron::process(); + DXConnect::process(); } }