diff options
author | Jason Katz-Brown <jason@airbnb.com> | 2013-08-25 02:17:13 -0700 |
---|---|---|
committer | Jason Katz-Brown <jason@airbnb.com> | 2013-08-25 02:17:13 -0700 |
commit | 9306cb60c32082c5403931de0823a9fd5daa196c (patch) | |
tree | ca1b6eb695fdf3f0c2294e92416b272164bae642 /quackleio/dictimplementation.cpp | |
parent | 8fb2c681cecc01b46b0f4ba02d5cc177c4747b1c (diff) |
Initial git commit.
Diffstat (limited to 'quackleio/dictimplementation.cpp')
-rw-r--r-- | quackleio/dictimplementation.cpp | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/quackleio/dictimplementation.cpp b/quackleio/dictimplementation.cpp new file mode 100644 index 0000000..5ea2e15 --- /dev/null +++ b/quackleio/dictimplementation.cpp @@ -0,0 +1,104 @@ +/* + * Quackle -- Crossword game artificial intelligence and analysis tool + * Copyright (C) 2005-2006 Jason Katz-Brown and John O'Laughlin. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + * 02110-1301 USA + */ + +#include <alphabetparameters.h> +#include <datamanager.h> +#include <generator.h> +#include <lexiconparameters.h> +#include <quackleio/util.h> + +#include "dictimplementation.h" + +QuackleIO::DictImplementation::DictImplementation() +{ +} + +QuackleIO::DictImplementation::~DictImplementation() +{ +} + +Dict::WordList QuackleIO::DictImplementation::query(const QString &query, int flags) +{ + QString modifiedQuery = query; + modifiedQuery.replace(".", "?"); + + int anagramFlags = Quackle::Generator::ClearBlanknesses; + + if (flags & Dict::Querier::NoRequireAllLetters) + anagramFlags |= Quackle::Generator::NoRequireAllLetters; + + QRegExp wildcardRegexp("[\\*/]"); + if (wildcardRegexp.indexIn(modifiedQuery) >= 0) + { + if (!(flags & Dict::Querier::NoRequireAllLetters)) + anagramFlags |= Quackle::Generator::AddAnyLetters; + + modifiedQuery.replace(wildcardRegexp, QString()); + } + + vector<Quackle::LetterString> words(m_generator.anagramLetters(QuackleIO::Util::encode(modifiedQuery), anagramFlags)); + Dict::WordList ret; + + vector<Quackle::LetterString>::const_iterator end = words.end(); + for (vector<Quackle::LetterString>::const_iterator it = words.begin(); it != end; ++it) + { + Dict::Word dictWord; + dictWord.word = QuackleIO::Util::letterStringToQString(*it); + dictWord.wordLetterString = (*it); + m_generator.storeWordInfo(&dictWord); + + if (flags & WithExtensions) + m_generator.storeExtensions(&dictWord); + + ret.push_back(dictWord); + } + + if (flags & NoRequireAllLetters) + { + ret.setSortBy(Dict::WordList::LengthLongestFirst); + } + else + { + ret.setSortBy(Dict::WordList::Alphabetical); + } + + qSort(ret); + + return ret; +} + +QString QuackleIO::DictImplementation::alphagram(const QString &letters) const +{ + return QuackleIO::Util::letterStringToQString(QuackleIO::Util::alphagram(QuackleIO::Util::encode(letters))); +} + +bool QuackleIO::DictImplementation::isLoaded() const +{ + return QUACKLE_LEXICON_PARAMETERS->hasSomething(); +} + +bool QuackleIO::DictImplementation::isBritish(const Quackle::LetterString &word) +{ + Quackle::WordWithInfo wordWithInfo; + wordWithInfo.wordLetterString = word; + m_generator.storeWordInfo(&wordWithInfo); + return wordWithInfo.british; +} + |