X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Freply.pl;h=22f04b85bd98d9570318a4f861566c0f0887768e;hb=4b207544da78b182bd12e94eab01451694749012;hp=a05e3cbed2c0731fe954cdcee1794e20989cbfd1;hpb=78ed3f6025103ec1c47c90725e37b417647d83c8;p=spider.git diff --git a/cmd/reply.pl b/cmd/reply.pl index a05e3cbe..22f04b85 100644 --- a/cmd/reply.pl +++ b/cmd/reply.pl @@ -1,7 +1,86 @@ # -# reply to a message +# send a message # +# this should handle +# +# send [ .. ] +# send private [ .. ] +# send private rr [ .. ] +# send rr [ .. ] +# send noprivate [ .. ] +# send b [ .. ] +# send copy [ .. ] +# send copy rr [ .. ] +# # Copyright (c) Dirk Koopman G1TLH # -# $Id$ # +# +my ($self, $line) = @_; +my @out; +my $loc; + +#$DB::single = 1; + +if ($self->state eq "prompt") { + + my @f = split /\s+/, $line if $line; + + # now deal with real message inputs + # parse out send line for various possibilities + $loc = {}; + + my $i = 0; + my @extra = (); + my $msgno = $self->lastread; + $loc->{private} = '1'; + $loc->{rrreq} = '0'; + while (@f) { + my $w = shift @f; + if ($w =~ /^\d+$/) { + $msgno = $w; + } elsif ($w =~ /^(B|NOP)/i) { + $loc->{private} = '0'; + } elsif ($w =~ /^P/i) { + ; + } elsif (uc $w eq 'RR') { + $loc->{rrreq} = '1'; + } else { + push @extra, uc $w; + } + } + + my $oref; + + # check we have a reply number + # $DB::single = 1; + + $oref = DXMsg::get($msgno) if $msgno; + return (1, $self->msg('m4', $i)) unless $oref; + + # now save all the 'to' callsigns for later + my $to; + if ($loc->{private}) { + $to = $oref->from; + } else { + $to = $oref->to; + @extra = (); + } + + return (1, $self->msg('e28')) unless $self->isregistered || $to eq $main::myalias; + + $loc->{to} = [ $to, @extra ]; # to is an array + $loc->{subject} = $oref->subject; + $loc->{subject} = "Re: " . $loc->{subject} if !($loc->{subject} =~ /^Re:\s/io); + + # find me and set the state and the function on my state variable to + # keep calling me for every line until I relinquish control + $self->func("DXMsg::do_send_stuff"); + $self->state('sendbody'); + $self->loc($loc); + push @out, $self->msg('m6', join(',', $to, @extra)); + push @out, $self->msg('m7', $loc->{subject}); + push @out, $self->msg('m8'); +} + +return (1, @out);