From 16dd372574ca0e03481b1ca65c65556eddb40be1 Mon Sep 17 00:00:00 2001 From: alecpl Date: Mon, 19 Oct 2009 07:27:16 +0000 Subject: - pspell checker: split text by [dot]+[non-word] instead of [dot] and don't check numeric strings --- program/steps/mail/spell_pspell.inc | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'program/steps') diff --git a/program/steps/mail/spell_pspell.inc b/program/steps/mail/spell_pspell.inc index 717b92ee5..0abdc9ea1 100644 --- a/program/steps/mail/spell_pspell.inc +++ b/program/steps/mail/spell_pspell.inc @@ -43,7 +43,7 @@ $text = substr($data, $left+6, $right-($left+6)); $text = html_entity_decode($text, ENT_QUOTES, RCMAIL_CHARSET); // tokenize -$words = preg_split('/[ !"#$%&()*+\\,-.\/\n:;<=>?@\[\]^_{|}]+/', $text, NULL, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_OFFSET_CAPTURE ); +$words = preg_split('/[ !"#$%&()*+\\,\/\n:;<=>?@\[\]^_{|}-]+|\.[^\w]/', $text, NULL, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_OFFSET_CAPTURE ); // init spellchecker $plink = pspell_new(get_input_value('lang', RCUBE_INPUT_GET), null, null, RCMAIL_CHARSET, PSPELL_FAST); @@ -56,7 +56,8 @@ foreach ($words as $w) { $word = trim($w[0]); $pos = $w[1] - $diff; $len = mb_strlen($word); - if ($word && $plink && !pspell_check($plink, $word)) { + if ($word && $plink && preg_match('/[^0-9\.]/', $word) + && !pspell_check($plink, $word)) { $suggestions = pspell_suggest($plink, $word); if (sizeof($suggestions)>10) $suggestions = array_slice($suggestions, 0, MAX_SUGGESTIONS); -- cgit v1.2.3