diff options
Diffstat (limited to 'kspell2/backgroundthread.cpp')
-rw-r--r-- | kspell2/backgroundthread.cpp | 115 |
1 files changed, 0 insertions, 115 deletions
diff --git a/kspell2/backgroundthread.cpp b/kspell2/backgroundthread.cpp deleted file mode 100644 index 0f3471537..000000000 --- a/kspell2/backgroundthread.cpp +++ /dev/null @@ -1,115 +0,0 @@ -/** - * backgroundthread.cpp - * - * Copyright (C) 2004 Zack Rusin <zack@kde.org> - * - * 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 "backgroundthread.h" - -#include "threadevents.h" -#include "broker.h" -#include "filter.h" -#include "dictionary.h" - -#include <kdebug.h> -#include <tqapplication.h> - -using namespace KSpell2; - -BackgroundThread::BackgroundThread() - : TQThread(), m_broker( 0 ), m_dict( 0 ) -{ - m_recv = 0; - m_filter = Filter::defaultFilter(); - m_done = false; -} - -void BackgroundThread::setReceiver( TQObject *recv ) -{ - m_recv = recv; -} - -void BackgroundThread::setBroker( const Broker::Ptr& broker ) -{ - stop(); - m_broker = broker; - delete m_dict; - m_dict = m_broker->dictionary(); - m_filter->restart(); -} - -TQStringList BackgroundThread::suggest( const TQString& word ) const -{ - return m_dict->suggest( word ); -} - -void BackgroundThread::run() -{ - m_mutex.lock(); - m_done = false; - for ( Word w = m_filter->nextWord(); !m_done && !w.end; - w = m_filter->nextWord() ) { - if ( !m_dict->check( w.word ) && !m_done ) { - MisspellingEvent *event = new MisspellingEvent( w.word, w.start ); - TQApplication::postEvent( m_recv, event ); - } - } - m_mutex.unlock(); - FinishedCheckingEvent *event = new FinishedCheckingEvent(); - TQApplication::postEvent( m_recv, event ); -} - -void BackgroundThread::setText( const TQString& buff ) -{ - stop(); - m_mutex.lock(); - m_filter->setBuffer( buff ); - m_mutex.unlock(); - start(); -} - -void BackgroundThread::setFilter( Filter *filter ) -{ - stop(); - m_mutex.lock(); - Filter *oldFilter = m_filter; - m_filter = filter; - if ( oldFilter ) { - m_filter->setBuffer( oldFilter->buffer() ); - oldFilter->setBuffer( TQString::null ); - } - m_mutex.unlock(); - start(); -} - -void BackgroundThread::changeLanguage( const TQString& lang ) -{ - stop(); - m_mutex.lock(); - delete m_dict; - m_dict = m_broker->dictionary( lang ); - m_filter->restart(); - m_mutex.unlock(); - start(); -} - -void BackgroundThread::stop() -{ - //### maybe terminate() would be better than using m_done - m_done = true; - wait(); -} |