diff options
| author | Hugues Hiegel <root@paranoid> | 2014-08-05 16:46:22 +0200 | 
|---|---|---|
| committer | Hugues Hiegel <root@paranoid> | 2014-08-05 16:46:22 +0200 | 
| commit | 59478e06c25303a790a0840ab2ac30662c4ef781 (patch) | |
| tree | 8d5e964a8f94adaef41efebb0597629f11495c42 /program/lib/Roundcube/rcube_spellchecker.php | |
| parent | 7c494b677f9e470ee0d32e62cfa8dc709f39e748 (diff) | |
 c'est la merde..working
Diffstat (limited to 'program/lib/Roundcube/rcube_spellchecker.php')
| -rw-r--r-- | program/lib/Roundcube/rcube_spellchecker.php | 163 | 
1 files changed, 7 insertions, 156 deletions
| diff --git a/program/lib/Roundcube/rcube_spellchecker.php b/program/lib/Roundcube/rcube_spellchecker.php index df4365223..672515204 100644 --- a/program/lib/Roundcube/rcube_spellchecker.php +++ b/program/lib/Roundcube/rcube_spellchecker.php @@ -38,7 +38,7 @@ class rcube_spellchecker      // default settings -    const GOOGLE_HOST = 'ssl://www.google.com'; +    const GOOGLE_HOST = 'ssl://spell.roundcube.net';      const GOOGLE_PORT = 443;      const MAX_SUGGESTIONS = 10; @@ -84,9 +84,6 @@ class rcube_spellchecker          if ($this->engine == 'pspell') {              $this->matches = $this->_pspell_check($this->content);          } -        else if ($this->engine == 'enchant') { -            $this->matches = $this->_enchant_check($this->content); -        }          else {              $this->matches = $this->_googie_check($this->content);          } @@ -118,9 +115,6 @@ class rcube_spellchecker          if ($this->engine == 'pspell') {              return $this->_pspell_suggestions($word);          } -        else if ($this->engine == 'enchant') { -            return $this->_enchant_suggestions($word); -        }          return $this->_googie_suggestions($word);      } @@ -139,9 +133,6 @@ class rcube_spellchecker          if ($this->engine == 'pspell') {              return $this->_pspell_words($text, $is_html);          } -        else if ($this->engine == 'enchant') { -            return $this->_enchant_words($text, $is_html); -        }          return $this->_googie_words($text, $is_html);      } @@ -323,6 +314,11 @@ class rcube_spellchecker          if (!$this->plink) {              if (!extension_loaded('pspell')) {                  $this->error = "Pspell extension not available"; +                rcube::raise_error(array( +                    'code' => 500, 'type' => 'php', +                    'file' => __FILE__, 'line' => __LINE__, +                    'message' => $this->error), true, false); +                  return;              } @@ -335,141 +331,6 @@ class rcube_spellchecker      } -    /** -     * Checks the text using enchant -     * -     * @param string $text Text content for spellchecking -     */ -    private function _enchant_check($text) -    { -        // init spellchecker -        $this->_enchant_init(); - -        if (!$this->enchant_dictionary) { -            return array(); -        } - -        // tokenize -        $text = preg_split($this->separator, $text, NULL, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_OFFSET_CAPTURE); - -        $diff       = 0; -        $matches    = array(); - -        foreach ($text as $w) { -            $word = trim($w[0]); -            $pos  = $w[1] - $diff; -            $len  = mb_strlen($word); - -            // skip exceptions -            if ($this->is_exception($word)) { -            } -            else if (!enchant_dict_check($this->enchant_dictionary, $word)) { -                $suggestions = enchant_dict_suggest($this->enchant_dictionary, $word); - -                if (sizeof($suggestions) > self::MAX_SUGGESTIONS) { -                    $suggestions = array_slice($suggestions, 0, self::MAX_SUGGESTIONS); -                } - -                $matches[] = array($word, $pos, $len, null, $suggestions); -            } - -            $diff += (strlen($word) - $len); -        } - -        return $matches; -    } - - -    /** -     * Returns the misspelled words -     */ -    private function _enchant_words($text = null, $is_html=false) -    { -        $result = array(); - -        if ($text) { -            // init spellchecker -            $this->_enchant_init(); - -            if (!$this->enchant_dictionary) { -                return array(); -            } - -            // With Enchant we don't need to get suggestions to return misspelled words -            if ($is_html) { -                $text = $this->html2text($text); -            } - -            $text = preg_split($this->separator, $text, NULL, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_OFFSET_CAPTURE); - -            foreach ($text as $w) { -                $word = trim($w[0]); - -                // skip exceptions -                if ($this->is_exception($word)) { -                    continue; -                } - -                if (!enchant_dict_check($this->enchant_dictionary, $word)) { -                    $result[] = $word; -                } -            } - -            return $result; -        } - -        foreach ($this->matches as $m) { -            $result[] = $m[0]; -        } - -        return $result; -    } - - -    /** -     * Returns suggestions for misspelled word -     */ -    private function _enchant_suggestions($word) -    { -        // init spellchecker -        $this->_enchant_init(); - -        if (!$this->enchant_dictionary) { -            return array(); -        } - -        $suggestions = enchant_dict_suggest($this->enchant_dictionary, $word); - -        if (sizeof($suggestions) > self::MAX_SUGGESTIONS) -            $suggestions = array_slice($suggestions, 0, self::MAX_SUGGESTIONS); - -        return is_array($suggestions) ? $suggestions : array(); -    } - - -    /** -     * Initializes PSpell dictionary -     */ -    private function _enchant_init() -    { -        if (!$this->enchant_broker) { -            if (!extension_loaded('enchant')) { -                $this->error = "Enchant extension not available"; -                return; -            } - -            $this->enchant_broker = enchant_broker_init(); -        } - -        if (!enchant_broker_dict_exists($this->enchant_broker, $this->lang)) { -            $this->error = "Unable to load dictionary for selected language using Enchant"; -            return; -        } - -        $this->enchant_dictionary = enchant_broker_request_dict($this->enchant_broker, $this->lang); -    } - -      private function _googie_check($text)      {          // spell check uri is configured @@ -493,7 +354,7 @@ class rcube_spellchecker          $gtext = '<?xml version="1.0" encoding="utf-8" ?>'              .'<spellrequest textalreadyclipped="0" ignoredups="0" ignoredigits="1" ignoreallcaps="1">' -            .'<text>' . $gtext . '</text>' +            .'<text>' . htmlspecialchars($gtext) . '</text>'              .'</spellrequest>';          $store = ''; @@ -511,19 +372,9 @@ class rcube_spellchecker              fclose($fp);          } -        // parse HTTP response -        if (preg_match('!^HTTP/1.\d (\d+)(.+)!', $store, $m)) { -            $http_status = $m[1]; -            if ($http_status != '200') -                $this->error = 'HTTP ' . $m[1] . $m[2]; -        } -          if (!$store) {              $this->error = "Empty result from spelling engine";          } -        else if (preg_match('/<spellresult error="([^"]+)"/', $store, $m) && $m[1]) { -            $this->error = "Error code $m[1] returned"; -        }          preg_match_all('/<c o="([^"]*)" l="([^"]*)" s="([^"]*)">([^<]*)<\/c>/', $store, $matches, PREG_SET_ORDER); | 
