$main::build += $VERSION;
$main::branch += $BRANCH;
+use vars qw($sentencelth);
+
+$sentencelth = 180;
+
#
# All the PCxx generation routines
#
# create an announce message
sub pc12
{
- my ($call, $text, $tonode, $sysop, $wx) = @_;
+ my ($call, $text, $tonode, $sysop, $wx, $origin) = @_;
my $hops = get_hops(12);
- $sysop = ' ' if !$sysop;
- $text = ' ' if !$text;
- $wx = '0' if !$wx;
- $tonode = '*' if !$tonode;
+ $text ||= ' ';
$text =~ s/\^/%5E/g;
- return "PC12^$call^$tonode^$text^$sysop^$main::mycall^$wx^$hops^~";
+ $tonode ||= '*';
+ $sysop ||= ' ';
+ $wx ||= '0';
+ $origin ||= $main::mycall;
+ return "PC12^$call^$tonode^$text^$sysop^$origin^$wx^$hops^~";
}
#
my $ncall = $node->call;
my @out;
- while (@_) {
- my $str = "PC16^$ncall";
- for ( ; @_ && length $str < 200; ) {
- my $ref = shift;
- $str .= sprintf "^%s %s %d", $ref->call, $ref->conf ? '*' : '-', $ref->here;
+ my $s = "";
+ for (@_) {
+ next unless $_;
+ my $ref = $_;
+ my $str = sprintf "^%s %s %d", $ref->call, $ref->conf ? '*' : '-', $ref->here;
+ if (length($s) + length($str) > $sentencelth) {
+ push @out, "PC16^$ncall" . $s . sprintf "^%s^", get_hops(16);
+ $s = "";
}
- $str .= sprintf "^%s^", get_hops(16);
- push @out, $str;
+ $s .= $str;
}
+ push @out, "PC16^$ncall" . $s . sprintf "^%s^", get_hops(16);
return @out;
}
# Request init string
sub pc18
{
- return "PC18^DXSpider Version: $main::version Build: $main::build^$DXProt::myprot_version^";
+ my $flags = " pc92";
+ $flags .= " xml" if DXXml::available();
+ return "PC18^DXSpider Version: $main::version Build: $main::build$flags^$DXProt::myprot_version^";
}
#
sub pc19
{
my @out;
-
- while(@_) {
- my $str = "PC19";
- for (; @_ && length $str < 200;) {
- my $ref = shift;
- my $call = $ref->call;
- my $here = $ref->here;
- my $conf = $ref->conf;
- my $version = $ref->version;
- $str .= "^$here^$call^$conf^$version";
+ my @in;
+
+ my $s = "";
+ for (@_) {
+ next unless $_;
+ my $ref = $_;
+ my $call = $ref->call;
+ my $here = $ref->here;
+ my $conf = $ref->conf;
+ my $version = $ref->version;
+ my $str = "^$here^$call^$conf^$version";
+ if (length($s) + length($str) > $sentencelth) {
+ push @out, "PC19" . $s . sprintf "^%s^", get_hops(19);
+ $s = "";
}
- $str .= sprintf "^%s^", get_hops(19);
- push @out, $str;
+ $s .= $str;
}
+ push @out, "PC19" . $s . sprintf "^%s^", get_hops(19);
return @out;
}
return "PC85^$tonode^$fromnode^$call^$msg^~";
}
-# spider route broadcast
-sub pc90
+# spider route broadcasts
+#
+
+my $_last_time;
+my $_last_occurs;
+
+sub _gen_time
+{
+ if (!$_last_time || $_last_time != $main::systime) {
+ $_last_time = $main::systime;
+ $_last_occurs = 0;
+ return $_last_time;
+ } else {
+ $_last_occurs++;
+ return sprintf "$_last_time.%02d", $_last_occurs;
+ }
+}
+
+sub _gen_pc92
+{
+ my $sort = shift;
+# my $ext = $sort eq 'C';
+ my $ext = 1;
+ my $s = "PC92^$main::mycall^" . _gen_time . "^$sort";
+ for (@_) {
+ $s .= "^" . _encode_pc92_call($_, $ext);
+ }
+ return $s . '^H99^';
+}
+
+sub gen_pc92_with_time
+{
+ my $call = shift;
+ my $sort = shift;
+ my $t = shift;
+ my $ext = 1;
+ my $s = "PC92^$call^$t^$sort";
+ for (@_) {
+ $s .= "^" . _encode_pc92_call($_, $ext);
+ }
+ return $s . '^H99^';
+}
+
+# add a local one
+sub pc92a
+{
+ return _gen_pc92('A', @_);
+}
+
+# delete a local one
+sub pc92d
+{
+ return _gen_pc92('D', @_);
+}
+
+# send a config
+sub pc92c
{
+ return _gen_pc92('C', @_);
}
1;