diff --git a/program/steps/mail/spell_pspell.inc b/program/steps/mail/spell_pspell.inc index 4d15604bf..bf696f2fe 100644 --- a/program/steps/mail/spell_pspell.inc +++ b/program/steps/mail/spell_pspell.inc @@ -29,19 +29,29 @@ if (!extension_loaded('pspell')) { exit; } +// read input $data = file_get_contents('php://input'); -$xml = simplexml_load_string($data); -$text = (string)$xml->text; + +// parse data (simplexml_load_string breaks CRLFs) +$left = strpos($data, ''); +$right = strrpos($data, ''); +$text = substr($data, $left+6, $right-($left+6)); + +// tokenize $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'); + +// init spellchecker +$plink = pspell_new(get_input_value('lang', RCUBE_INPUT_GET), null, null, 'utf-8', PSPELL_FAST); + +// send output $out = ''; $diff = 0; foreach ($words as $w) { - $word = $w[0]; + $word = trim($w[0]); $pos = $w[1] - $diff; $len = rc_strlen($word); - if ($plink && !pspell_check($plink, $word)) { + if ($word && $plink && !pspell_check($plink, $word)) { $suggestions = pspell_suggest($plink, $word); $out .= ''; $out .= implode("\t", $suggestions); @@ -49,6 +59,7 @@ foreach ($words as $w) { } $diff += (strlen($word) - $len); } + $out .= ''; header("Content-Type: text/xml");