X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;ds=sidebyside;f=classes%2Fminiwiki.php;h=ab547e0510a2d8507030f3835891f9ccbdf6e242;hb=2aad148119289ff23cf136218cd62f48da8f701f;hp=a267379bb64ae3236f0aa680cb545c8ece579aa5;hpb=61664f8bcd3b1a622b0e67381802f5234c271772;p=platal.git
diff --git a/classes/miniwiki.php b/classes/miniwiki.php
index a267379..ab547e0 100644
--- a/classes/miniwiki.php
+++ b/classes/miniwiki.php
@@ -7,142 +7,165 @@ class MiniWiki
private static $replacementHTML = array();
private static $replacementText = array();
+ private static $title_index = -1;
private static $info = array();
- public static function Markup($id, $pattern, $replacement, $replacementTxt, $info = null)
+ public static function Markup($pattern, $replacement, $replacementTxt, $info = null)
{
+ $id = count(MiniWiki::$patternsWiki);
MiniWiki::$patternsWiki[$id] = $pattern;
MiniWiki::$replacementHTML[$id] = $replacement;
MiniWiki::$replacementText[$id] = $replacementTxt;
if ($info) {
MiniWiki::$info[$id] = $info;
}
+ return $id;
}
-
+
public static function init()
{
if (isset(MiniWiki::$patternsWiki[0])) {
return;
}
- MiniWiki::Markup(0, "/(\r\n|\r([^\n]))/", "\n$2", "\n$2");
-
+ MiniWiki::Markup("/(\r\n|\r([^\n]))/", "\n$2", "\n$2");
+
// retours à la ligne avec \\
- MiniWiki::Markup(1, "/\\\\(?".">(\\\\*))\n/e", "str_repeat('
\n',strlen('$1'))", "str_repeat('\n',strlen('$1'))", "ligne1\\\\\nligne2");
-
+ MiniWiki::Markup("/\\\\(?".">(\\\\*))\n/e", "str_repeat('
\n',mb_strlen('$1'))", "str_repeat('\n',mb_strlen('$1'))", "ligne1\\\\\nligne2");
+
+ // * unordered list
+ MiniWiki::Markup("/(^|\n)\*(([^\n]*(\n|$))(\*[^\n]*(\n|$))*)/se",
+ "'
'", + "'$1 -' . str_replace(\"\\n*\", \"\\n -\", '$2')", + "* element1\n* element2\n* element3"); + // # unordered list + MiniWiki::Markup("/(^|\n)#(([^\n]*(\n|$))(#[^\n]*(\n|$))*)/se", "'
', "\n\n", "paragraphe1\n\nparagraphe2"); - MiniWiki::Markup(20, "/\n/", ' ', "\n"); - MiniWiki::Markup(21, "/^.*<\/p>
.*$/s", "
$0
", "$0"); + MiniWiki::Markup("/\n\n/", '', "\n\n", "paragraphe1\n\nparagraphe2"); + MiniWiki::Markup("/\n/", ' ', "\n"); + MiniWiki::Markup("/^.*<\/p>.*
.*$/s", "
$0
", "$0"); + + // french typo rules, unbreakable spaces + MiniWiki::Markup("/ +([!?:;])/", " $1", "$0"); } public static function WikiToHTML($wiki, $title = false) { if (!$title) { - $oldrule12 = MiniWiki::$replacementHTML[12]; - MiniWiki::$replacementHTML[12] = "'$0'"; + $oldrule12 = MiniWiki::$replacementHTML[MiniWiki::$title_index]; + MiniWiki::$replacementHTML[MiniWiki::$title_index] = "'$0'"; } $html = preg_replace(MiniWiki::$patternsWiki, MiniWiki::$replacementHTML, htmlentities(trim($wiki), ENT_COMPAT, 'UTF-8')); if (!$title) { - MiniWiki::$replacementHTML[12] = $oldrule12; + MiniWiki::$replacementHTML[MiniWiki::$title_index] = $oldrule12; } return $html; } - - private static function justify($text,$n) + + private static function justify($text, $n) { - $arr = explode("\n",wordwrap($text,$n)); - $arr = array_map('trim',$arr); + $arr = explode("\n", wordwrap($text, $n)); + $arr = array_map('trim', $arr); $res = ''; foreach ($arr as $key => $line) { $nxl = isset($arr[$key+1]) ? trim($arr[$key+1]) : ''; - $nxl_split = preg_split('! +!',$nxl); - $nxw_len = count($nxl_split) ? strlen($nxl_split[0]) : 0; + $nxl_split = preg_split('! +!u', $nxl); + $nxw_len = count($nxl_split) ? mb_strlen($nxl_split[0]) : 0; $line = trim($line); - - if (strlen($line)+1+$nxw_len < $n) { + + if (mb_strlen($line)+1+$nxw_len < $n) { $res .= "$line\n"; continue; } - - if (preg_match('![.:;]$!',$line)) { + + if (preg_match('![.:;]$!u',$line)) { $res .= "$line\n"; continue; } - - $tmp = preg_split('! +!',trim($line)); + + $tmp = preg_split('! +!u', trim($line)); $words = count($tmp); if ($words <= 1) { $res .= "$line\n"; continue; } - - $len = array_sum(array_map('strlen',$tmp)); + + $len = array_sum(array_map('mb_strlen', $tmp)); $empty = $n - $len; $sw = floatval($empty) / floatval($words-1); - + $cur = 0; $l = ''; foreach ($tmp as $word) { $l .= $word; - $cur += $sw + strlen($word); - $l = str_pad($l,intval($cur+0.5)); + $cur += $sw + strlen($word); // Use strlen here instead of mb_strlen because it is used by str_pad + // which is not multibyte compatible + $l = str_pad($l, intval($cur + 0.5)); } $res .= trim($l)."\n"; } return trim($res); } - + public static function WikiToText($wiki, $just=false, $indent=0, $width=68, $title=false) { if (!$title) { - $oldrule12 = MiniWiki::$replacementHTML[12]; - MiniWiki::$replacementHTML[12] = "'$0'"; + $oldrule12 = MiniWiki::$replacementHTML[MiniWiki::$title_index]; + MiniWiki::$replacementHTML[MiniWiki::$title_index] = "'$0'"; } + //$text = trim($wiki); + //foreach (MiniWiki::$patternsWiki as $key=>$pattern) { + // echo $key . " - " . $pattern . "\n"; + // $text = preg_replace($pattern, MiniWiki::$replacementText[$key], $text); + //} $text = preg_replace(MiniWiki::$patternsWiki, MiniWiki::$replacementText, trim($wiki)); if (!$title) { - MiniWiki::$replacementHTML[12] = $oldrule12; + MiniWiki::$replacementHTML[MiniWiki::$title_index] = $oldrule12; } - $text = $just ? MiniWiki::justify($text,$width-$indent) : wordwrap($text,$width-$indent); + $text = $just ? MiniWiki::justify($text, $width - $indent) : wordwrap($text, $width - $indent); if($indent) { $ind = str_pad('',$indent); $text = $ind.str_replace("\n","\n$ind",$text); @@ -153,8 +176,8 @@ class MiniWiki static public function help($with_title = false) { if (!$with_title) { - $info12 = MiniWiki::$info[12]; - unset(MiniWiki::$info[12]); + $info12 = MiniWiki::$info[MiniWiki::$title_index]; + unset(MiniWiki::$info[MiniWiki::$title_index]); } $res = array(); @@ -163,7 +186,7 @@ class MiniWiki } if (!$with_title) { - MiniWiki::$info[12] = $info12; + MiniWiki::$info[MiniWiki::$title_index] = $info12; } return $res; }