- push @out, $self->msg('snode2', $pcall, $sort, "$ver $build");
- } else {
- my ($major, $minor, $subs) = unpack("AAA*", $ver) if $ver;
- push @out, $self->msg('snode2', $pcall, $sort, $ver ? "$major\-$minor.$subs" : " ");
+ $ver = "";
+ $build = "";
+ if ($call eq $main::mycall) {
+ $sort = "Spider";
+ $ver = $main::version;
+ } else {
+ $ver = $clref->version if $clref && $clref->version;
+ $ver = $uref->version if !$ver && $uref->version;
+ $sort = "CCClus" if $ver >= 1000 && $ver < 4000 && $sort eq "Spider";
+ }
+
+ if ($uref->is_spider || ($clref && $clref->do_pc9x)) {
+ $ver /= 100 if $ver > 5400;
+ $ver -= 53 if $ver > 54;
+ if ($clref && $clref->build) {
+ $build = "build: " . $clref->build
+ }
+ elsif ($uref->build) {
+ $build = "build: " . $uref->build;
+ }
+ push @out, $self->msg('snode2', $pcall, $sort, "$ver $build");
+ } else {
+ my ($major, $minor, $subs) = unpack("AAA*", $ver) if $ver;
+ push @out, $self->msg('snode2', $pcall, $sort, $ver ? "$major\-$minor.$subs" : " ");
+ }
+ ++$count;