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; |
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 = '([^:]+):i:([^:].*)'; |
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 = ( |
my %embed_command = ( |
128 |
searched => '^\[\[#searched:([^\]]+)\]\]$', |
searched => '^\[\[#searched:([^\]]+)\]\]$', |
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, |
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}); |
my ($r, $c) = get_search_result ($form{mypage}); |
211 |
if ($c) { |
if ($c) { |
212 |
print q{<h2>See also</h2>}; |
print q{<h2>See also</h2>}; |
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); |
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 |
} |
} |
361 |
my $word = $form{mymsg}; |
my $word = $form{mymsg}; |
362 |
&print_header($SearchPage); |
&print_header($SearchPage); |
363 |
&print_searchform(&escape($word)); |
&print_searchform(&escape($word)); |
364 |
print get_search_result ($word, -output_not_found => 1); |
print scalar get_search_result ($word, -output_not_found => 1); |
365 |
&print_footer($SearchPage); |
&print_footer($SearchPage); |
366 |
} |
} |
367 |
|
|
376 |
|| index ($page, $word) > 0 |
|| index ($page, $word) > 0 |
377 |
|| index ($word, $page) > 0 |
|| index ($word, $page) > 0 |
378 |
) { |
) { |
379 |
$r .= qq(<li><a href ="$url_cgi?@{[&encode($page)]}">$page</a>@{[&escape(&get_subjectline($page))]}</li>); |
$r .= qq(<li><a href ="$url_cgi?@{[&encode($page)]}">@{[&escape($page)]}</a>@{[&escape(&get_subjectline($page))]}</li>); |
380 |
$counter++; |
$counter++; |
381 |
} |
} |
382 |
} |
} |
427 |
print qq{Refresh: 0; url="$option{-goto}"\n}; |
print qq{Refresh: 0; url="$option{-goto}"\n}; |
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 |
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 |
EOD |
449 |
print <<EOD; |
print <<EOD; |
450 |
<h1 class="header"><a |
<h1 class="header"><a |
451 |
title="$resource{searchthispage}" |
title="$resource{searchthispage}" |
452 |
href="$url_cgi?mycmd=search;mymsg=$cookedpage">$page</a>@{[&escape(&get_subjectline($page))]}</h1> |
href="$url_cgi?mycmd=search;mymsg=$cookedpage">@{[&escape($page)]}</a>@{[&escape(&get_subjectline($page))]}</h1> |
453 |
EOD |
EOD |
454 |
} |
} |
455 |
|
|
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|\&|&|g; |
$s =~ s|&|&|g; |
539 |
$s =~ s|<|<|g; |
$s =~ s|<|<|g; |
540 |
$s =~ s|>|>|g; |
$s =~ s|>|>|g; |
541 |
$s =~ s|"|"|g; |
$s =~ s|"|"|g; |
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|\&|\&|g; |
$s =~ s|<|<|g; |
549 |
$s =~ s|\<|\<|g; |
$s =~ s|>|>|g; |
550 |
$s =~ s|\>|\>|g; |
$s =~ s|"|"|g; |
551 |
$s =~ s|\"|\"|g; |
$s =~ s|&|&|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 |
|
|
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 (/^:([^:]+):(.*)/) { |
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 |
} |
} |
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 |
(?:<(?:mailto|http|https|ftp|urn):[\x21-\x7E]*)> |
(?:<(?:mailto|http|https|ftp|urn|news):[\x21-\x7E]*)> |
683 |
| |
| |
684 |
($bracket_name) # [[likethis]], [[#comment]], [[Friend:remotelink]] |
($bracket_name) # [[likethis]], [[#comment]], [[Friend:remotelink]] |
685 |
| |
| |
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>); |
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>); |
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 |
} |
} |
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" tabindex="1">$mymsg</textarea><br> |
<textarea cols="$cols" rows="$rows" name="mymsg" tabindex="1">$mymsg</textarea><br> |
965 |
@{[ |
@{[ |
966 |
$mode{admin} ? |
$mode{admin} ? |
967 |
qq( |
qq( |
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: |
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; |
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) { |
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}"> |