/[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.21 by wakaba, Sun Jun 2 07:15:20 2002 UTC revision 1.25 by wakaba, Sat Sep 28 09:43:07 2002 UTC
# Line 83  my $file_FrontPage = "$modifier_dir_data Line 83  my $file_FrontPage = "$modifier_dir_data
83  my $file_conflict = "$modifier_dir_data/conflict.txt";  my $file_conflict = "$modifier_dir_data/conflict.txt";
84  my $file_format = "$modifier_dir_data/format.txt";  my $file_format = "$modifier_dir_data/format.txt";
85  my $url_cgi = 'wiki';  my $url_cgi = 'wiki';
86  my $url_stylesheet = 'wiki-style.css';  my $url_stylesheet = $url_cgi.'?mycmd=TEXT_CSS;mypage=WikiHTMLStyle';
87  my $icontag = '<img src="/icons/folder" alt="*" width="40" height="40" />';  my $icontag = '<img src="/icons/folder" alt="*" width="40" height="40" />';
88  my $maxrecent = 50;  my $maxrecent = 50;
89  my $cols = 80;  my $cols = 80;
# Line 117  my $wiki_name   = '\b([A-Z][a-z]+([A-Z][ Line 117  my $wiki_name   = '\b([A-Z][a-z]+([A-Z][
117  my $bracket_name = '\[\[(\S+?)\]\]';  my $bracket_name = '\[\[(\S+?)\]\]';
118  my $embedded_name = '\[\[(#\S+?)\]\]';  my $embedded_name = '\[\[(#\S+?)\]\]';
119  my $interwiki_definition = '\[\[(\S+?)\ (\S+?)\]\]';  my $interwiki_definition = '\[\[(\S+?)\ (\S+?)\]\]';
120  my $interwiki_name = '([^:]+):([^:].*)';  my $interwiki_name = 'i:([^:]+):([^:].*)';
121  ##############################  ##############################
122  my $embed_comment = '[[#comment]]';  my $embed_comment = '[[#comment]]';
123  my $embed_rcomment = '[[#rcomment]]';  my $embed_rcomment = '[[#rcomment]]';
124    my $embed_comment_Name_Prompt = '名前:';
125    my $DEFAULT_embed_comment_name = '名無しさん';
126  my $embed_interwiki = '^\[\[#(box|text|password):(\S+)\]\]$';    # Walrus add (5)  my $embed_interwiki = '^\[\[#(box|text|password):(\S+)\]\]$';    # Walrus add (5)
127    my %embed_command = (
128            searched        => '^\[\[#searched:([^\]]+)\]\]$',
129    );
130  ##############################  ##############################
131  my $info_LastModified = 'LastModified';  my $info_LastModified = 'LastModified';
132  my $info_IsFrozen = 'IsFrozen';  my $info_IsFrozen = 'IsFrozen';
# Line 158  my %page_command = ( Line 163  my %page_command = (
163  );  );
164  my %command_do = (  my %command_do = (
165      read => \&do_read,      read => \&do_read,
166        TEXT_CSS => \&do_output_css,
167      edit => \&do_edit,      edit => \&do_edit,
168      adminedit => \&do_adminedit,      adminedit => \&do_adminedit,
169      adminchangepasswordform => \&do_adminchangepasswordform,      adminchangepasswordform => \&do_adminchangepasswordform,
# Line 200  sub main { Line 206  sub main {
206  sub do_read {  sub do_read {
207      &print_header($form{mypage});      &print_header($form{mypage});
208      &print_content($database{$form{mypage}});      &print_content($database{$form{mypage}});
209        print &text_to_html (q([[#comment]]));
210        my ($r, $c) = get_search_result ($form{mypage});
211        if ($c) {
212          print q{<h2>See also</h2>};
213          print $r;
214        }
215      &print_footer($form{mypage});      &print_footer($form{mypage});
216  }  }
217    
218    sub do_output_css {
219      my $content = $database{$form{mypage}};
220      if ($content =~ m#^\s*/\*\s*W3C-CSS#) {
221        print "Content-Type: text/css; charset=$charset\n";
222        print "\n";
223        print $content;
224      } else {
225        print "Status: 406 Unsupported Media Type\n";
226        &print_header('WikiPageIsNotCSS');
227        &print_content($database{WikiPageIsNotCSS});
228        &print_footer('WikiPageIsNotCSS');
229      }
230    }
231    
232  sub do_edit {  sub do_edit {
233      my ($page) = &unarmor_name(&armor_name($form{mypage}));      my ($page) = &unarmor_name(&armor_name($form{mypage}));
234      &print_header($page);      &print_header($page);
# Line 266  sub do_index { Line 292  sub do_index {
292      print qq(<ul>);      print qq(<ul>);
293      foreach my $page (sort keys %database) {      foreach my $page (sort keys %database) {
294          if (&is_editable($page)) {          if (&is_editable($page)) {
295              print qq(<li><a href="$url_cgi?@{[&encode($page)]}">$page</a>@{[&escape(&get_subjectline($page))]}</li>);              print qq(<li><a href="$url_cgi?@{[&encode($page)]}">@{[&escape($page)]}</a>@{[&escape(&get_subjectline($page))]}</li>);
296              # print qq(<li>@{[&get_info($page, $info_IsFrozen)]}</li>);              # print qq(<li>@{[&get_info($page, $info_IsFrozen)]}</li>);
297              # print qq(<li>@{[0 + &is_frozen($page)]}</li>);              # print qq(<li>@{[0 + &is_frozen($page)]}</li>);
298          }          }
# Line 308  sub do_write { Line 334  sub do_write {
334              &update_recent_changes;              &update_recent_changes;
335          }          }
336          &set_info($form{mypage}, $info_IsFrozen, 0 + $form{myfrozen});          &set_info($form{mypage}, $info_IsFrozen, 0 + $form{myfrozen});
337          &print_header($CompletedSuccessfully);          &print_header($CompletedSuccessfully, -goto => $url_cgi.'?'.&encode($form{mypage}));
338          &print_message($resource{saved});          &print_message($resource{saved});
339          &print_content("$resource{continuereading} @{[&armor_name($form{mypage})]}");          &print_content("$resource{continuereading} @{[&armor_name($form{mypage})]}");
340          &print_footer($CompletedSuccessfully);          &print_footer($CompletedSuccessfully);
# Line 332  sub do_searchform { Line 358  sub do_searchform {
358  }  }
359    
360  sub do_search {  sub do_search {
361      my $word = &escape($form{mymsg});      my $word = $form{mymsg};
362      &print_header($SearchPage);      &print_header($SearchPage);
363      &print_searchform($word);      &print_searchform(&escape($word));
364      my $counter = 0;      print scalar get_search_result ($word, -output_not_found => 1);
     foreach my $page (sort keys %database) {  
         next if $page =~ /^$RecentChanges$/;  
         if ($database{$page} =~ /\Q$form{mymsg}\E/ or $page =~ /\Q$form{mymsg}\E/) {  
             if ($counter == 0) {  
                 print qq|<ul>|;  
             }  
             print qq(<li><a href ="$url_cgi?@{[&encode($page)]}">$page</a>@{[&escape(&get_subjectline($page))]}</li>);  
             $counter++;  
         }  
     }  
     if ($counter == 0) {  
         &print_message($resource{notfound});  
     } else {  
         print qq|</ul>|;  
     }  
365      &print_footer($SearchPage);      &print_footer($SearchPage);
366  }  }
367    
368    sub get_search_result ($;%) {
369      my $word = shift;
370      my %option = @_;
371      my $counter = 0;
372      my $r = '';
373      foreach my $page (sort keys %database) {
374        next if $page eq $RecentChanges;
375        if (   index ($database{$page}, $word) > 0
376            || index ($page, $word) > 0
377            || index ($word, $page) > 0
378           ) {
379          $r .= qq(<li><a href ="$url_cgi?@{[&encode($page)]}">@{[&escape($page)]}</a>@{[&escape(&get_subjectline($page))]}</li>);
380          $counter++;
381        }
382      }
383      $r = qq|<ul>$r</ul>| if $r;
384      get_message ($resource{notfound})
385        if $counter == 0 && $option{-output_not_found};
386      wantarray? ($r, $counter): $r;
387    }
388    
389  sub do_create {  sub do_create {
390      &print_header($CreatePage);      &print_header($CreatePage);
391      print <<"EOD";      print <<"EOD";
# Line 386  sub print_error { Line 418  sub print_error {
418  }  }
419    
420  sub print_header {  sub print_header {
421      my ($page) = @_;      my ($page,%option) = @_;
422      my $bodyclass = "normal";      my $bodyclass = "normal";
     my $editable = 0;  
     my $admineditable = 0;  
423      if (&is_frozen($page) and $form{mycmd} =~ /^(read|write)$/) {      if (&is_frozen($page) and $form{mycmd} =~ /^(read|write)$/) {
         $editable = 0;  
         $admineditable = 1;  
424          $bodyclass = "frozen";          $bodyclass = "frozen";
425      } elsif (&is_editable($page) and $form{mycmd} =~ /^(read|write)$/) {      }
426          $admineditable = 1;      if ($option{-goto}) {
427          $editable = 1;        print qq{Refresh: 0; url="$option{-goto}"\n};
     } else {  
         $editable = 0;  
428      }      }
429      my $cookedpage = &encode($page);      my $cookedpage = &encode($page);
430        my $escapedpage = &escape($page);
431      print <<"EOD";      print <<"EOD";
432  Content-type: text/html; charset=$charset  Content-type: text/html; charset=$charset
433  Content-Language: $lang  Content-Language: $lang
# Line 411  Content-Style-Type: text/css Line 438  Content-Style-Type: text/css
438      "http://www.w3.org/TR/html4/loose.dtd">      "http://www.w3.org/TR/html4/loose.dtd">
439  <html lang="$lang">  <html lang="$lang">
440  <head>  <head>
441      <title>$page @{[&escape(&get_subjectline($page))]}</title>      <title>$escapedpage @{[&escape(&get_subjectline($page))]}</title>
442      <link rel="index" href="$url_cgi?$IndexPage">      <link rel="index" href="$url_cgi?$IndexPage">
443      <link rev="made" href="mailto:$modifier_mail">      <link rev="made" href="mailto:@{[&escape($modifier_mail)]}">
444      <link rel="stylesheet" type="text/css" href="$url_stylesheet">      <link rel="stylesheet" type="text/css" href="@{[&escape($url_stylesheet)]}">
445  </head>  </head>
446  <body class="$bodyclass">  <body class="$bodyclass">
447    EOD
448      &print_navigate_links ($page);
449      print <<EOD;
450    <h1 class="header"><a
451        title="$resource{searchthispage}"
452        href="$url_cgi?mycmd=search;mymsg=$cookedpage">@{[&escape($page)]}</a>@{[&escape(&get_subjectline($page))]}</h1>
453    EOD
454    }
455    
456    sub print_navigate_links (@) {
457      my ($page) = @_;
458        my $editable = 0;
459        my $admineditable = 0;
460        if (&is_frozen($page) and $form{mycmd} =~ /^(read|write)$/) {
461            $editable = 0;
462            $admineditable = 1;
463        } elsif (&is_editable($page) and $form{mycmd} =~ /^(read|write)$/) {
464            $admineditable = 1;
465            $editable = 1;
466        } else {
467            $editable = 0;
468        }
469        my $cookedpage = &encode($page);
470      print <<EOH;
471  <div class="tools">  <div class="tools">
472      @{[ $admineditable      @{[ $admineditable
473          ? qq(<a title="$resource{admineditthispage}" href="$url_cgi?mycmd=adminedit;mypage=$cookedpage">$resource{admineditbutton}</a> | )          ? qq(<a title="$resource{admineditthispage}" href="$url_cgi?mycmd=adminedit;mypage=$cookedpage">$resource{admineditbutton}</a> | )
474          : qq()          : qq()
475      ]}      ]}
476      @{[ $editable      @{[ $editable
477          ? qq(<a title="$resource{editthispage}" href="$url_cgi?mycmd=edit;mypage=$cookedpage">$resource{editbutton}</a> | )          ? qq(<a title="$resource{editthispage}" href="$url_cgi?mycmd=edit;mypage=$cookedpage" accesskey="E">$resource{editbutton} <kbd>E</kbd></a> | )
478          : qq()          : qq()
479      ]}      ]}
480      @{[ $admineditable      @{[ $admineditable
# Line 437  Content-Style-Type: text/css Line 488  Content-Style-Type: text/css
488      <a href="$url_cgi?$SearchPage">$resource{searchbutton}</a> |      <a href="$url_cgi?$SearchPage">$resource{searchbutton}</a> |
489      <a href="$url_cgi?$RecentChanges">$resource{recentchangesbutton}</a>      <a href="$url_cgi?$RecentChanges">$resource{recentchangesbutton}</a>
490  </div>  </div>
491  <h1 class="header"><a  EOH
     title="$resource{searchthispage}"  
     href="$url_cgi?mycmd=search;mymsg=$cookedpage">$page</a>@{[&escape(&get_subjectline($page))]}</h1>  
 EOD  
492  }  }
493    
494  sub print_footer {  sub print_footer {
495      my ($page) = @_;      my ($page) = @_;
496      $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)
497      # Walrus mod (1) start      # Walrus mod (1) start
498  my $cvslog = '$Revision$ $Date$';    my $cvslog = '$Revision$ $Date$';
499      print <<"EOD";    print_navigate_links ($page);
500      print <<"EOD";
501  <div class="footer">  <div class="footer">
502  <p>  <p>
503  <a href="http://digit.que.ne.jp/work/">WalWiki</a> $walversion &copy; 2000-2002 by <a href="http://digit.que.ne.jp/">Makio Tsukamoto</a>.<br />  <a href="http://digit.que.ne.jp/work/">WalWiki</a> $walversion &copy; 2000-2002 by <a href="http://digit.que.ne.jp/">Makio Tsukamoto</a>.<br />
# Line 486  EOD Line 535  EOD
535  sub escape {  sub escape {
536      my $s = shift;      my $s = shift;
537      $s =~ s|\r\n|\n|g;      $s =~ s|\r\n|\n|g;
538      $s =~ s|\&|&amp;|g;      $s =~ s|&|&amp;|g;
539      $s =~ s|<|&lt;|g;      $s =~ s|<|&lt;|g;
540      $s =~ s|>|&gt;|g;      $s =~ s|>|&gt;|g;
541      $s =~ s|"|&quot;|g;      $s =~ s|"|&quot;|g;
# Line 496  sub escape { Line 545  sub escape {
545  sub unescape {  sub unescape {
546      my $s = shift;      my $s = shift;
547      # $s =~ s|\n|\r\n|g;      # $s =~ s|\n|\r\n|g;
548      $s =~ s|\&amp;|\&|g;      $s =~ s|&lt;|<|g;
549      $s =~ s|\&lt;|\<|g;      $s =~ s|&gt;|>|g;
550      $s =~ s|\&gt;|\>|g;      $s =~ s|&quot;|"|g;
551      $s =~ s|\&quot;|\"|g;      $s =~ s|&amp;|&|g;
552      return $s;      return $s;
553  }  }
554    
555  sub print_content {  sub print_content {
556      my ($rawcontent) = @_;      my ($rawcontent) = @_;
557        $rawcontent =~ s#^SuikaWiki/0.9[^\x0D\x0A]*[\x0D\x0A]+##s;
558      print &text_to_html($rawcontent, toc=>1);      print &text_to_html($rawcontent, toc=>1);
559  }  }
560    
# Line 518  sub text_to_html { Line 568  sub text_to_html {
568      push(@result, "<p>");      push(@result, "<p>");
569      foreach (@txt) {      foreach (@txt) {
570          chomp;          chomp;
571          # Walrus mod (6) start          if (/^\*\*\*\*\*([^\x0D\x0A]*)/) {
572          #if ($saved[0] eq '</html>') {              push(@toc, qq(----- <a href="#i$tocnum">@{[&escape($1)||$tocnum]}</a>\n));
         #    if (/<\/html>/i) { splice(@saved); }  
         #    else { push (@result, &html_to_ignored_html($_)); }  
         #} elsif (/^<html>/i and &is_ignore_html($form{mypage})) {  
         #    push(@result, splice(@saved));  
         #    push(@saved, '</html>');  
         #} els  
         if (/^\*\*\*\*\*(.*)/) {  
             push(@toc, qq(-- <a href="#i$tocnum">@{[&escape($1)]}</a>\n));  
573              push(@result, splice(@saved), qq(<h6 id="i$tocnum">) . &inline($1) . '</h6>');              push(@result, splice(@saved), qq(<h6 id="i$tocnum">) . &inline($1) . '</h6>');
574              $tocnum++;              $tocnum++;
575          } elsif (/^\*\*\*\*(.*)/) {          } elsif (/^\*\*\*\*([^\x0D\x0A]*)/) {
576              push(@toc, qq(-- <a href="#i$tocnum">@{[&escape($1)]}</a>\n));              push(@toc, qq(---- <a href="#i$tocnum">@{[&escape($1)||$tocnum]}</a>\n));
577              push(@result, splice(@saved), qq(<h5 id="i$tocnum">) . &inline($1) . '</h5>');              push(@result, splice(@saved), qq(<h5 id="i$tocnum">) . &inline($1) . '</h5>');
578              $tocnum++;              $tocnum++;
579          } elsif (/^\*\*\*(.*)/) {          } elsif (/^\*\*\*([^\x0D\x0A]*)/) {
580              push(@toc, qq(-- <a href="#i$tocnum">@{[&escape($1)]}</a>\n));              push(@toc, qq(--- <a href="#i$tocnum">@{[&escape($1)||$tocnum]}</a>\n));
581              push(@result, splice(@saved), qq(<h4 id="i$tocnum">) . &inline($1) . '</h4>');              push(@result, splice(@saved), qq(<h4 id="i$tocnum">) . &inline($1) . '</h4>');
582              $tocnum++;              $tocnum++;
583          } elsif (/^\*\*(.*)/) {          } elsif (/^\*\*([^\x0D\x0A]*)/) {
584          # if (/^\*\*(.*)/) {          # if (/^\*\*(.*)/) {
585          # Walrus mod (6) end          # Walrus mod (6) end
586              push(@toc, qq(-- <a href="#i$tocnum">@{[&escape($1)]}</a>\n));              push(@toc, qq(-- <a href="#i$tocnum">@{[&escape($1)||$tocnum]}</a>\n));
587              push(@result, splice(@saved), qq(<h3><a name="i$tocnum"> </a>) . &inline($1) . '</h3>');              push(@result, splice(@saved), qq(<h3><a name="i$tocnum"> </a>) . &inline($1) . '</h3>');
588              $tocnum++;              $tocnum++;
589          } elsif (/^\*(.*)/) {          } elsif (/^\*([^\x0D\x0A]*)/) {
590              push(@toc, qq(- <a href="#i$tocnum">@{[&escape($1)]}</a>\n));              push(@toc, qq(- <a href="#i$tocnum">@{[&escape($1)||$tocnum]}</a>\n));
591              push(@result, splice(@saved), qq(<h2><a name="i$tocnum"> </a>) . &inline($1) . '</h2>');              push(@result, splice(@saved), qq(<h2><a name="i$tocnum"> </a>) . &inline($1) . '</h2>');
592              $tocnum++;              $tocnum++;
593          #} elsif (/^----/) {          } elsif (/^(={1,6})(.*)/) {
         #    push(@result, splice(@saved), '<hr>');  
         } elsif (/^(={1,5})(.*)/) {  
594              &back_push('ol', length($1), \@saved, \@result);              &back_push('ol', length($1), \@saved, \@result);
595              push(@result, '<li>' . &inline($2) . '</li>');              push(@result, '<li>' . &inline($2) . '</li>');
596          } elsif (/^(-{1,5})(.*)/) {          } elsif (/^(-{1,6})(.*)/) {
597              &back_push('ul', length($1), \@saved, \@result);              &back_push('ul', length($1), \@saved, \@result);
598              push(@result, '<li>' . &inline($2) . '</li>');              push(@result, '<li>' . &inline($2) . '</li>');
599          } elsif (/^:([^:]+):(.*)/) {          } elsif (/^:([^:]+):(.*)/) {
# Line 605  sub text_to_html { Line 645  sub text_to_html {
645          # This part is taken from Makio Tsukamoto's WalWiki.          # This part is taken from Makio Tsukamoto's WalWiki.
646          my (@tocsaved, @tocresult);          my (@tocsaved, @tocresult);
647          foreach (@toc) {          foreach (@toc) {
648              if (/^(-{1,3})(.*)/) {              if (/^(-{1,6})(.*)$/) {
649                  &back_push('ul', length($1), \@tocsaved, \@tocresult);                  &back_push('ul', length($1), \@tocsaved, \@tocresult);
650                  push(@tocresult, '<li>' . $2 . '</li>');                  push(@tocresult, '<li>' . $2 . '</li>');
651              }              }
# Line 639  sub inline { Line 679  sub inline {
679      $line =~ s|(\d\d\d\d-\d\d-\d\d \(\w\w\w\) \d\d:\d\d:\d\d)|<span class="date">$1</span>|g;   # Date      $line =~ s|(\d\d\d\d-\d\d-\d\d \(\w\w\w\) \d\d:\d\d:\d\d)|<span class="date">$1</span>|g;   # Date
680      $line =~ s!      $line =~ s!
681        (        (
682          (?:&lt;(?:mailto|http|https|ftp|urn):[\x21-\x7E]*)&gt;          (?:&lt;(?:mailto|http|https|ftp|urn|news):[\x21-\x7E]*)&gt;
683        |        |
684          ($bracket_name) # [[likethis]], [[#comment]], [[Friend:remotelink]]          ($bracket_name) # [[likethis]], [[#comment]], [[Friend:remotelink]]
685        |        |
# Line 663  sub make_link { Line 703  sub make_link {
703      } elsif ($chunk =~ /^mailto:(.*)$/) {      } elsif ($chunk =~ /^mailto:(.*)$/) {
704          $name = $1;          $name = $1;
705      }      }
706      if ($use_autoimg and $name =~ /^(http|https|ftp|):.+\.(png|gif|jpe?g)/) {      if ($use_autoimg and $name =~ /^(http|https|ftp):.+\.(png|gif|jpe?g)/) {
707          $name = qq(<img src="$name">) ;          $name = qq(<img src="$name">) ;
708      }      }
709      $name = &unarmor_name($name);      $name = &unarmor_name($name);
710      # Walrus add (3) end      # Walrus add (3) end
711      if ($chunk =~ /^(http|https|ftp):/) {      if ($chunk =~ /^(http|https|ftp|news):/) {
712          # Walrus mod (3) start          # Walrus mod (3) start
713  #       if ($use_autoimg and $chunk =~ /\.(gif|png|jpeg|jpg)$/) {  #       if ($use_autoimg and $chunk =~ /\.(gif|png|jpeg|jpg)$/) {
714  #           return qq(<a href="$chunk"><img src="$chunk"></a>);  #           return qq(<a href="$chunk"><img src="$chunk"></a>);
# Line 698  sub make_link { Line 738  sub make_link {
738  #               $remoteurl =~ s/\b(euc|sjis|ykwk|asis)\(\$1\)/&interwiki_convert($1, $localname)/e;      # Walrus del (4)  #               $remoteurl =~ s/\b(euc|sjis|ykwk|asis)\(\$1\)/&interwiki_convert($1, $localname)/e;      # Walrus del (4)
739                  $remoteurl =~ s/\b(euc|sjis|ykwk|asis|isbn)\(\$1\)/&interwiki_convert($1, $localname)/e; # Walrus add (4)                  $remoteurl =~ s/\b(euc|sjis|ykwk|asis|isbn)\(\$1\)/&interwiki_convert($1, $localname)/e; # Walrus add (4)
740  #               return qq(<a href="$remoteurl">$chunk</a>); # Walrus del (3)  #               return qq(<a href="$remoteurl">$chunk</a>); # Walrus del (3)
741                  return qq(<a href="$remoteurl">$name</a>);  # Walrus add (3)                  return qq(<a href="$remoteurl">@{[&escape($name)]}</a>);  # Walrus add (3)
742              } else {              } else {
743  #               return $chunk;                              # Walrus del (3)  #               return $chunk;                              # Walrus del (3)
744                  return $name;                               # Walrus add (3)                  return &escape($name);                               # Walrus add (3)
745              }              }
746          } elsif ($database{$chunk}) {          } elsif ($database{$chunk}) {
747              my $subject = &escape(&get_subjectline($chunk, delimiter => ''));              my $subject = &escape(&get_subjectline($chunk, delimiter => ''));
748  #           return qq(<a title="$subject" href="$url_cgi?$cookedchunk">$chunk</a>);  # Walrus del (3)  #           return qq(<a title="$subject" href="$url_cgi?$cookedchunk">$chunk</a>);  # Walrus del (3)
749              return qq(<a title="$subject" href="$url_cgi?$cookedchunk">$name</a>);   # Walrus add (3)              return qq(<a title="$subject" href="$url_cgi?$cookedchunk">@{[&escape($name)]}</a>);   # Walrus add (3)
750          } elsif ($page_command{$chunk}) {          } elsif ($page_command{$chunk}) {
751  #           return qq(<a title="$chunk" href="$url_cgi?$cookedchunk">$chunk</a>);    # Walrus del (3)  #           return qq(<a title="$chunk" href="$url_cgi?$cookedchunk">$chunk</a>);    # Walrus del (3)
752              return qq(<a title="$chunk" href="$url_cgi?$cookedchunk" class="wiki">$name</a>);     # Walrus add (3)              return qq(<a title="$chunk" href="$url_cgi?$cookedchunk" class="wiki">@{[&escape($name)]}</a>);     # Walrus add (3)
753          } else {          } else {
754              return qq(<a title="$resource{editthispage}" href="$url_cgi?mycmd=edit;mypage=$cookedchunk" class="wiki">$name<span class="mark">$editchar</span></a>);              return qq(<a title="$resource{editthispage}" href="$url_cgi?mycmd=edit;mypage=$cookedchunk" class="wiki">@{[&escape($name)]}<span class="mark">$editchar</span></a>);
755          }          }
756      }      }
757  }  }
758    
 # Walrus add (6) start  
 sub is_ignore_html {  
     my ($pagename) = @_;  
     foreach (@ignore_html_page) {  
         return 1 if ($pagename eq $_);  
     }  
     return 0;  
 }  
 # Walrus add (6) end  
   
 # Walrus add (6) start  
 sub html_to_ignored_html {  
     my $str = shift(@_);  
     my $text_regex        = q{[^<]*};  
     my $tag_regex_        = q{[^"'<>]*(?:"[^"]*"[^"'<>]*|'[^']*'[^"'<>]*)*(?:>|(?=<)|$(?!\n))}; #'}}}}  
     my $comment_tag_regex = '<!(?:--[^-]*-(?:[^-]+-)*?-(?:[^>-]*(?:-[^>-]+)*?)??)*(?:>|$(?!\n)|--.*$)';  
     my $tag_regex         = qq{$comment_tag_regex|<$tag_regex_};  
     my $ignored           = join('|', @ignore_html_tags);  
     my $result = '';  
     while ($str =~ /($text_regex)($tag_regex)?/gso) {  
       last if $1 eq '' and $2 eq '';  
       $result .= $1;  
       my $tag_tmp = $2;  
       $result .= ($tag_tmp =~ /^<\/?($ignored)(?![0-9A-Za-z])/i) ? $tag_tmp : &escape($tag_tmp);  
       if ($tag_tmp =~ /^<(XMP|PLAINTEXT|SCRIPT)(?![0-9A-Za-z])/i) {  
         $str =~ /(.*?)(?:<\/$1(?![0-9A-Za-z])$tag_regex_|$)/gsi;  
         $result .= &escape($1);  
       }  
     }  
     return $result;  
 }  
 # Walrus add (6) end  
   
759  sub print_message {  sub print_message {
760      my ($msg) = @_;      my ($msg) = @_;
761      print qq(<p><strong>$msg</strong></p>);      print qq(<p><strong>$msg</strong></p>);
762  }  }
763    
764    sub get_message {
765        my ($msg) = @_;
766        qq(<p><strong>$msg</strong></p>);
767    }
768    
769  sub init_form {  sub init_form {
770      if (param()) {      if (param()) {
771          foreach my $var (param()) {          foreach my $var (param()) {
# Line 829  sub get_subjectline { Line 841  sub get_subjectline {
841    
842          # Get the subject of the page.          # Get the subject of the page.
843          my $subject = $database{$page};          my $subject = $database{$page};
844            $subject =~ s#^SuikaWiki/0.9[^\x0D\x0A]*[\x0D\x0A]+##s;
845          $subject =~ s/\r?\n.*//s;          $subject =~ s/\r?\n.*//s;
846          return "$delim$subject";          return "$delim$subject";
847      }      }
# Line 936  sub print_editform { Line 949  sub print_editform {
949          }          }
950          $mymsg = &escape($form{mymsg});          $mymsg = &escape($form{mymsg});
951      } else {      } else {
952          $mymsg = &escape($mymsg);          $mymsg = &escape($mymsg || $database{NewPageTemplate});
953      }      }
954    
955      my $edit = $mode{admin} ? 'adminedit' : 'edit';      my $edit = $mode{admin} ? 'adminedit' : 'edit';
956        my $escapedmypage = &escape($form{mypage});
957        my $escapedmypassword = &escape($form{mypassword});
958    
959      print <<"EOD";      print <<"EOD";
960  <form action="$url_cgi" method="post">  <form action="$url_cgi" method="post">
961      @{[ $mode{admin} ? qq($resource{frozenpassword} <input type="password" name="mypassword" value="$form{mypassword}" size="10"><br>) : "" ]}      @{[ $mode{admin} ? qq($resource{frozenpassword} <input type="password" name="mypassword" value="$escapedmypassword" size="10"><br>) : "" ]}
962      <input type="hidden" name="myLastModified" value="$lastmodified">      <input type="hidden" name="myLastModified" value="$lastmodified">
963      <input type="hidden" name="mypage" value="$form{mypage}">      <input type="hidden" name="mypage" value="$escapedmypage">
964      <textarea cols="$cols" rows="$rows" name="mymsg" wrap="off">$mymsg</textarea><br>      <textarea cols="$cols" rows="$rows" name="mymsg" tabindex="1">$mymsg</textarea><br>
965  @{[  @{[
966      $mode{admin} ?      $mode{admin} ?
967      qq(      qq(
# Line 959  sub print_editform { Line 974  sub print_editform {
974      qq(      qq(
975          <input type="checkbox" name="mytouch" value="on" checked="checked">$resource{touch}<br>          <input type="checkbox" name="mytouch" value="on" checked="checked">$resource{touch}<br>
976          <input type="submit" name="mypreview_$edit" value="$resource{previewbutton}">          <input type="submit" name="mypreview_$edit" value="$resource{previewbutton}">
977          <input type="submit" name="mypreview_write" value="$resource{savebutton}"><br>          <input type="submit" name="mypreview_write" value="$resource{savebutton}" accesskey="S"><kbd>S</kbd><br>
978      )      )
979  ]}  ]}
980  </form>  </form>
# Line 1008  sub is_editable { Line 1023  sub is_editable {
1023  #   not_wiki_name -> [[not_wiki_name]]  #   not_wiki_name -> [[not_wiki_name]]
1024  sub armor_name {  sub armor_name {
1025      my ($name) = @_;      my ($name) = @_;
1026      if ($name =~ /^$wiki_name$/) {      #if ($name =~ /^$wiki_name$/) {
1027          return $name;      #    return $name;
1028      } else {      #} else {
1029          return "[[$name]]";          return "[[$name]]";
1030      }      #}
1031  }  }
1032    
1033  # unarmor_name:  # unarmor_name:
# Line 1185  sub is_frozen { Line 1200  sub is_frozen {
1200  sub do_comment {  sub do_comment {
1201      my ($content) = $database{$form{mypage}};      my ($content) = $database{$form{mypage}};
1202      my $datestr = &get_now;      my $datestr = &get_now;
1203      my $namestr = $form{myname} ? " ''[[$form{myname}]]'' : " : " ";      my $namestr = " ''[[@{[$form{myname}||$DEFAULT_embed_comment_name]}]]'' : ";
1204      if ($content =~ s/(\Q$embed_comment\E)/- $datestr$namestr$form{mymsg}\n$1/) {      #if ($content =~ s/(\Q$embed_comment\E)/- $datestr$namestr$form{mymsg}\n$1/) {
1205          ;      #  ;
1206      } else {      #} else {
1207          $content =~ s/(\Q$embed_rcomment\E)/$1\n- $datestr$namestr$form{mymsg}/;      #  $content =~ s/(\Q$embed_rcomment\E)/$1\n- $datestr$namestr$form{mymsg}/;
1208        #}
1209        my $i = 0;  my $o = 0;
1210        $content =~ s{(\Q$embed_comment\E|\Q$embed_rcomment\E)}{
1211          my $embed = $1;
1212          if ($i == $form{comment_index}) {
1213            if ($embed eq $embed_comment) {
1214              $embed = "- $datestr$namestr$form{mymsg}\n$embed";  $o = 1;
1215            } else {
1216              $embed .= "\n- $datestr$namestr$form{mymsg}";  $o = 1;
1217            }
1218          }
1219          $i++; $embed;
1220        }ge;
1221        unless ($o) {
1222          $content .= "- $datestr$namestr$form{mymsg}\n";
1223      }      }
1224      if ($form{mymsg}) {      if ($form{mymsg}) {
1225          $form{mymsg} = $content;          $form{mymsg} = $content;
# Line 1201  sub do_comment { Line 1231  sub do_comment {
1231      }      }
1232  }  }
1233    
1234    my $_O_COMMENT_INDEX = 0;
1235  sub embedded_to_html {  sub embedded_to_html {
1236      my ($embedded) = @_;      my ($embedded) = @_;
1237      if ($embedded eq $embed_comment or $embedded eq $embed_rcomment) {      if ($embedded eq $embed_comment or $embedded eq $embed_rcomment) {
# Line 1211  sub embedded_to_html { Line 1242  sub embedded_to_html {
1242      <input type="hidden" name="mypage" value="$form{mypage}">      <input type="hidden" name="mypage" value="$form{mypage}">
1243      <input type="hidden" name="myLastModified" value="$lastmodified">      <input type="hidden" name="myLastModified" value="$lastmodified">
1244      <input type="hidden" name="mytouch" value="on">      <input type="hidden" name="mytouch" value="on">
1245      $resource{yourname}      <input type="hidden" name="comment_index" value="@{[$_O_COMMENT_INDEX++]}">
1246        $embed_comment_Name_Prompt
1247      <input type="text" name="myname" value="" size="10">      <input type="text" name="myname" value="" size="10">
1248      <input type="text" name="mymsg" value="" size="40">      <input type="text" name="mymsg" value="" size="40">
1249      <input type="submit" value="$resource{commentbutton}">      <input type="submit" value="$resource{commentbutton}">
1250  </form>  </form>
1251  EOD  EOD
1252      } elsif ($embedded =~ /$embed_command{searched}/) {
1253        return get_search_result ($1);
1254      # Walrus add (5) start      # Walrus add (5) start
1255      } elsif ($embedded =~ /$embed_interwiki/ and my $remoteurl = $interwiki{$2}) {      } elsif ($embedded =~ /$embed_interwiki/ and my $remoteurl = $interwiki{$2}) {
1256          $_ = &make_interwiki_box($1, $2);          $_ = &make_interwiki_box($1, $2);

Legend:
Removed from v.1.21  
changed lines
  Added in v.1.25

admin@suikawiki.org
ViewVC Help
Powered by ViewVC 1.1.24