/[webpac]/trunk2/all2all.pl
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 /trunk2/all2all.pl

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

revision 426 by dpavlin, Sun Sep 12 01:25:55 2004 UTC revision 437 by dpavlin, Mon Sep 13 15:32:55 2004 UTC
# Line 9  all2all.pl - basic script for all WebPAC Line 9  all2all.pl - basic script for all WebPAC
9  use strict;  use strict;
10  use Data::Dumper;  use Data::Dumper;
11  use Carp;  use Carp;
12    use Getopt::Long;
13    
14  use lib './lib';  use lib './lib';
15  use WebPAC;  use WebPAC;
16  use WebPAC::jsFind;  use WebPAC::jsFind;
17  use WebPAC::Index;  use WebPAC::Index;
18    
19    # options which can be changed via command line
20    #
21    my $code_page = 'ISO-8859-2';
22    my ($limit_mfn, $start_mfn, $debug, $low_mem);
23    my $index_path = './out/index';
24    
25    my $result = GetOptions(
26            "code_page=s"   => \$code_page,
27            "limit_mfn=i"   => \$limit_mfn,
28            "start_mfn=i"   => \$start_mfn,
29            "debug!"        => \$debug,
30            "low_mem!"      => \$low_mem,
31    );
32    
33    # create WebPAC object
34    #
35  my $webpac = new WebPAC(  my $webpac = new WebPAC(
36          code_page => 'ISO-8859-2',          code_page => $code_page,
37          limit_mfn => 500,          limit_mfn => $limit_mfn,
38  #       debug => 1,          start_mfn => $start_mfn,
39  #       low_mem => 1,          debug => $debug,
40            low_mem => $low_mem,
41  ) || die;  ) || die;
42    
43  my $log = $webpac->_get_logger() || die "can't get logger";  my $log = $webpac->_get_logger() || die "can't get logger";
# Line 27  my $log = $webpac->_get_logger() || die Line 45  my $log = $webpac->_get_logger() || die
45  $log->debug("creating WebPAC::jsFind object");  $log->debug("creating WebPAC::jsFind object");
46    
47  my $index = new WebPAC::jsFind(  my $index = new WebPAC::jsFind(
48          index_path => './out/index',          index_path => $index_path,
49          keys => 10,          keys => 10,
50  ) || die;  ) || die;
51    
# Line 150  if (0 && $log->is_debug) { Line 168  if (0 && $log->is_debug) {
168    
169  } # XXX if(0)  } # XXX if(0)
170    
171  $log->info("lookup hash: ",Dumper($webpac->{'lookup'}));  $log->debug("lookup hash: ",Dumper($webpac->{'lookup'}));
172    
173  #  #
174  # tree dump implementation which shouldn't be here :-)  # tree dump implementation which shouldn't be here :-)
175  #  #
176    
177    
178  my $file = 'out/browse.html';  my $file = 'out/browse.html';
179    my $js_url = 'tree-ids.js';
180    
181    $log->info("creating '$file' for tree html");
182  open(HTML, "> $file") || $log->logdie("can't open '$file'");  open(HTML, "> $file") || $log->logdie("can't open '$file'");
183    
184  print HTML qq{  print HTML qq{
# Line 165  print HTML qq{ Line 187  print HTML qq{
187   <title>Browse</title>   <title>Browse</title>
188   <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-2"/>   <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-2"/>
189   <script type="text/javascript" src="bfilter/hide.js"></script>   <script type="text/javascript" src="bfilter/hide.js"></script>
190     <script type="text/javascript" src="$js_url"></script>
191  </head>  </head>
192    
193    <!--
194    <body onLoad="show_hide_display(show,hide);">
195    -->
196  <body>  <body>
197    
198    <span style="background: #e0e0e0;">
199        <a href="search.html">search</a> |
200        <a href="thesaurus.html">thesarus</a> |
201        <a href="browse.html"><b>browse</b></a>
202    </span>
203    
204    <div style="float: right; width: 10em; text-align: center; margin: 0.5m; background: #e0e0e0; border: 1px dashed #c0c0c0; z-index: 1;">
205    Folding:
206    <br/>
207    <a href="#" onClick="back_display();">&laquo;</a>&nbsp;<a href="#" onClick="default_display();">default</a>&nbsp;<a href="#" onClick="forward_display();">&raquo;</a>
208    <br/>
209    <a href="#" onClick="show_hide_display(show,hide);">reset</a>
210    <a href="#" onClick="show_display(show); show_display(hide);">all</a>
211    <a href="#" onClick="hide_display(hide); hide_display(show);">none</a>
212    <br/>
213    <a href="#" onClick="alert('show: '+show.length+', hide: '+hide.length+', changed:'+changed_display_ids.length+', positin: '+changed_display_pos);">debug</a>
214    
215    <a href="#" onClick="outline_display('mfn6030');">outline</a>
216    </div>
217    
218  <ul>  <ul>
219  };  };
220    
# Line 229  my @tree = ({ Line 277  my @tree = ({
277                          },                          },
278          lookup_term     => sub { shift @{$l->{"d:".$_[0]}} },          lookup_term     => sub { shift @{$l->{"d:".$_[0]}} },
279          lookup_mfn      => sub { shift @{$l->{"900_mfn:".$_[0]}} },          lookup_mfn      => sub { shift @{$l->{"900_mfn:".$_[0]}} },
280            have_children   => sub { defined($l->{$_[1]}) },
281            child_code      => sub { return $_[1] },
282            },{
283            # 5
284            code_arr        => sub { @{$l->{$_[0]}} },
285            filter_code     => sub { shift },
286            lookup_v900     => sub {
287                                    my ($c,$p) = @_;
288                                    $p =~ s/^a:(..:....):.*$/$1/;
289                                    return "a:".$p.":".$c;
290                            },
291            lookup_term     => sub { shift @{$l->{"d:".$_[0]}} },
292            lookup_mfn      => sub { shift @{$l->{"900_mfn:".$_[0]}} },
293            have_children   => sub { defined($l->{$_[1]}) },
294            child_code      => sub { return $_[1] },
295            },{
296            # 6
297            code_arr        => sub { @{$l->{$_[0]}} },
298            filter_code     => sub { shift },
299            lookup_v900     => sub {
300                                    my ($c,$p) = @_;
301                                    $p =~ s/^a:(..:....):.*$/$1/;
302                                    return "a:".$p.":".$c;
303                            },
304            lookup_term     => sub { shift @{$l->{"d:".$_[0]}} },
305            lookup_mfn      => sub { shift @{$l->{"900_mfn:".$_[0]}} },
306            have_children   => sub { defined($l->{$_[1]}) },
307            child_code      => sub { return $_[1] },
308            },{
309            # 7
310            code_arr        => sub { @{$l->{$_[0]}} },
311            filter_code     => sub { shift },
312            lookup_v900     => sub {
313                                    my ($c,$p) = @_;
314                                    $p =~ s/^a:(..:....):.*$/$1/;
315                                    return "a:".$p.":".$c;
316                            },
317            lookup_term     => sub { shift @{$l->{"d:".$_[0]}} },
318            lookup_mfn      => sub { shift @{$l->{"900_mfn:".$_[0]}} },
319            have_children   => sub { defined($l->{$_[1]}) },
320            child_code      => sub { return $_[1] },
321            },{
322            # 8
323            code_arr        => sub { @{$l->{$_[0]}} },
324            filter_code     => sub { shift },
325            lookup_v900     => sub {
326                                    my ($c,$p) = @_;
327                                    $p =~ s/^a:(..:....):.*$/$1/;
328                                    return "a:".$p.":".$c;
329                            },
330            lookup_term     => sub { shift @{$l->{"d:".$_[0]}} },
331            lookup_mfn      => sub { shift @{$l->{"900_mfn:".$_[0]}} },
332  #       have_children   => sub { defined($l->{$_[1]}) },  #       have_children   => sub { defined($l->{$_[1]}) },
333  #       child_code      => sub { return $_[1] },  #       child_code      => sub { return $_[1] },
334          have_children   => sub { 0 },          have_children   => sub { 0 },
335          child_code      => sub { 0 },          child_code      => sub { 0 },
336  });  });
337    
338    my @show_ids;
339    my @hide_ids;
340    
341  unroll(0,'');  unroll(0,'');
342    
343  $log->debug("test filter: ",$tree[0]->{'filter_code'}->("root:99"));  $log->debug("test filter: ",$tree[0]->{'filter_code'}->("root:99"));
# Line 270  sub unroll { Line 373  sub unroll {
373                    
374                          my $have_children = $tree[$level]->{'have_children'}->($code,$v900,$start_code);                          my $have_children = $tree[$level]->{'have_children'}->($code,$v900,$start_code);
375                          if ($have_children) {                          if ($have_children) {
376                                  ($link_start,$link_end) = (qq{<a href="#mfn$mfn" onClick="return hide_show('mfn$mfn');">},qq{</a>});                                  ($link_start,$link_end) = (qq{<a href="#mfn$mfn" onClick="return toggle_display('id$mfn');">},qq{</a>});
377                          } else {                          } else {
378                                  $log->debug("# $level doesn't have_children($code,$v900,$start_code)");                                  $log->debug("# $level doesn't have_children($code,$v900,$start_code)");
379                          }                          }
380    
                         $log->debug("# $level children re-check failed", sub { Dumper($tree[$level]->{'have_children'}->($code,$v900,$start_code)) }) if (defined($l->{$v900}) && ! $tree[$level]->{'have_children'}->($code,$v900,$start_code));  
   
381                          my $mfn_link = "thes/$mfn.html";                          my $mfn_link = "thes/$mfn.html";
382                          if (-e "out/$mfn_link") {                          if (-e "out/$mfn_link") {
383                                  print HTML " " x $level .                                  print HTML " " x $level .
# Line 289  sub unroll { Line 390  sub unroll {
390                          unless ($have_children) {                          unless ($have_children) {
391                                  next;                                  next;
392                          }                          }
393                                                    my $style = $tree[$level]->{'style'};
394    
395                          print HTML " " x $level .                          print HTML " " x $level .
396                                  qq{<a name="mfn$mfn"></a>\n <ul id="mfn$mfn"}.                                  qq{<a name="mfn$mfn"></a>\n <ul id="id$mfn"}.
397                                  ($tree[$level]->{'style'} ? ' style="'.$tree[$level]->{'style'}.'"' : '').                                  ($style ? ' style="'.$style.'"' : '').
398                                  qq{>\n};                                  qq{>\n};
399    
400                            if ($style) {
401                                    if ($style =~ m/display\s*:\s*none/i) {
402                                            push @hide_ids, "id$mfn";
403                                    } else {
404                                            push @show_ids, "id$mfn";
405                                    }
406                            } else {
407                                    # default: show
408                                    push @show_ids, "id$mfn";
409                            }
410    
411                          unroll($level+1, $tree[$level]->{'child_code'}->($code,$v900,$start_code));                          unroll($level+1, $tree[$level]->{'child_code'}->($code,$v900,$start_code));
412                                                    
413                          print HTML " " x $level . qq{</ul>\n};                          print HTML " " x $level . qq{</ul>\n};
# Line 311  print HTML qq{ Line 424  print HTML qq{
424    
425  close(HTML);  close(HTML);
426    
427    
428    my $js_file = "out/$js_url";
429    $log->info("creating '$js_file' with arrays of shown and hidden ids");
430    open(JS, ">", $js_file) || $log->logdie("can't open '$js_file': $!");
431    print JS "var show = ['",join("','",@show_ids),"'];\n";
432    print JS "var hide = ['",join("','",@hide_ids),"'];\n";
433    close(JS);
434    
435    $log->info("closing index");
436  $index->close;  $index->close;
437    
438  $log->info("elapsed time: ",$webpac->fmt_time(time() - $webpac->{'start_t'}));  $log->info("elapsed time: ",$webpac->fmt_time(time() - $webpac->{'start_t'}));

Legend:
Removed from v.426  
changed lines
  Added in v.437

  ViewVC Help
Powered by ViewVC 1.1.26