+14Mar01=======================================================================
+1. first cut at outgoing ax25 /external program connects
13Mar01=======================================================================
1. implemented first cut at non blocking connect
2. removed memory leakage in connects
{
my $call = uc shift;
my $dxchan = DXChannel->get($call);
- if ($dxchan) {
- if ($dxchan->is_ak1a) {
- $dxchan->send_now("D", DXProt::pc39($main::mycall, "$main::mycall DXCron"));
- } else {
- $dxchan->send_now('D', "");
- }
- $dxchan->disconnect;
- }
+ $dxchan->disconnect if $dxchan;
}
# start a connect process off
# in child, unset warnings, disable debugging and general clean up from us
$^W = 0;
eval "{ package DB; sub DB {} }";
- alarm(0);
DXChannel::closeall();
for (@main::listeners) {
$_->close_server;
unless ($^O =~ /^MS/) {
$SIG{HUP} = 'IGNORE';
$SIG{CHLD} = $SIG{TERM} = $SIG{INT} = $SIG{__WARN__} = 'DEFAULT';
+ alarm(0);
}
exec "$line" or dbg('cron', "exec '$line' failed $!");
}
my $conn = shift;
my $msg;
+ if ($conn->{sort} eq 'ax25' && exists $conn->{msg}) {
+ $conn->{msg} =~ s/\cM/\cJ/g;
+ }
if ($conn->{state} eq 'WC') {
if (exists $conn->{cmd}) {
if (@{$conn->{cmd}}) {
{
my ($conn, $sort, $line) = @_;
my $r;
-
+
+ $sort = lc $sort;
dbg('connect', "CONNECT sort: $sort command: $line");
if ($sort eq 'telnet') {
# this is a straight network connect
dbg('connect', "***Connect Failed to $host $port $!");
}
} elsif ($sort eq 'ax25' || $sort eq 'prog') {
- ;
+ my $pid = fork();
+ if (defined $pid) {
+ if (!$pid) {
+ # in child, unset warnings, disable debugging and general clean up from us
+ $^W = 0;
+ eval "{ package DB; sub DB {} }";
+ DXChannel::closeall();
+ for (@main::listeners) {
+ $_->close_server;
+ }
+ unless ($^O =~ /^MS/) {
+ $SIG{HUP} = 'IGNORE';
+ $SIG{CHLD} = $SIG{TERM} = $SIG{INT} = $SIG{__WARN__} = 'DEFAULT';
+ alarm(0);
+ }
+ exec "$line" or dbg('cron', "exec '$line' failed $!");
+ }
+ dbg('connect', "program $sort $line started");
+ $conn->{pid} = $pid;
+ $conn->{sort} = $sort;
+ $conn->{lineend} = "\cM" if $sort eq 'ax25';
+ } else {
+ dbg('connect', "can't $sort fork for $line $!");
+ }
} else {
dbg('err', "invalid type of connection ($sort)");
$conn->disconnect;
$call ||= 'unallocated';
dbg('connll', "Connection $call disconnected");
- set_event_handler ($sock, read => undef, write => undef, error => undef);
-
unless ($^O =~ /^MS/i) {
kill 'TERM', $conn->{pid} if exists $conn->{pid};
}
}
return unless defined($sock);
+ set_event_handler ($sock, read => undef, write => undef, error => undef);
shutdown($sock, 3);
close($sock);
}