Added support for broadcasting messages in one shot if the IRC server
supports multiple targets. (Inspircd only right now, need to add support for
more servers.) This will hopefully reduce flood issues and latency.
Cleaned up messages, improved use of color, added join notifications,
added a 'get ready' state 5 seconds before game starts.
Some code cleanup and refactoring.
This is a clone of a famous game involving a 4x4 grid of random letters.
It uses Plugin's inFilter to filter out private messages to the bot during
the game, so that they are not treated as commands. You can still send
commands to the bot using the command character during this period. When
the game ends, the filter puts things back to normal.
Also implemented a new command when DEBUG is True, wordsolve, which shows
the solution to the current wordgame.
It shouldn't need to know what specific parameters the game will take.
(And its "length" parameter was out of date since the games currently
use "difficulty".)
Some solution length logic was previously moved to handle_message. Some of
the code in _valid_solution became nonsensical (not broken, just weird).
Cleaned up.
Now defaults to the /usr/share/dict/american-english dictionary which is
probably found on many Linux systems today (avoiding the need to dig up a word
file on the interwebs). On Debian/Ubuntu, you can 'apt-get install wamerican'.
Added a configurable regexp to filter the word list down to reasonable words.
Defaults to allow lowercase a-z only, therefore filtering out proper names,
hyphenations, contractions, and words with accented characters like "adiós".
(But hopefully still supporting non-English users by allowing this to be
changed.)
Instead of taking lengths, the games now take easy|medium|hard|evil.
These values correspond to a range of puzzle lengths, word lengths, and
number of possible solutions. I attempted to tune them to reasonable
values, but I could see them changing.
Also did a little more code clean-up.
No substrings should occur in any word of any solution (not just two
successive words). This is really going to narrow down the set of puzzles,
hopefully it doesn't churn or get repetitive.
The two games have a lot in common, so factored out a base class called
WordChain that implements most of the logic. The game-specific behaviors
are implemented in the (now smaller) WordTwist and WordShrink classes.
Optimized to build a map of word relationships first and then derive all game
behavior from that map. This could probably be improved even more, but for
the moment it is working nicely.