org.fife.com.swabunga.spell.event.AbstractWordTokenizer Maven / Gradle / Ivy
/*
Jazzy - a Java library for Spell Checking
Copyright (C) 2001 Mindaugas Idzelis
Full text of license can be found in LICENSE.txt
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
*/
package org.fife.com.swabunga.spell.event;
import java.text.BreakIterator;
/**
* This class tokenizes a input string.
*
*
* It also allows for the string to be mutated. The result after the spell
* checking is completed is available to the call to getFinalText
*
*
* @author Jason Height([email protected])
* @author Anthony Roy ([email protected])
*/
public abstract class AbstractWordTokenizer implements WordTokenizer {
//~ Instance/static variables ...............................................
/** The word being analyzed */
protected Word currentWord;
/** The word finder used to filter out words which are non pertinent to
* spell checking */
protected WordFinder finder;
/** An iterator to work through the sentence */
protected BreakIterator sentenceIterator;
/** The cumulative word count that have been processed */
protected int wordCount = 0;
//~ Constructors ............................................................
/**
* Creates a new AbstractWordTokenizer object.
*
* @param text the text to process.
*/
public AbstractWordTokenizer(String text) {
this(new DefaultWordFinder(text));
}
/**
* Creates a new AbstractWordTokenizer object.
*
* @param wf the custom WordFinder to use in searching for words.
*/
public AbstractWordTokenizer(WordFinder wf) {
this.finder = wf;
}
//~ Methods .................................................................
/**
* Returns the current number of words that have been processed
*
* @return number of words so far iterated.
*/
@Override
public int getCurrentWordCount() {
return wordCount;
}
/**
* Returns the end of the current word in the text
*
* @return index in string of the end of the current word.
* @throws WordNotFoundException current word has not yet been set.
*/
@Override
public int getCurrentWordEnd() {
if (currentWord == null) {
throw new WordNotFoundException("No Words in current String");
}
return currentWord.getEnd();
}
/**
* Returns the index of the start of the current word in the text
*
* @return index in string of the start of the current word.
* @throws WordNotFoundException current word has not yet been set.
*/
@Override
public int getCurrentWordPosition() {
if (currentWord == null) {
throw new WordNotFoundException("No Words in current String");
}
return currentWord.getStart();
}
/**
* Returns true if there are more words that can be processed in the string
*
* @return true if there are further words in the text.
*/
@Override
public boolean hasMoreWords() {
return finder.hasNext();
}
/**
* Returns searches for the next word in the text, and returns that word.
*
* @return the string representing the current word.
* @throws WordNotFoundException search string contains no more words.
*/
@Override
public String nextWord() {
currentWord = finder.next();
return currentWord.getText();
}
/**
* Replaces the current word token
*
* @param newWord replacement word.
* @throws WordNotFoundException current word has not yet been set.
*/
@Override
public abstract void replaceWord(String newWord);
/**
* Returns the current text that is being tokenized (includes any changes
* that have been made)
*
* @return the text being tokenized.
*/
@Override
public String getContext() {
return finder.toString();
}
/**
* returns true if the current word is at the start of a sentence
*
* @return true if the current word starts a sentence.
* @throws WordNotFoundException current word has not yet been set.
*/
@Override
public boolean isNewSentence() {
return finder.startsSentence();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy