summaryrefslogtreecommitdiffstats
path: root/tdespell2/plugins/hspell/tdespell_hspelldict.cpp
diff options
context:
space:
mode:
authorDarrell Anderson <humanreadable@yahoo.com>2013-03-02 15:57:34 -0600
committerDarrell Anderson <humanreadable@yahoo.com>2013-03-02 15:57:34 -0600
commit7c0b0c9dc9fcbe9c198925bdc7ee18ac6be49f4f (patch)
treec76702a7f6310fbe9d437e347535422e836e94e9 /tdespell2/plugins/hspell/tdespell_hspelldict.cpp
parenta2a38be7600e2a2c2b49c66902d912ca036a2c0f (diff)
parent27bbee9a5f9dcda53d8eb23863ee670ad1360e41 (diff)
downloadtdelibs-7c0b0c9dc9fcbe9c198925bdc7ee18ac6be49f4f.tar.gz
tdelibs-7c0b0c9dc9fcbe9c198925bdc7ee18ac6be49f4f.zip
Merge branch 'master' of http://scm.trinitydesktop.org/scm/git/tdelibs
Diffstat (limited to 'tdespell2/plugins/hspell/tdespell_hspelldict.cpp')
-rw-r--r--tdespell2/plugins/hspell/tdespell_hspelldict.cpp107
1 files changed, 107 insertions, 0 deletions
diff --git a/tdespell2/plugins/hspell/tdespell_hspelldict.cpp b/tdespell2/plugins/hspell/tdespell_hspelldict.cpp
new file mode 100644
index 000000000..fa2efaccb
--- /dev/null
+++ b/tdespell2/plugins/hspell/tdespell_hspelldict.cpp
@@ -0,0 +1,107 @@
+/**
+ * tdespell_hspelldict.cpp
+ *
+ * Copyright (C) 2003 Zack Rusin <zack@kde.org>
+ * Copyright (C) 2005 Mashrab Kuvatov <kmashrab@uni-bremen.de>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301 USA
+ */
+
+#include "tdespell_hspelldict.h"
+#include <kdebug.h>
+
+#include <tqtextcodec.h>
+
+using namespace KSpell2;
+
+HSpellDict::HSpellDict( const TQString& lang )
+ : Dictionary( lang )
+{
+ int int_error = hspell_init( &m_speller, HSPELL_OPT_DEFAULT );
+ if ( int_error == -1 )
+ kdDebug() << "HSpellDict::HSpellDict: Init failed" << endl;
+ /* hspell understans only iso8859-8-i */
+ codec = TQTextCodec::codecForName( "iso8859-8-i" );
+}
+
+HSpellDict::~HSpellDict()
+{
+ /* It exists in =< hspell-0.8 */
+ hspell_uninit( m_speller );
+}
+
+bool HSpellDict::check( const TQString& word )
+{
+ kdDebug() << "HSpellDict::check word = " << word <<endl;
+ int preflen;
+ TQCString wordISO = codec->fromUnicode( word );
+ /* returns 1 if the word is correct, 0 otherwise */
+ int correct = hspell_check_word ( m_speller,
+ wordISO,
+ &preflen); //this going to be removed
+ //in next hspell releases
+ /* I do not really understand what gimatria is */
+ if( correct != 1 ){
+ if( hspell_is_canonic_gimatria( wordISO ) != 0 )
+ correct = 1;
+ }
+ return correct == 1;
+}
+
+TQStringList HSpellDict::suggest( const TQString& word )
+{
+ TQStringList qsug;
+ struct corlist cl;
+ int n_sugg;
+ corlist_init( &cl );
+ hspell_trycorrect( m_speller, codec->fromUnicode( word ), &cl );
+ for( n_sugg = 0; n_sugg < corlist_n( &cl ); n_sugg++){
+ qsug.append( codec->toUnicode( corlist_str( &cl, n_sugg) ) );
+ }
+ corlist_free( &cl );
+ return qsug;
+}
+
+bool HSpellDict::checkAndSuggest( const TQString& word,
+ TQStringList& suggestions )
+{
+ bool c = check( word );
+ if( c )
+ suggestions = suggest( word );
+ return c;
+}
+
+bool HSpellDict::storeReplacement( const TQString& bad,
+ const TQString& good )
+{
+ // hspell-0.9 cannot do this
+ kdDebug() << "HSpellDict::storeReplacement: Sorry, cannot." << endl;
+ return false;
+}
+
+bool HSpellDict::addToPersonal( const TQString& word )
+{
+ // hspell-0.9 cannot do this
+ kdDebug() << "HSpellDict::addToPersonal: Sorry, cannot." << endl;
+ return false;
+}
+
+bool HSpellDict::addToSession( const TQString& word )
+{
+ // hspell-0.9 cannot do this
+ kdDebug() << "HSpellDict::addToSession: Sorry, cannot." << endl;
+ return false;
+}