NAME
WordBrain::Prefix - Creates a Cache of Valid Word Prefixes
SYNOPSIS
# Create new Prefix Cache
my $prefix = Game::WordBrain::Prefix->new({
max_prefix_length => 5, # Optional
word_list => '/path/to/wordlist', # Optional
});
# Test if a string could be the start of a word
my $start_of_word = 'fla';
if( $prefix->is_start_of_word( $start_of_word ) ) {
print "Could be a word...";
}
else {
print "Nope, no way this is going to be a word.";
}
DESCRIPTION
Game::WordBrain::Prefix is the largest speedup afforded to the Game::WordBrain->solve method. It works by reading in a wordlist and using it to construct a hash of valid word prefixes. As an example, let's take the word "flag"
{
'f' => 1,
'fl' => 1,
'fla' => 1,
'flag' => 1,
}
By creating this Game::WordBrain is able to check if the current path being walked ( collection of Game::WordBrain::Letters ) could possibly ever be a real word. By leverage the fact that, for example, no word in the english language starts with 'flaga' we can short circuit and abandon a path that will not lead to a solution sa fast as possible.
ATTRIBUTES
max_prefix_length
The length of the prefixes to build. This should equal the max Game::WordBrain::WordToFind->{num_letters}. If not provided, it defaults to 8.
Keep in mind, the larger this value the longer the spin up time needed in order to run the solver.
word_list
Path to a new line delimited word_list. If not provided, the wordlist provided with this distrubtion will be used.
METHODS
new
my $prefix = Game::WordBrain::Prefix->new({
max_prefix_length => 5, # Optional
word_list => '/path/to/wordlist', # Optional
});
If the max_prefix length is not specified it will default to 8. If no word_list is specified then the bundled wordlist will be used.
Returns an instance of Game::WordBrain::Prefix
is_start_of_word
my $prefix = Game::WordBrain::Prefix->...;
my $start_of_word = 'fla';
if( $prefix->is_start_of_word( $start_of_word ) ) {
print "Could be a word...";
}
else {
print "Nope, no way this is going to be a word.";
}
Given a string, will check to seeif there are any words in the provided word_list that start with this string. If there are ( meaning this could become a real word at some point ) a truthy value is returned. If not, a falsey value is returned.