/[mws]/trunk/MWS.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/MWS.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 19 by dpavlin, Fri May 7 20:52:34 2004 UTC revision 21 by dpavlin, Sat May 8 00:54:16 2004 UTC
# Line 12  use POSIX qw(strftime); Line 12  use POSIX qw(strftime);
12  use Text::Autoformat;  use Text::Autoformat;
13  use Text::Iconv;  use Text::Iconv;
14  use Text::Unaccent;  use Text::Unaccent;
15    use Date::Parse;
16    use POSIX qw(strftime);
17    use MIME::Base64;
18    
19  #use MWS_plucene;  #use MWS_plucene;
20  use MWS_swish;  use MWS_swish;
# Line 88  sub add_counter($$) { Line 91  sub add_counter($$) {
91          return $self->{counter}->{$c}->{$k}->{usage}++;          return $self->{counter}->{$c}->{$k}->{usage}++;
92  }  }
93    
94    sub yyyymmdd {
95            my $self = shift;
96    
97            my $t = shift || time;
98    
99            my (undef,undef,undef,$dd,$mm,$yyyy) = localtime($t);
100            $mm++;
101            $yyyy+=1900;
102            return ($yyyy,$mm,$dd);
103    }
104    
105    sub fmtdate {
106            my $self = shift;
107    
108            my @out;
109            my @formats = qw(%04d %02d %02d);
110            while (my $v = shift) {
111                    my $f = shift @formats;
112                    push @out, sprintf($f, $v);
113            }
114    
115    print STDERR "fmtdate: ",join('|',@out),"\n";
116    
117            return (wantarray ? @out : join("-",@out));
118    }
119    
120    sub add_counter_calendar($) {
121            my $self = shift;
122    
123            my $t = shift || croak "add_counter_calendar without argument!";
124            
125            my ($yyyy,$mm,$dd) = $self->fmtdate($self->yyyymmdd($t));
126    
127            return $self->{counter}->{calendar}->{"$yyyy-$mm"}->{$dd}++;
128    }
129    
130    
131  sub counter {  sub counter {
132          my $self = shift;          my $self = shift;
133    
# Line 166  sub fetch_message { Line 206  sub fetch_message {
206  sub search {  sub search {
207          my $self = shift;          my $self = shift;
208    
209          my $s = shift || carp "search called without argument!";          carp "search called without argument!" if (! @_);
210    
211          $self->reset_counters;          $self->reset_counters;
212    
213          print STDERR "search_index($s)\n" if ($debug == 2);          print STDERR "search(",join(" ",@_),")\n" if ($debug == 2);
214          my @index_ids = $self->search_index($s);          my @index_ids = $self->search_index(@_);
215    
216          $self->{'index_ids'} = \@index_ids;          $self->{'index_ids'} = \@index_ids;
217    
# Line 192  sub decode_qp($) { Line 232  sub decode_qp($) {
232    
233          my $tmp = shift || return;          my $tmp = shift || return;
234    
235          sub decode($$) {          sub decode($$$) {
236                  my ($cp,$qp) = @_;                  my ($cp,$enc,$qp) = @_;
237    
238                    print STDERR "decode($cp,$qp) -> " if ($debug == 2);
239    
240                    if (uc($enc) eq "Q") {
241                            $qp =~ s/=([a-f0-9][a-f0-9])/chr(hex($1))/ieg;
242                            $qp =~ s/_/ /g;
243                    } elsif (uc($enc) eq "B") {
244                            $qp = decode_base64($qp);
245                    } else {
246                            croak "unsupported encoding '$enc' in decode_qp\n";
247                            return $qp;
248                    }
249    
250                    print STDERR "$qp -> " if ($debug == 2);
251    
252                  my $iconv = Text::Iconv->new($cp,'ISO-8859-2');                  my $iconv = Text::Iconv->new($cp,'ISO-8859-2');
253          print STDERR "decode($cp,$qp) -> " if ($debug == 2);                  return $iconv->convert($qp) || '';
                 $qp =~ s/=([a-f0-9][a-f0-9])/chr(hex($1))/ieg;  
                 $qp =~ s/_/ /g;  
         print STDERR "$qp\n" if ($debug == 2);  
                 return $iconv->convert($qp) || $qp;  
254          }          }
255    
256          $tmp =~ s/=\?([^\?]+)\?Q\?(.+?)\?=/decode($1,$2)/ex;          $tmp =~ s/=\?([^\?]+)\?([QB])\?(.+?)\?=/decode($1,$2,$3)/ige;
257          $tmp =~ s/^\s*["']+(.*?)["']+\s*$/$1/g;          $tmp =~ s/^\s*["']+(.*?)["']+\s*$/$1/g;
258            #print STDERR "$tmp\n" if ($debug == 2);
259          return $tmp;          return $tmp;
260  }  }
261    
# Line 280  sub plain_text_body { Line 332  sub plain_text_body {
332          my $wrap = $self->{wrap_margin};          my $wrap = $self->{wrap_margin};
333          if ($wrap && $body && $body =~ m/^.{$wrap}..*$/m) {          if ($wrap && $body && $body =~ m/^.{$wrap}..*$/m) {
334                  $body =~ s/[\r\n]/\n/gs;                  $body =~ s/[\r\n]/\n/gs;
335                  $body = autoformat($body, {right=>$wrap});                  $body = autoformat($body, {right=>$wrap, all=>1});
336                  $body .="\n[reformated using autoformat, margin at $wrap]" if ($debug == 2);                  $body .="\n[reformated using autoformat, margin at $wrap]" if ($debug == 2);
337          }          }
338    
# Line 311  sub fetch_result_by_id { Line 363  sub fetch_result_by_id {
363                  }                  }
364                  $row->{'subject'} = $self->decode_qp($message->subject);                  $row->{'subject'} = $self->decode_qp($message->subject);
365                  $row->{'body'} = $self->plain_text_body($message);                  $row->{'body'} = $self->plain_text_body($message);
366                  $row->{'date'} = $message->date;                  my $utime = str2time($message->date);
367    
368                    $row->{'date_utime'} = $utime;
369    
370                    $row->{'date'} = strftime("%Y-%m-%d %H:%M:%S", localtime($utime));
371                    $self->add_counter_calendar($utime);
372    
373                  # XXX store in cache?                  # XXX store in cache?
374                  $self->{cache}->{$id} = $row;                  $self->{cache}->{$id} = $row;

Legend:
Removed from v.19  
changed lines
  Added in v.21

  ViewVC Help
Powered by ViewVC 1.1.26