1. first cut with new routing code. Created NEW_ROUTE branch
[spider.git] / perl / DXProtout.pm
index 1ebb29bc8ceb7d356c7ac2d7309c2d4ad16d6a7b..786d78c0f8d08c8be09704d6fdbd81bd8bd06567 100644 (file)
@@ -67,36 +67,42 @@ sub pc12
 
 #
 # add one or more users (I am expecting references that have 'call', 
-# 'confmode' & 'here' method) 
+# 'conf' & 'here' method) 
 #
 # this will create a list of PC16 with up pc16_max_users in each
 # called $self->pc16(..)
 #
 sub pc16
 {
-       my $self = shift;
+       my $node = shift;
+       my $ncall = $node->call;
        my @out;
-       my $i;
 
-       for ($i = 0; @_; ) {
-               my $str = "PC16^$self->{call}";
-               for ( ; @_ && length $str < 200; $i++) {
+       my $str = "PC16^$ncall";
+       while (@_) {
+               for ( ; @_ && length $str < 200; ) {
                        my $ref = shift;
-                       $str .= sprintf "^%s %s %d", $ref->call, $ref->confmode ? '*' : '-', $ref->here;
+                       $str .= sprintf "^%s %s %d", $ref->call, $ref->conf ? '*' : '-', $ref->here;
                }
                $str .= sprintf "^%s^", get_hops(16);
                push @out, $str;
-               $i = 0;
        }
-       return (@out);
+       return @out;
 }
 
 # remove a local user
 sub pc17
 {
-       my ($self, $ref) = @_;
-       my $hops = get_hops(17);
-       return "PC17^$ref->{call}^$self->{call}^$hops^";
+       my @out;
+       while (@_) {
+               my $node = shift;
+               my $ref = shift;
+               my $hops = get_hops(17);
+               my $ncall = $node->call;
+               my $ucall = $ref->call;
+               push @out, "PC17^$ucall^$ncall^$hops^"; 
+       }
+       return @out;
 }
 
 # Request init string
@@ -110,22 +116,20 @@ sub pc18
 # 
 sub pc19
 {
-       my $self = shift;
        my @out;
-       my $i;
-       
 
-       for ($i = 0; @_; ) {
+       while(@_) {
                my $str = "PC19";
-               for (; @_ && length $str < 200; $i++) {
+               for (; @_ && length $str < 200;) {
                        my $ref = shift;
-                       my $here = $ref->{here} ? '1' : '0';
-                       my $confmode = $ref->{confmode} ? '1' : '0';
-                       $str .= "^$here^$ref->{call}^$confmode^$ref->{pcversion}";
+                       my $call = $ref->call;
+                       my $here = $ref->here;
+                       my $conf = $ref->conf;
+                       my $version = $ref->version;
+                       $str .= "^$here^$call^$conf^$version";
                }
                $str .= sprintf "^%s^", get_hops(19);
                push @out, $str;
-               $i = 0;
        }
        return @out;
 }
@@ -139,10 +143,14 @@ sub pc20
 # delete a node
 sub pc21
 {
-       my ($call, $reason) = @_;
-       my $hops = get_hops(21);
-       $reason = "Gone." if !$reason;
-       return "PC21^$call^$reason^$hops^";
+       my @out;
+       while (@_) {
+               my $node = shift;
+               my $hops = get_hops(21);
+               my $call = $node->call;
+               push @out, "PC21^$call^Gone^$hops^";
+       }
+       return @out;
 }
 
 # end of init phase
@@ -244,8 +252,7 @@ sub pc35
 # send all the DX clusters I reckon are connected
 sub pc38
 {
-       my @nodes = map { ($_->dxchan && $_->dxchan->isolate) ? () : $_->call } DXNode->get_all();
-       return "PC38^" . join(',', @nodes) . "^~";
+       return join '^', "PC38", map {$_->call} Route::Node::get_all();
 }
 
 # tell the local node to discconnect