--- deliantra/Deliantra-Client/bin/pod2wiki 2006/08/14 14:35:31 1.7
+++ deliantra/Deliantra-Client/bin/pod2wiki 2008/03/25 02:12:36 1.12
@@ -39,19 +39,36 @@
$_
}
+sub special {
+ $MA_BEG . (join $MA_SEP, @_) . $MA_END
+}
+
package AsParagraphs;
use strict;
use base "Pod::POM::View";
+# nodes (order must stay as it is)
+sub N_PARENT (){ 0 }
+sub N_PAR (){ 1 }
+sub N_LEVEL (){ 2 }
+sub N_KW (){ 3 }
+sub N_DOC (){ 4 }
+
+# paragraphs (order must stay as it is)
+sub P_INDENT (){ 0 }
+sub P_LEVEL (){ 1 }
+sub P_MARKUP (){ 2 }
+sub P_INDEX (){ 3 }
+
*view_seq_file =
*view_seq_code =
*view_seq_bold = sub { "$_[1]" };
*view_seq_italic = sub { "$_[1]" };
*view_seq_zero = sub { };
*view_seq_space = sub { my $text = $_[1]; $text =~ s/ / /g; $text };
-*view_seq_index = sub { push @{ $result[-1]{index} }, $_[1]; "" };
+*view_seq_index = sub { push @{ $result[-1][P_INDEX] }, $_[1]; "" };
sub view_seq_text {
my $text = $_[1];
@@ -70,77 +87,47 @@
my $path = $1;
(my $base = $path) =~ s/.*\///;
-f "$ARCH/$path" && system "rsync -av -c \Q$ARCH/$path\E \Qresources/arch/$base";
- "${MA_BEG}image${MA_SEP}arch/$base$MA_END"
+ ::special image => "arch/$base", 1;
} else {
- "${MA_BEG}link$MA_SEP$text$MA_SEP$link$MA_END"
+ ::special link => $text, $link
}
}
-sub view_item {
- push @result, {
- indent => $indent * 8,
- level => $level,
- };
- my $title = $_[1]->title->present ($_[0]);
- $result[-1]{markup} = "$title\n\n" if length $title;
- $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title;
- local $level = $level + 1;
- $_[1]->content->present ($_[0]);
- ()
-}
-
sub view_verbatim {
- push @result, {
- indent => $indent * 16,
- level => $level,
- markup => "" . (::asxml $_[1]) . "\n",
- };
+ push @result, [ $indent * 16, $level, "" . (::asxml $_[1]) . "\n" ];
()
}
sub view_textblock {
- push @result, {
- indent => $indent * 16,
- level => $level,
- markup => "$_[1]\n",
- };
+ push @result, [ $indent * 16, $level, "$_[1]\n" ];
()
}
sub view_head1 {
- push @result, {
- indent => $indent * 16,
- level => $level,
- };
+ push @result, [ $indent * 16, $level ];
my $title = $_[1]->title->present ($_[0]);
- $result[-1]{markup} = "\n\n$title\n" if length $title;
- $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title;
+ $result[-1][P_MARKUP] = "\n\n$title\n" if length $title;
+ $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
local $level = $level + 1;
$_[1]->content->present ($_[0]);
()
};
sub view_head2 {
- push @result, {
- indent => $indent * 16,
- level => $level,
- };
+ push @result, [ $indent * 16, $level ];
my $title = $_[1]->title->present ($_[0]);
- $result[-1]{markup} = "\n\n$title\n" if length $title;
- $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title;
+ $result[-1][P_MARKUP] = "\n\n$title\n" if length $title;
+ $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
local $level = $level + 1;
$_[1]->content->present ($_[0]);
()
};
sub view_head3 {
- push @result, {
- indent => $indent * 16,
- level => $level,
- };
+ push @result, [ $indent * 16, $level ];
my $title = $_[1]->title->present ($_[0]);
- $result[-1]{markup} = "\n\n$title\n" if length $title;
- $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title;
+ $result[-1][P_MARKUP] = "\n\n$title\n" if length $title;
+ $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
local $level = $level + 1;
$_[1]->content->present ($_[0]);
()
@@ -148,22 +135,36 @@
sub view_over {
local $indent = $indent + $_[1]->indent;
- push @result, { indent => $indent };
+ push @result, [ $indent, $level ];
+ $_[1]->content->present ($_[0]);
+ ()
+}
+
+sub view_item {
+ push @result, [ $indent * 8, $level ];
+ my $title = $_[1]->title->present ($_[0]);
+ $result[-1][P_MARKUP] = "$title\n" if length $title;
+ $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
+ local $level = $level + 1;
$_[1]->content->present ($_[0]);
()
}
sub view_for {
if ($_[1]->format eq "image") {
- push @result, {
- indent => $indent * 16,
- level => $level,
- markup => "${MA_BEG}image${MA_SEP}pod/" . $_->text . $MA_END,
- };
+ push @result, [
+ $indent * 16,
+ $level,
+ (::special image => "pod/" . $_->text),
+ ];
}
()
}
+sub view_begin {
+ ()
+}
+
sub view {
my ($self, $type, $item) = @_;
@@ -176,12 +177,12 @@
my ($pom) = @_;
local $indent = 0;
- local $level = 1;
- local @result = ( { } );
+ local $level = 2;
+ local @result = ( [] );
$pom->present ("AsParagraphs");
- [grep $_->{index} || exists $_->{markup}, @result]
+ [grep $_->[P_INDEX] || defined $_->[P_MARKUP], @result]
}
#############################################################################
@@ -191,14 +192,13 @@
sub add_node($) {
my ($node) = @_;
- for (@{ $node->{kw} || {} }) {
+ for (@{ $node->[N_KW] || {} }) {
push @{$wiki{lc $_}}, $node;
}
}
-my $root = {
- kw => ["pod"],
-};
+my $root;
+$root->[N_KW] = ["pod"];
for my $path (@ARGV) {
$path =~ /([^\/\\]+)\.pod$/ or die "$path: illegal pathname";
@@ -212,26 +212,30 @@
my $para = as_paragraphs $pom;
- my @parent = (
- { parent => $root, kw => [$base], doc => $para, par => 0, level => 0 },
- );
+ my $pod;
+ $pod->[N_PARENT] = $root;
+ $pod->[N_PAR] = 0;
+ $pod->[N_LEVEL] = 1;
+ $pod->[N_KW] = [$base];
+ $pod->[N_DOC] = $para;
+
+ my @parent = ($pod);
add_node $parent[-1];
for my $idx (0 .. $#$para) {
my $par = $para->[$idx];
- while ($parent[-1]{level} >= $par->{level}) {
+ while ($parent[-1][N_LEVEL] >= $par->[P_LEVEL]) {
pop @parent;
}
- if ($par->{index}) {
- my $node = {
- kw => $par->{index},
- parent => $parent[-1],
- doc => $para,
- par => $idx,
- level => $par->{level},
- };
+ if ($par->[P_INDEX]) {
+ my $node;
+ $node->[N_PARENT] = $parent[-1];
+ $node->[N_PAR] = $idx;
+ $node->[N_LEVEL] = $par->[P_LEVEL];
+ $node->[N_KW] = $par->[P_INDEX];
+ $node->[N_DOC] = $para;
push @parent, $node;
add_node $node;
}