X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fdirectory.pl;h=1e2193219ef984afc97bde2cc1e0dfbba04f5563;hb=refs%2Fheads%2Fmaster;hp=ab81798585a9008158abf54982f199ec1dad8e42;hpb=6a0068ec3df1dca0c6ae2714af3c0a4a62998dcf;p=spider.git diff --git a/cmd/directory.pl b/cmd/directory.pl index ab817985..1e219321 100644 --- a/cmd/directory.pl +++ b/cmd/directory.pl @@ -3,7 +3,7 @@ # # Copyright (c) Dirk Koopman G1TLH # -# $Id$ +# # my ($self, $line) = @_; @@ -11,34 +11,75 @@ my @f = split /\s+/, $line; my @ref; my $ref; my @out; +my $f; +my $n = 0; -$f[0] = uc $f[0]; -if ($f[0] eq 'ALL') { - foreach $ref (DXMsg::get_all()) { - next if $self->priv < 5 && $ref->private && $ref->to ne $self->call && $ref->from ne $self->call; - push @ref, $ref; - } -} elsif ($f[0] =~ /^O/o) { # dir/own - foreach $ref (DXMsg::get_all()) { - push @ref, $ref if $ref->private && ($ref->to eq $self->call || $ref->from eq $self->call); - } -} elsif ($f[0] =~ /^N/o) { # dir/new - foreach $ref (DXMsg::get_all()) { - push @ref, $ref if $ref->private && !$ref->read && $ref->to eq $self->call; - } -} else { - my @all = (DXMsg::get_all()); - my ($i, $count); - for ($i = $#all; $i > 0; $i--) { - $ref = $all[$i]; - next if $self->priv < 5 && $ref->private && $ref->to ne $self->call && $ref->from ne $self->call; - unshift @ref, $ref; - last if ++$count > 10; - } -} +# select candidates +my @all = grep {!$_->private || !($self->priv < 5 && $_->to ne $self->call && $_->from ne $self->call)} (DXMsg::get_all()); +@all = grep {!$_->delete || ($self->priv >= 5 && $_->delete)} @all; + +return (1, $self->msg('dir1')) unless @all; +my $sel = 0; +my $from = 0; +my $to = $all[@all-1]->msgno; -foreach $ref (@ref) { - push @out, $ref->dir; +while (@f) { + $f = uc shift @f; + if ($f eq 'ALL') { + @ref = @all; + $n = @ref; + $sel++; + } elsif ($f =~ /^O/o) { # dir/own + @ref = grep { $_->to eq $self->call || $_->from eq $self->call } @all; + $sel++; + } elsif ($f =~ /^N/o) { # dir/new + @ref = grep { $_->t > $self->user->lastin } @all; + $sel++; + } elsif ($f =~ /^S/o) { # dir/subject + $f = shift @f; + if ($f) { + $f =~ s{(.)}{"\Q$1"}ge; + @ref = grep { $_->subject =~ m{$f}i } @all; + $sel++; + } + } elsif ($f eq '>' || $f =~ /^T/o){ + $f = uc shift @f; + if ($f) { + $f = shellregex($f); + @ref = grep { $_->to =~ m{$f} } @all; + $sel++; + } + } elsif ($f eq '<' || $f =~ /^F/o){ + $f = uc shift @f; + if ($f) { + $f = shellregex($f); + @ref = grep { $_->from =~ m{$f} } @all; + $sel++; + } + } elsif ($f =~ /^(\d+)-(\d+)$/) { # a range of items + $from = $1; + $to = $2; + } elsif ($f =~ /^\d+$/ && $f > 0) { # a number of items + $n = $f; + } } +$n = 10 unless $n; +@ref = @all unless $sel || @ref; + +if (@ref) { + if ($from != 0 || $to != $all[@all-1]->msgno) { + @ref = grep {$_->msgno >= $from && $_->msgno <= $to} @ref; + } + my $i = @ref - $n; + $i = 0 unless $i > 0; + my $count; + while ($i < @ref) { + $ref = $ref[$i++]; + push @out, $ref->dir; + last if ++$count >= $n; + } +} else { + push @out, $self->msg('dir1'); +} return (1, @out);