56 |
|
|
57 |
$webpac->open_import_xml(type => 'isis_hidra_ths'); |
$webpac->open_import_xml(type => 'isis_hidra_ths'); |
58 |
|
|
59 |
if(0) { # XXX |
if(1) { # XXX |
60 |
|
|
61 |
while (my $rec = $webpac->fetch_rec) { |
while (my $rec = $webpac->fetch_rec) { |
62 |
|
|
182 |
lookup_v900 => sub { shift @{$l->{"root:".$_[0]}} }, |
lookup_v900 => sub { shift @{$l->{"root:".$_[0]}} }, |
183 |
lookup_term => sub { shift @{$l->{"d:".$_[1]}} }, |
lookup_term => sub { shift @{$l->{"d:".$_[1]}} }, |
184 |
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[1]}} }, |
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[1]}} }, |
185 |
have_children => sub { $l->{"a:".$_[0]."::" } }, |
have_children => sub { defined($l->{"a:".$_[0]."::"}) }, |
186 |
child_code => sub { return $_[0] }, |
child_code => sub { return $_[0] }, |
187 |
style => 'display: none', |
style => 'display: none', |
188 |
},{ |
},{ |
192 |
lookup_v900 => sub { shift @{$l->{"code:".$_[0]}} }, |
lookup_v900 => sub { shift @{$l->{"code:".$_[0]}} }, |
193 |
lookup_term => sub { shift @{$l->{"d:".$_[0]}} }, |
lookup_term => sub { shift @{$l->{"d:".$_[0]}} }, |
194 |
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[0]}} }, |
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[0]}} }, |
195 |
have_children => sub { $l->{"a:".$_[1].":" } }, |
have_children => sub { defined($l->{"a:".$_[1].":"}) }, |
196 |
child_code => sub { return $_[1] }, |
child_code => sub { return $_[1] }, |
197 |
style => 'display: none', |
style => 'display: none', |
198 |
},{ |
},{ |
202 |
lookup_v900 => sub { shift }, |
lookup_v900 => sub { shift }, |
203 |
lookup_term => sub { shift @{$l->{"d:".$_[0]}} }, |
lookup_term => sub { shift @{$l->{"d:".$_[0]}} }, |
204 |
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[0]}} }, |
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[0]}} }, |
205 |
|
have_children => sub { defined($l->{"a:".$_[2].":".$_[1]}) }, |
206 |
|
child_code => sub { return "a:".$_[2].":".$_[1] }, |
207 |
|
style => 'display: none', |
208 |
|
},{ |
209 |
|
# 3 uži pojam |
210 |
|
code_arr => sub { @{$l->{$_[0]}} }, |
211 |
|
filter_code => sub { shift }, |
212 |
|
lookup_v900 => sub { |
213 |
|
my ($c,$p) = @_; |
214 |
|
$p =~ s/^a:(..:....):.*$/$1/; |
215 |
|
return "a:".$p.":".$c; |
216 |
|
}, |
217 |
|
lookup_term => sub { shift @{$l->{"d:".$_[0]}} }, |
218 |
|
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[0]}} }, |
219 |
|
have_children => sub { defined($l->{$_[1]}) }, |
220 |
|
child_code => sub { return $_[1] }, |
221 |
|
},{ |
222 |
|
# 4 |
223 |
|
code_arr => sub { @{$l->{$_[0]}} }, |
224 |
|
filter_code => sub { shift }, |
225 |
|
lookup_v900 => sub { |
226 |
|
my ($c,$p) = @_; |
227 |
|
$p =~ s/^a:(..:....):.*$/$1/; |
228 |
|
return "a:".$p.":".$c; |
229 |
|
}, |
230 |
|
lookup_term => sub { shift @{$l->{"d:".$_[0]}} }, |
231 |
|
lookup_mfn => sub { shift @{$l->{"900_mfn:".$_[0]}} }, |
232 |
|
# have_children => sub { defined($l->{$_[1]}) }, |
233 |
|
# child_code => sub { return $_[1] }, |
234 |
have_children => sub { 0 }, |
have_children => sub { 0 }, |
235 |
child_code => sub { 0 }, |
child_code => sub { 0 }, |
|
|
|
236 |
}); |
}); |
237 |
|
|
238 |
unroll(0,''); |
unroll(0,''); |
255 |
|
|
256 |
$log->debug("# $level filter passed code $code"); |
$log->debug("# $level filter passed code $code"); |
257 |
|
|
258 |
my $v900 = $tree[$level]->{'lookup_v900'}->($code) || $log->logdie("can't lookup_v900 '$code'"); |
my $v900 = $tree[$level]->{'lookup_v900'}->($code,$start_code) || $log->warn("can't lookup_v900($code,$start_code)"); |
259 |
$log->debug("# $level lookup_v900($code) = $v900"); |
$log->debug("# $level lookup_v900($code,$start_code) = $v900"); |
260 |
my $term = $tree[$level]->{'lookup_term'}->($code,$v900) || $log->logdie("can't lookup_term '$v900'"); |
|
261 |
|
my $term = $tree[$level]->{'lookup_term'}->($code,$v900) || $log->warn("can't lookup_term($code,$v900)"); |
262 |
$log->debug("# $level lookup_term($code,$v900) = $term"); |
$log->debug("# $level lookup_term($code,$v900) = $term"); |
263 |
my $mfn = $tree[$level]->{'lookup_mfn'}->($code,$v900) || $log->logdie("can't lookup_mfn '$v900'"); |
|
264 |
|
my $mfn = $tree[$level]->{'lookup_mfn'}->($code,$v900) || $log->warn("can't lookup_mfn($code,$v900)"); |
265 |
$log->debug("# $level lookup_mfn($code,$v900) = $mfn"); |
$log->debug("# $level lookup_mfn($code,$v900) = $mfn"); |
266 |
|
|
267 |
$log->debug("$code -> $v900 : $term [$mfn]"); |
$log->debug("$code -> $v900 : $term [$mfn]"); |
268 |
|
|
269 |
print HTML " " x $level . |
my ($link_start,$link_end) = ('',''); |
270 |
qq{<li><a href="#mfn$mfn" onClick="return hide_show('mfn$mfn');">$term</a> <a href="thes/$mfn.html">»</a></li>\n} if (-e "out/thes/$mfn.html"); |
|
271 |
|
my $have_children = $tree[$level]->{'have_children'}->($code,$v900,$start_code); |
272 |
|
if ($have_children) { |
273 |
|
($link_start,$link_end) = (qq{<a href="#mfn$mfn" onClick="return hide_show('mfn$mfn');">},qq{</a>}); |
274 |
|
} else { |
275 |
|
$log->debug("# $level doesn't have_children($code,$v900,$start_code)"); |
276 |
|
} |
277 |
|
|
278 |
unless ($tree[$level]->{'have_children'}->($code,$v900)) { |
$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)); |
279 |
$log->warn("can't find children of $code at level $level"); |
|
280 |
|
my $mfn_link = "thes/$mfn.html"; |
281 |
|
if (-e "out/$mfn_link") { |
282 |
|
print HTML " " x $level . |
283 |
|
qq{<li>${link_start}${term}${link_end}}. |
284 |
|
qq{ <a href="$mfn_link">»</a></li>\n}; |
285 |
|
} else { |
286 |
|
$log->warn("file 'out/$mfn_link' doesn't exist, skipping"); |
287 |
|
} |
288 |
|
|
289 |
|
unless ($have_children) { |
290 |
next; |
next; |
291 |
} |
} |
292 |
|
|
295 |
($tree[$level]->{'style'} ? ' style="'.$tree[$level]->{'style'}.'"' : ''). |
($tree[$level]->{'style'} ? ' style="'.$tree[$level]->{'style'}.'"' : ''). |
296 |
qq{>\n}; |
qq{>\n}; |
297 |
|
|
298 |
unroll($level+1, $tree[$level]->{'child_code'}->($code,$v900)); |
unroll($level+1, $tree[$level]->{'child_code'}->($code,$v900,$start_code)); |
299 |
|
|
300 |
print HTML " " x $level . qq{</ul>\n}; |
print HTML " " x $level . qq{</ul>\n}; |
301 |
|
|
309 |
</html> |
</html> |
310 |
}; |
}; |
311 |
|
|
312 |
|
close(HTML); |
313 |
|
|
314 |
$index->close; |
$index->close; |
315 |
|
|
316 |
$log->info("elapsed time: ",$webpac->fmt_time(time() - $webpac->{'start_t'})); |
$log->info("elapsed time: ",$webpac->fmt_time(time() - $webpac->{'start_t'})); |