summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoralecpl <alec@alec.pl>2008-10-13 13:11:55 +0000
committeralecpl <alec@alec.pl>2008-10-13 13:11:55 +0000
commit81308b30ed9c24a55fe87811a782f95fad0e4f3a (patch)
tree14646ae163b2775212b229f51b027ce635467c92
parent87b7959f2b6c79235ea54979c79a8562d291402f (diff)
#1485441: fix pspell checking of multibyte languages
-rw-r--r--program/steps/mail/spell_pspell.inc11
1 files changed, 7 insertions, 4 deletions
diff --git a/program/steps/mail/spell_pspell.inc b/program/steps/mail/spell_pspell.inc
index ea5907a0d..4d15604bf 100644
--- a/program/steps/mail/spell_pspell.inc
+++ b/program/steps/mail/spell_pspell.inc
@@ -32,19 +32,22 @@ if (!extension_loaded('pspell')) {
$data = file_get_contents('php://input');
$xml = simplexml_load_string($data);
$text = (string)$xml->text;
-$words = preg_split('/[ !"#$%&()*+\\,-.\/\n:;<=>?@\[\]^_{|}]+/', $text, NULL, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_OFFSET_CAPTURE );
+$words = preg_split('/[ !"#$%&()*+\\,-.\/\n:;<=>?@\[\]^_{|}]+/', $text, NULL, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_OFFSET_CAPTURE );
$plink = pspell_new(get_input_value('lang', RCUBE_INPUT_GET), null, null, 'utf-8');
-$out = '<?xml version="1.0" encoding="UTF-8"?><spellresult charschecked="'.strlen($text).'">';
+$out = '<?xml version="1.0" encoding="UTF-8"?><spellresult charschecked="'.rc_strlen($text).'">';
+
+$diff = 0;
foreach ($words as $w) {
$word = $w[0];
- $pos = $w[1];
- $len = strlen($word);
+ $pos = $w[1] - $diff;
+ $len = rc_strlen($word);
if ($plink && !pspell_check($plink, $word)) {
$suggestions = pspell_suggest($plink, $word);
$out .= '<c o="'.$pos.'" l="'.$len.'">';
$out .= implode("\t", $suggestions);
$out .= '</c>';
}
+ $diff += (strlen($word) - $len);
}
$out .= '</spellresult>';