/[pub]/suikawiki/script/wiki.cgi
Suika

Diff of /suikawiki/script/wiki.cgi

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

revision 1.31 by wakaba, Thu Nov 14 10:22:19 2002 UTC revision 1.34 by wakaba, Wed Dec 4 12:00:42 2002 UTC
# Line 26  use Yuki::DiffText qw(difftext); Line 26  use Yuki::DiffText qw(difftext);
26  use Yuki::YukiWikiDB;  use Yuki::YukiWikiDB;
27  use AnyDBM_File;  use AnyDBM_File;
28  require 'jcode.pl';  require 'jcode.pl';
29  # use Jcode;  require Jcode;
30  use Fcntl;  use Fcntl;
31  my $version = '2.0.beta1.2002-05-29';  my $version = '2.0.beta1.2002-05-29';
32  my $walversion;  my $walversion;
# Line 97  my $DEFAULT_embed_comment_name = '名無し Line 97  my $DEFAULT_embed_comment_name = '名無し
97  my $embed_interwiki = '^\[\[#(box|text|password):(\S+)\]\]$';    # Walrus add (5)  my $embed_interwiki = '^\[\[#(box|text|password):(\S+)\]\]$';    # Walrus add (5)
98  my %embed_command = (  my %embed_command = (
99          searched        => '^\[\[#searched:([^\]]+)\]\]$',          searched        => '^\[\[#searched:([^\]]+)\]\]$',
100        form => qw/\[\[\#form(?:\(([A-Za-z0-9-]+)\))?:'((?:[^'\\]|\\.)*)':'((?:[^'\\]|\\.)*)'(?::'((?:[^'\\]|\\.)*)')?\]\]/,
101  );  );
102  ##############################  ##############################
103  my $info_LastModified = 'LastModified';  my $info_LastModified = 'LastModified';
# Line 116  my %fixedpage = ( Line 117  my %fixedpage = (
117      $AdminChangePassword => 1,      $AdminChangePassword => 1,
118      $CompletedSuccessfully => 1,      $CompletedSuccessfully => 1,
119      #$FrontPage => 1,      #$FrontPage => 1,
120        WikiUserAgentList => 1,
121  );  );
122  my %form;  my %form;
123  my %database;  my %database;
# Line 151  my %command_do = ( Line 153  my %command_do = (
153      rss => \&do_rss,      rss => \&do_rss,
154      diff => \&do_diff,      diff => \&do_diff,
155      interwikibox => \&do_interwiki_box, # Walrus add (5)      interwikibox => \&do_interwiki_box, # Walrus add (5)
156        wikiform => \&do_wikiform,
157  );  );
158  ##############################  ##############################
 my @ignore_html_page = ('FrontPage');        # Walrus add (6)  
 my @ignore_html_tags = ('a', 'br', 'img');   # Walrus add (6)  
159  my $walversion = '2.0.beta1.wal.1';          # Walrus add (1)  my $walversion = '2.0.beta1.wal.1';          # Walrus add (1)
160  ##############################  ##############################
161  # &test_convert;  # &test_convert;
162    my $UA = '';  ## User agent name
163  &main;  &main;
164  exit(0);  exit(0);
165  ##############################  ##############################
166    
167  sub main {  sub main {
168        $UA = $main::ENV{HTTP_USER_AGENT};
169      &init_resource;      &init_resource;
170      &open_db;      &open_db;
171      &init_form;      &init_form;
# Line 179  sub do_read { Line 182  sub do_read {
182    my $content = $database{$form{mypage}};    my $content = $database{$form{mypage}};
183    my $lm = &get_info($form{mypage}, $info_LastModified);    my $lm = &get_info($form{mypage}, $info_LastModified);
184    wiki::referer::add ($form{mypage}, $ENV{HTTP_REFERER});    wiki::referer::add ($form{mypage}, $ENV{HTTP_REFERER});
185      wiki::useragent::add ($ENV{HTTP_USER_AGENT});
186    my ($r, $c) = get_search_result ($form{mypage});    my ($r, $c) = get_search_result ($form{mypage});
187    my $rl = wiki::referer::list_html ($form{mypage});    my $rl = wiki::referer::list_html ($form{mypage});
188    my @toc;    my @toc;
# Line 189  sub do_read { Line 193  sub do_read {
193      ## - 'SuikaWiki/0.9' CRLF      ## - 'SuikaWiki/0.9' CRLF
194      ## - 'H2H/' ("0.9" / "1.0" / "1.1") CRLF      ## - 'H2H/' ("0.9" / "1.0" / "1.1") CRLF
195      ## - "/*" WSP* 'W3C-CSS/' ("1.0" / "2.0") "*/" CRLF      ## - "/*" WSP* 'W3C-CSS/' ("1.0" / "2.0") "*/" CRLF
196      $cf = $1 if $content =~ s#^(?:/\*\s*|[\#<]\?)?([A-Z][A-Za-z0-9-]+/[0-9.]+(?:[^0-9.][^\x0D\x0A]*)?)[\x0D\x0A]+##s;      $cf = $1 if $content =~ s#^(?:/\*\s*|[\#<]\?)?([A-Z][A-Za-z0-9-]+/[0-9.]+(?:[^0-9.\x0D\x0A][^\x0D\x0A]*)?)[\x0D\x0A]+##s;
197      if ($cf =~ m!^(?:\#\?)?SuikaWiki/0.9(?:$|\s)!) {      if ($cf =~ m!^(?:\#\?)?SuikaWiki/0.9(?:$|\s)!) {
198        &print_header ($form{mypage}, -last_modified => $lm,        &print_header ($form{mypage}, -last_modified => $lm,
199          -content_format => $cf, -noindex => $cf =~ /obsoleted="yes"/);          -content_format => $cf, -noindex => $cf =~ /obsoleted="yes"/);
200        &print_content ($content, content_format => $cf, last_modified => $lm,        &print_content ($content, content_format => $cf, last_modified => $lm,
201          -toc => \@toc);          -toc => \@toc);
202        print &text_to_html (q([[#comment]])) unless $cf =~ /obsoleted="yes"/;        print &text_to_html (q([[#comment]])) if $cf !~ /obsoleted="yes"/ && !$fixedpage{$form{mypage}};
203      } else {      } else {
204        &print_header($form{mypage}, -last_modified => $lm);        &print_header($form{mypage}, -last_modified => $lm);
205        print "<pre>@{[&escape($content)]}</pre>";        print "<pre>@{[&escape($content)]}</pre>";
206      }      }
207      if ($c) {      if ($c) {
208        print q{<h2 id="wikipage-see-also">See also</h2>};        print qq{<h2 @{[&id_and_name('wikipage-see-also')]}>See also</h2>};
209        print $r;        print $r;
210      }      }
211      if ($rl) {      if ($rl) {
212        print qq(<div id="wikipage-referer"><h2>参照元</h2>\n$rl</div>\n);        print qq(<div @{[&id_and_name('wikipage-referer')]}><h2>参照元</h2>\n$rl</div>\n);
213      }      }
214    &print_footer($form{mypage}, $lm);    &print_footer($form{mypage}, $lm);
215  }  }
# Line 226  sub do_output_css { Line 230  sub do_output_css {
230    }    }
231  }  }
232    
233    sub id_and_name ($) {
234        my $name = shift;
235        if ($UA =~ m#Mozilla/[12]\.#) {
236          qq{id="$name"><a name="$name"></a};
237        } else {
238            qq{id="$name"};
239        }
240    }
241    
242  sub do_edit {  sub do_edit {
243      my ($page) = &unarmor_name(&armor_name($form{mypage}));      my ($page) = &unarmor_name(&armor_name($form{mypage}));
244      &print_header($page, -noindex => 1);      &print_header($page, -noindex => 1);
# Line 237  sub do_edit { Line 250  sub do_edit {
250          &print_editform($database{$page}, &get_info($page, $info_LastModified), admin=>0);          &print_editform($database{$page}, &get_info($page, $info_LastModified), admin=>0);
251      }      }
252      wiki::referer::add ($form{mypage}, $ENV{HTTP_REFERER});      wiki::referer::add ($form{mypage}, $ENV{HTTP_REFERER});
253        wiki::useragent::add ($ENV{HTTP_USER_AGENT});
254      my ($r, $c) = get_search_result ($form{mypage});      my ($r, $c) = get_search_result ($form{mypage});
255      my $rl = wiki::referer::list_html ($form{mypage});      my $rl = wiki::referer::list_html ($form{mypage});
256      if ($c) {      if ($c) {
# Line 341  sub do_write { Line 355  sub do_write {
355              &update_recent_changes;              &update_recent_changes;
356          }          }
357          &set_info($form{mypage}, $info_IsFrozen, 0 + $form{myfrozen});          &set_info($form{mypage}, $info_IsFrozen, 0 + $form{myfrozen});
358          &print_header($CompletedSuccessfully, -noindex => 1, -goto => $url_cgi.'?'.&encode($form{mypage}).($form{__comment_anchor_index}?"#anchor-$form{__comment_anchor_index}":''));          my $fragment;
359            if ($form{__comment_anchor_index}) {
360                $fragment = qq(anchor-$form{__comment_anchor_index});
361            } elsif ($form{__wikiform_anchor_index}) {
362                $fragment = qq(wikiform-$form{__wikiform_anchor_index});
363            }
364            &print_header($CompletedSuccessfully, -noindex => 1, -goto => $url_cgi.'?mycmd=read;mypage='.&encode($form{mypage}).qq(;x-param=@{[time.[0..9]->[rand 10]]}).($fragment?'#'.$fragment:''));
365          &print_message($resource{saved});          &print_message($resource{saved});
366          &print_content("$resource{continuereading} @{[&armor_name($form{mypage})]}");          &print_content("$resource{continuereading} @{[&armor_name($form{mypage})]}");
367          &print_footer($CompletedSuccessfully);          &print_footer($CompletedSuccessfully);
# Line 373  sub do_search { Line 393  sub do_search {
393  }  }
394    
395  sub get_search_result ($;%) {  sub get_search_result ($;%) {
396    my $word = shift;    my $word = lc shift;
397    my %option = @_;    my %option = @_;
398    my @r;    my @r;
399    foreach my $page (keys %database) {    foreach my $page (keys %database) {
# Line 382  sub get_search_result ($;%) { Line 402  sub get_search_result ($;%) {
402      my $cf = 'SuikaWiki/0.9';      my $cf = 'SuikaWiki/0.9';
403      $cf = $1 if $content =~ s/^\#\?([^\x0A\x0D]+)//s;      $cf = $1 if $content =~ s/^\#\?([^\x0A\x0D]+)//s;
404      next if $cf =~ /obsoleted="yes"/;      next if $cf =~ /obsoleted="yes"/;
405      if (index ($page, $word) > -1) {      if (index (lc $page, $word) > -1) {
406        my $c = $content =~ s/\Q$word\E/$word/g;        my $c = $content =~ s/\Q$word\E//gi;
407        push @r, [$page, $c+20];        push @r, [$page, $c+20];
408      } elsif (index ($word, $page) > -1) {      } elsif (index ($word, lc $page) > -1) {
409        my $c = $content =~ s/\Q$word\E/$word/g;        my $c = $content =~ s/\Q$word\E//gi;
410        push @r, [$page, $c+10];        push @r, [$page, $c+10];
411      } elsif (my $c = $content =~ s/\Q$word\E/$word/g) {      } elsif (my $c = $content =~ s/\Q$word\E//gi) {
412        push @r, [$page, $c];        push @r, [$page, $c];
413      }      }
414    }    }
415    my $em = sub { my $s = shift; $s =~ s#(\Q$word\E)#<em>$1</em>#g; $s };    my $em = sub { my $s = shift; $s =~ s#(\Q$word\E)#<em>$1</em>#gi; $s };
416    my $r = join "\n", map {qq(<li>[$_->[1]] <a href ="$url_cgi?@{[&encode($_->[0])]}" class="wiki">@{[&$em(&escape($_->[0]))]}</a> <span class="wikipage-summary">@{[&$em(&escape(&get_subjectline($_->[0])))]}</span></li>)} sort {$b->[1] <=> $a->[1] || $a->[0] cmp $b->[0]} @r;    my $r = join "\n", map {qq(<li>[$_->[1]] <a href ="$url_cgi?@{[&encode($_->[0])]}" class="wiki">@{[&$em(&escape($_->[0]))]}</a> <span class="wikipage-summary">@{[&$em(&escape(&get_subjectline($_->[0])))]}</span></li>)} sort {$b->[1] <=> $a->[1] || $a->[0] cmp $b->[0]} @r;
417    $r = qq|<ul class="search-result">$r</ul>| if $r;    $r = qq|<ul class="search-result">$r</ul>| if $r;
418    get_message ($resource{notfound}) if @r == 0 && $option{-output_not_found};    get_message ($resource{notfound}) if @r == 0 && $option{-output_not_found};
# Line 446  sub print_header ($;%) { Line 466  sub print_header ($;%) {
466          $bodyclass = "frozen";          $bodyclass = "frozen";
467      }      }
468      $bodyclass .= " wiki-page-obsoleted" if $option{-content_format} =~ /obsoleted="yes"/;      $bodyclass .= " wiki-page-obsoleted" if $option{-content_format} =~ /obsoleted="yes"/;
469      print qq{Refresh: 0; url="$option{-goto}"\n} if $option{-goto};      if ($option{-goto}) {
470          if ($UA =~ m#Mozilla/[12]\.|Opera#) {
471              $option{-goto} =~ tr/;/&/;
472              print qq{Refresh: 0; url=$option{-goto}\n};
473              $option{-goto} = qq(<meta http-equiv="refresh" content="0; url=$option{-goto}">);
474          } else {
475              print qq{Refresh: 0; url="$option{-goto}"\n};
476              $option{-goto} = qq(<meta http-equiv="refresh" content="0; url=&quot;@{[&escape($option{-goto})]}&quot;">);
477          }
478        }
479      print qq{Last-Modified: $option{-last_modified}\n} if $option{-last_modified};      print qq{Last-Modified: $option{-last_modified}\n} if $option{-last_modified};
480        my $meta_ct = '';
481        if ($UA =~ m#Mozilla/2#) {
482            $meta_ct = qq{text/html; charset=@{[&x_charset($charset)]}};
483            print qq{Content-Type: $meta_ct\n};
484            $meta_ct = qq{<meta http-equiv="content-type" content="$meta_ct">};
485        } else {
486            print qq{Content-Type: text/html; charset=$charset\n};
487        }
488      my $cookedpage = &encode($page);      my $cookedpage = &encode($page);
489      my $escapedpage = &escape($page);      my $escapedpage = &escape($page);
490      print <<"EOD";      print <<"EOD";
 Content-type: text/html; charset=$charset  
491  Content-Language: $lang  Content-Language: $lang
492  Content-Style-Type: text/css  Content-Style-Type: text/css
493    
# Line 461  Content-Style-Type: text/css Line 497  Content-Style-Type: text/css
497      "http://www.w3.org/TR/html4/loose.dtd"> + RUBY -->      "http://www.w3.org/TR/html4/loose.dtd"> + RUBY -->
498  <html lang="$lang">  <html lang="$lang">
499  <head>  <head>
500        $meta_ct$option{-goto}
501      <title>$escapedpage</title>      <title>$escapedpage</title>
502      <link rel="index" href="$url_cgi?$IndexPage">      <link rel="index" href="$url_cgi?$IndexPage">
503      <link rel="help" href="$url_cgi?WikiHelp">      <link rel="help" href="$url_cgi?WikiHelp">
# Line 476  EOD Line 513  EOD
513  EOD  EOD
514  }  }
515    
516    sub x_charset ($) {
517        my $charset = lc shift;
518        if ($charset eq 'euc-jp') {
519            $charset = 'x-euc-jp';
520        } elsif ($charset eq 'shift_jis') {
521            $charset = 'x-sjis';
522        }
523        $charset;
524    }
525    
526  sub print_navigate_links (@) {  sub print_navigate_links (@) {
527    my ($page) = @_;    my ($page) = @_;
528      my $editable = 0;      my $editable = 0;
# Line 501  sub print_navigate_links (@) { Line 548  sub print_navigate_links (@) {
548          qq(<a title="$resource{editthispage}" href="$url_cgi?mycmd=edit;mypage=$cookedpage" accesskey="E">編集</a> | )          qq(<a title="$resource{editthispage}" href="$url_cgi?mycmd=edit;mypage=$cookedpage" accesskey="E">編集</a> | )
549          : qq()          : qq()
550      ]}      ]}
551        <a href="$url_cgi?mycmd=read;mypage=$cookedpage;x-param=@{[time.[0..9]->[rand 10]]}">表示</a> |
552      @{[ $admineditable      @{[ $admineditable
553          ? qq(<a href="$url_cgi?mycmd=diff;mypage=$cookedpage">$resource{diffbutton}</a> | )          ? qq(<a href="$url_cgi?mycmd=diff;mypage=$cookedpage">$resource{diffbutton}</a> | )
554          : qq()          : qq()
# Line 527  EOH Line 575  EOH
575    
576  sub print_footer {  sub print_footer {
577      my ($page, $lm) = @_;      my ($page, $lm) = @_;
578        my $epage = &encode ($page);
579      $walrus_log = ($walrus_debugging) ? &text_to_html("----\n$walrus_log") : '';    # Walrus add (debug)      $walrus_log = ($walrus_debugging) ? &text_to_html("----\n$walrus_log") : '';    # Walrus add (debug)
580      # Walrus mod (1) start      # Walrus mod (1) start
581    my $cvslog1 = q$Revision$;    my $cvslog1 = q$Revision$;
# Line 542  sub print_footer { Line 591  sub print_footer {
591  <a href="/map" title="このサーバーの案内">地図</a>  <a href="/map" title="このサーバーの案内">地図</a>
592  <a href="/search/" title="このサーバーの検索">検索</a>]  <a href="/search/" title="このサーバーの検索">検索</a>]
593  </div>  </div>
594    <div class="myuri">
595        &lt;<a href="$url_cgi?$epage">$url_cgi?$epage</a>&gt;
596    </div>
597  </div>  </div>
598  $walrus_log  $walrus_log
599  </body>  </body>
600  </html>  </html>
601  EOD  EOD
 #       print <<"EOD";  
 #   <hr>  
 #   <address class="footer">  
 #       <a href="http://www.hyuki.com/yukiwiki/">YukiWiki</a> $version  
 #       &copy; 2000-2002 by <a href="http://www.hyuki.com/">Hiroshi Yuki</a>.<br />  
 #       Modified by <a href="$modifier_url">$modifier_name</a>.  
 #   </address>  
 #   <p class="footer">  
 #       <a href="http://www.hyuki.com/yukiwiki/">$icontag</a>  
 #   </p>  
 #   </body>  
 #   </html>  
 #   EOD  
     # Walrus mod (1) end  
602  }  }
603    
604  sub escape {  sub escape {
# Line 727  sub back_push { Line 765  sub back_push {
765  sub inline {  sub inline {
766      my ($line) = @_;      my ($line) = @_;
767      $line = &escape($line);      $line = &escape($line);
768      $line =~ s{\[(INS|DEL|SUP|SUB|VAR|CODE|KBD)(?:\(([A-Za-z0-9\x20-]+)\))?\[(.+?)\]\]}{<@{[lc $1]}@{[$2 ? qq( class="$2") : '']}>$3</@{[lc $1]}>}g;      $line =~ s{$embed_command{form}}{&make_custom_form ($1, $2, $3, $4)}ge;
769        $line =~ s{\[(INS|DEL|SUP|SUB|VAR|CODE|KBD|SAMP|DFN)(?:\(([A-Za-z0-9\x20-]+)\))?\[(.+?)\]\]}{<@{[lc $1]}@{[$2 ? qq( class="$2") : '']}>$3</@{[lc $1]}>}g;
770      $line =~ s:\[(WEAK)\[(.+?)\]\]:<span class="@{[lc $1]}">$2</span>:g;      $line =~ s:\[(WEAK)\[(.+?)\]\]:<span class="@{[lc $1]}">$2</span>:g;
771      $line =~ s:\[ABBR\[([^]]+)\] \[([^]]+)\]\]:<acronym title="$2">$1</acronym>:g;      $line =~ s:\[ABBR\[([^]]+)\] \[([^]]+)\]\]:<acronym title="$2">$1</acronym>:g;
772      $line =~ s:\[RUBYB\[([^]]+)\] \[([^]]+)\] \[([^]]+)\]\]:<span class="ruby"><ruby class="rb"><rb>$1</rb><rp>(</rp><rt>$2</rt><rp>)</rp></ruby><span class="rp"> (</span><span class="rt-below">$3</span><span class="rp">) </span></span>:g;      $line =~ s:\[RUBYB\[([^]]+)\] \[([^]]+)\] \[([^]]+)\]\]:<span class="ruby"><ruby class="rb"><rb>$1</rb><rp>(</rp><rt>$2</rt><rp>)</rp></ruby><span class="rp"> (</span><span class="rt-below">$3</span><span class="rp">) </span></span>:g;
# Line 784  sub make_urilink ($;%) { Line 823  sub make_urilink ($;%) {
823        if ($interwiki{$site}) {        if ($interwiki{$site}) {
824          my $uri = &escape ($fmt{interwiki}->replace ($interwiki{$site} => {site => $site, name => $name}));          my $uri = &escape ($fmt{interwiki}->replace ($interwiki{$site} => {site => $site, name => $name}));
825          $site = &escape ($site); $name = &escape ($name);          $site = &escape ($site); $name = &escape ($name);
826          qq(&lt;<a href="$uri" class="out-of-wiki interwiki" title="$name ($site); URI: &lt;$uri&gt;">$name</a>&gt;);          qq(&lt;<a href="$uri" class="out-of-wiki interwiki" title="$name ($site); URI: &lt;$uri&gt;"><span class="interwiki-site">$site:</span><span class="interwiki-name">$name</span></a>&gt;);
827        } else {        } else {
828          qq(&lt;未登録の <a href="$url_cgi?InterWikiName" class="wiki">InterWikiName</a>: @{[&escape ($site)]}>);          qq(&lt;未登録の <a href="$url_cgi?InterWikiName" class="wiki">InterWikiName</a>: @{[&escape ($site)]}>);
829        }        }
# Line 808  sub make_urilink ($;%) { Line 847  sub make_urilink ($;%) {
847    }    }
848  }  }
849    
850    my $FormIndex = 0;
851    sub make_custom_form ($$$) {
852        my ($wfname, $definition, $template, $option) = @_;
853        ## $template and $option is currently not used in this procedure.
854        unless ($main::_EMBEDED) {
855            $FormIndex++;
856            if (length $definition) {
857                my $param = bless {}, 'SuikaWiki::Plugin';
858                my $lastmodified = &get_info($form{mypage}, $info_LastModified);
859                $definition =~ s/\\(.)/$1/g;
860                $definition .= ' %submit;' if $definition !~ /%submit/;
861                unless ($fmt{form_option}) {
862                    $fmt{form_option} = Message::Util::Formatter->new;
863                    for (@{$SuikaWiki::Plugin::List{wikiform_option}||[]}) {
864                        $_->load_formatter ($fmt{form_option}, type => 'wikiform_option');
865                    }
866                }
867                $option = &unescape ($option);
868                $option =~ s/\\(.)/$1/g;
869                $fmt{form_option}->replace ($option, $param);
870                my $target_form = $param->{output}->{id};
871                my $r = <<EOH;
872    <form method="post" action="$url_cgi" id="wikiform-$FormIndex" class="wikiform">
873      <input type="hidden" name="mycmd" value="wikiform">
874      <input type="hidden" name="mypage" value="@{[&escape($form{mypage})]}">
875      <input type="hidden" name="myLastModified" value="$lastmodified">
876      <input type="hidden" name="mytouch" value="on">
877      <input type="hidden" name="@{[$target_form? qq(wikiform_targetform" value="@{[&escape($target_form)]}) : qq(wikiform_index" value="$FormIndex)]}">
878    EOH
879                $r .= qq(<a name="wikiform-$FormIndex"></a>) if $UA =~ m#Mozilla/[12]\.#;
880                $r .= $fmt{form_input}->replace (&unescape ($definition), $param);
881                $r .= <<EOH;
882    </form>
883    EOH
884                $r;
885           } else {  ## No input-interface WikiForm
886               qq(<a id="wikiform-$FormIndex" name="wikiform-$FormIndex"><!-- #form --></a>);
887           }
888        } else {
889            q(<ins class="wiki-error"><strong>Warning</strong>: form in embeded page is currently not supported.</ins>);
890        }
891    }
892    
893  ## to be obsoleted  ## to be obsoleted
894  sub make_link {  sub make_link {
895      my $chunk = shift;      my $chunk = shift;
# Line 851  sub init_form { Line 933  sub init_form {
933              $form{$var} = param($var);              $form{$var} = param($var);
934        }        }
935      }      }
936      if ($main::ENV{QUERY_STRING} && $main::ENV{QUERY_STRING} !~ /[&;]/) {      $form{mypage} = &code_convert(\$form{mypage}, $kanjicode);
937        if ($main::ENV{QUERY_STRING} && $main::ENV{QUERY_STRING} !~ /[&;=]/) {
938        my $query = &decode($main::ENV{QUERY_STRING});        my $query = &decode($main::ENV{QUERY_STRING});
939          $query = &code_convert(\$query, $kanjicode);
940        if ($page_command{$query}) {        if ($page_command{$query}) {
941          $form{mycmd} = $page_command{$query};          $form{mycmd} = $page_command{$query};
942          $form{mypage} = $query;          $form{mypage} = $query;
# Line 862  sub init_form { Line 946  sub init_form {
946        }        }
947      }      }
948      $form{mypage} ||= 'HomePage';      $form{mypage} ||= 'HomePage';
949        $form{mycmd} ||= 'read';
950    
951      # mypreview_edit        -> do_edit, with preview.      # mypreview_edit        -> do_edit, with preview.
952      # mypreview_adminedit   -> do_adminedit, with preview.      # mypreview_adminedit   -> do_adminedit, with preview.
# Line 877  sub init_form { Line 962  sub init_form {
962      # $form{mycmd} is frozen here.      # $form{mycmd} is frozen here.
963      #      #
964    
965        for (grep /^wikiform__/, keys %form) {
966            $form{$_} = &code_convert (\$form{$_}, $kanjicode);
967        }
968      $form{mymsg} = &code_convert(\$form{mymsg}, $kanjicode);      $form{mymsg} = &code_convert(\$form{mymsg}, $kanjicode);
969      $form{myname} = &code_convert(\$form{myname}, $kanjicode);      $form{myname} = &code_convert(\$form{myname}, $kanjicode);
970  }  }
# Line 884  sub init_form { Line 972  sub init_form {
972  sub update_recent_changes {  sub update_recent_changes {
973      my $update = "- @{[&get_now]} [[@{[&escape($form{mypage})]}]] @{[&get_subjectline($form{mypage})]}";      my $update = "- @{[&get_now]} [[@{[&escape($form{mypage})]}]] @{[&get_subjectline($form{mypage})]}";
974      my @oldupdates = split(/\r?\n/, $database{$RecentChanges});      my @oldupdates = split(/\r?\n/, $database{$RecentChanges});
975        shift (@oldupdates); ## '#?' magic line
976      my @updates;      my @updates;
977      foreach (@oldupdates) {      foreach (@oldupdates) {
978          /^\- \d\d\d\d\-\d\d\-\d\d \([^)]+\) \d\d:\d\d \[\[(\S+?)\]\]/;          /^\- \d\d\d\d\-\d\d\-\d\d \([^)]+\) \d\d:\d\d \[\[(\S+?)\]\]/;
# Line 896  sub update_recent_changes { Line 985  sub update_recent_changes {
985        unshift @updates, $update;        unshift @updates, $update;
986      }      }
987      splice(@updates, $maxrecent + 1);      splice(@updates, $maxrecent + 1);
988      $database{$RecentChanges} = join("\n", @updates);      $database{$RecentChanges} = "#?SuikaWiki/0.9\n" . join("\n", @updates);
989      if ($file_touch) {      if ($file_touch) {
990          open(FILE, "> $file_touch");          open(FILE, "> $file_touch");
991          print FILE localtime() . "\n";          print FILE localtime() . "\n";
# Line 1184  sub init_InterWikiName { Line 1273  sub init_InterWikiName {
1273    $fmt{interwiki}->{encoded} = sub {    $fmt{interwiki}->{encoded} = sub {
1274      my ($o, $p) = @_;      my ($o, $p) = @_;
1275      if ($o->{except}) {      if ($o->{except}) {
1276        $o->{except} =~ tr/\x00-\x20<>\x23%\x22{|}\x5C^[]`\x7F-\xFF//d;        $o->{except} =~ tr/\x00-\x20\x22\x23%\x2D<>^[\x5C]`{|}\x7F-\xFF//d;
1277      }      }
1278      my $s = &code_convert (\$p->{name}, $o->{charset} || 'iso-2022-7bit');      my $s = &code_convert (\$p->{name}, $o->{charset} || 'iso-2022-7bit');
1279      $s =~ s/([^$o->{except}A-Za-z0-9_-])/sprintf '%02X', unpack 'C', $1/ge;      $s =~ s/([^$o->{except}A-Za-z0-9_-])/sprintf '%%%02X', unpack 'C', $1/ge;
1280      $s;      $s;
1281    };    };
1282    $fmt{interwiki}->{ykwk} = sub {       ## YukiWiki1    $fmt{interwiki}->{ykwk} = sub {       ## YukiWiki1
# Line 1196  sub init_InterWikiName { Line 1285  sub init_InterWikiName {
1285      $s = qq([[$s]]) if $s !~ /^[A-Z][a-z]+(?:[A-Z][a-z]+)+$/;      $s = qq([[$s]]) if $s !~ /^[A-Z][a-z]+(?:[A-Z][a-z]+)+$/;
1286      &encode (&code_convert (\$p->{name}, $o->{charset} || 'shift_jis'));      &encode (&code_convert (\$p->{name}, $o->{charset} || 'shift_jis'));
1287    };    };
1288    
1289      $fmt{form_input} = Message::Util::Formatter->new;
1290      for (@{$SuikaWiki::Plugin::List{wikiform_input}||[]}) {
1291        $_->load_formatter ($fmt{form_input}, type => 'wikiform_input');
1292      }
1293  }  }
1294    
1295    
# Line 1262  sub do_comment { Line 1356  sub do_comment {
1356      } elsif (length $namestr) {      } elsif (length $namestr) {
1357        $namestr = qq( ''[[$namestr]]'': );        $namestr = qq( ''[[$namestr]]'': );
1358      }      }
1359      my $anchor = 0;      my $anchor = &get_new_anchor_index ($content);
     $content =~ s/(?:-+\s)?\[([0-9]+)\]/$anchor = $1 if $1 > $anchor; $&/mge;  
     $anchor++;  
1360      my $i = 1;  my $o = 0;      my $i = 1;  my $o = 0;
1361      $content =~ s{(\Q$embed_comment\E|\Q$embed_rcomment\E)}{      $content =~ s{(\Q$embed_comment\E|\Q$embed_rcomment\E)}{
1362        my $embed = $1;        my $embed = $1;
# Line 1293  sub do_comment { Line 1385  sub do_comment {
1385      }      }
1386  }  }
1387    
1388    sub get_new_anchor_index ($) {
1389        my $content = shift;
1390        my $anchor = 0;
1391        $content =~ s/^(?:[-=]+\s*)?\[([0-9]+)\]/$anchor = $1 if $1 > $anchor; $&/mge;
1392        $anchor + 1;
1393    }
1394    
1395  my $CommentIndex = 0;  my $CommentIndex = 0;
1396  sub embedded_to_html {  sub embedded_to_html {
1397      my ($embedded) = @_;      my ($embedded) = @_;
# Line 1356  EOD Line 1455  EOD
1455    }    }
1456  }  }
1457    
1458    sub do_wikiform {
1459        my $content = $database{$form{mypage}};
1460        my $anchor = &get_new_anchor_index ($content);
1461        for my $t (qw/form_template form_option/) {
1462            unless ($fmt{$t}) {
1463                $fmt{$t} = Message::Util::Formatter->new;
1464                for (@{$SuikaWiki::Plugin::List{'wiki'.$t}||[]}) {
1465                    $_->load_formatter ($fmt{$t}, type => 'wiki'.$t);
1466                }
1467            }
1468        }
1469        my $write = 0;
1470        my $i = 1;
1471        $content =~ s{$embed_command{form}}{
1472            my ($embed, $wfname, $template, $option) = ($&, $1, $3, $4);
1473            if (($wfname && $wfname eq $form{wikiform_targetform})
1474                || $i == $form{wikiform_index}) {
1475                $template =~ s/\\(.)/$1/g;
1476                $option =~ s/\\(.)/$1/g;
1477                my $param = bless {}, 'SuikaWiki::Plugin';
1478                $param->{page} = $form{mypage};
1479                $param->{form_index} = $i;
1480                $param->{form_name} = $wfname;
1481                $param->{anchor_index} = $anchor;
1482                $param->{argv} = \%form;
1483                $param->{default_name} = $1 if $content =~ /default-name="([^"]+)"/;
1484                $param->{default_name} ||= $DEFAULT_embed_comment_name;
1485                $fmt{form_option}->replace ($option, $param);
1486                my $t = 1;
1487                for (@{$param->{require}||[]}) {
1488                  (undef $t, last) unless length $param->{argv}->{'wikiform__'.$_};
1489                }
1490                $t = $fmt{form_template}->replace ($template, $param) if $t;
1491                if (length $t) {
1492                    if ($param->{output}->{reverse}) {
1493                        $embed .= "\n" . $t;
1494                    } else {
1495                        $embed = $t . "\n" . $embed;
1496                    }
1497                    $write = 1;
1498                    $form{__comment_anchor_index} = $anchor
1499                      if $param->{anchor_index_};  ## $anchor is used!
1500                }
1501                $form{__wikiform_anchor_index} = $i;
1502                undef $form{wikiform_targetform};  ## make sure never to match
1503                undef $form{wikiform_index};       ## with WikiForm in rest of page
1504            }
1505            $i++; $embed;
1506        }ge;
1507        unless ($write) {
1508          #$content = "#?SuikaWiki/0.9\n\n" unless $content;
1509          #$content .= "\n" unless $content =~ /\n$/s;
1510          #
1511        }
1512        if ($write) {
1513            $form{mymsg} = $content;
1514            $form{mytouch} = 'on';
1515            &do_write;
1516        } else {
1517            $form{mycmd} = 'read';
1518            &do_read;
1519        }
1520    }
1521    
1522    
1523  # Walrus add (5) start  # Walrus add (5) start
1524  sub do_interwiki_box {  sub do_interwiki_box {
1525      my $remoteurl = $interwiki{$form{'myintername'}};      my $remoteurl = $interwiki{$form{'myintername'}};
# Line 1397  sub code_convert { Line 1561  sub code_convert {
1561      $code = 'euc' if $code =~ /euc/;      $code = 'euc' if $code =~ /euc/;
1562      $code = 'sjis' if $code =~ /shift/;      $code = 'sjis' if $code =~ /shift/;
1563      $code = 'utf8' if $code =~ /utf/;      $code = 'utf8' if $code =~ /utf/;
1564  #   &Jcode::convert($contentref, $code);       # for Jcode.pm      &Jcode::convert($contentref, $code);       # for Jcode.pm
1565      &jcode::convert($contentref, $code);       # for jcode.pl  #    &jcode::convert($contentref, $code);       # for jcode.pl
1566        &jcode::tr ($contentref, "\xA3\xB0-\xA3\xB9\xA3\xC1-\xA3\xDA\xA3\xE1-\xA3\xFA\xA1\xF5\xA1\xA4\xA1\xA5\xA1\xA7\xA1\xA8\xA1\xA9\xA1\xAA\xA1\xAE\xA1\xB0\xA1\xB2\xA1\xBF\xA1\xC3\xA1\xCA\xA1\xCB\xA1\xCE\xA1\xCF\xA1\xD0\xA1\xD1\xA1\xDC\xA1\xF0\xA1\xF3\xA1\xF4\xA1\xF6\xA1\xF7\xA1\xE1\xA2\xAF\xA2\xB0\xA2\xB2\xA2\xB1\xA1\xE4\xA1\xE3\xA1\xC0\xA1\xA1" => q(0-9A-Za-z&,.:;?!`^_/|()[]{}+$%#*@='"~-><\ )) if $code eq 'euc';
1567      return $$contentref;      return $$contentref;
1568  }  }
1569    
# Line 1538  sub is_exist_page { Line 1703  sub is_exist_page {
1703  }  }
1704    
1705  sub __get_database ($) { $database{ $_[0] } }  sub __get_database ($) { $database{ $_[0] } }
1706    sub __set_database ($$) { $database{ $_[0] } = $_[1] }
1707    
1708  package wiki::referer;  package wiki::referer;
1709  sub add ($$) {  sub add ($$) {
# Line 1619  sub __decode ($) { Line 1785  sub __decode ($) {
1785    main::code_convert (\$s);    main::code_convert (\$s);
1786  }  }
1787    
1788    package wiki::useragent;
1789    
1790    sub add ($) {
1791      my $s = shift;
1792      return unless length $s;
1793      $s =~ s/([\x00-\x08\x0A-\x1F\x25\x7F-\xFF])/sprintf '%%%02X', unpack 'C', $1/g;
1794      my %ua;
1795      for (split /\n/, &main::__get_database('WikiUserAgentList')) {
1796        if (/^-\[(\d+)\] (.+)$/) {
1797          my ($t, $n) = ($1, $2);
1798          $n =~ tr/\x0A\x0D//d;
1799          $ua{$n} = $t;
1800        }
1801      }
1802      $ua{$s}++;
1803      my $s = qq(#?SuikaWiki/0.9\n);
1804      for (sort {$ua{$a} <=> $ua{$b}} keys %ua) {
1805        $s .= sprintf qq(-[%d] %s\n), $ua{$_}, $_;
1806      }
1807      &main::__set_database ('WikiUserAgentList' => $s);
1808    }
1809    
1810    package SuikaWiki::Plugin;
1811      our %List;
1812    
1813    sub escape ($$) { main::escape ($_[1]) }
1814    sub unescape ($$) { main::unescape ($_[1]) }
1815    sub encode ($$) { main::encode ($_[1]) }
1816    sub decode ($$) { main::decode ($_[1]) }
1817    sub __get_datetime ($) { main::get_now () }
1818    
1819    sub regist ($@) {
1820        my $pack = shift;
1821        for (@_) {
1822            push @{$List{$_}}, $pack;
1823        }
1824    }
1825    
1826    use SuikaWiki::Plugin::WikiFormBasic;
1827    
1828  1;  1;
1829  __END__  __END__
1830  =head1 NAME  =head1 NAME

Legend:
Removed from v.1.31  
changed lines
  Added in v.1.34

admin@suikawiki.org
ViewVC Help
Powered by ViewVC 1.1.24