lang = params[:lang]
addlang = params[:addlang]
autoadd = @autoadd_base + addlang.to_s
- if Wordlist.exist?(lang)
+ if Wordlist.exist?(@bot, lang)
# wordlists are assumed to be UTF-8, but we need to strip the BOM, if present
- words = Wordlist.get(lang)
+ words = Wordlist.get(@bot, lang)
if addlang and File.exist?(autoadd)
word += File.readlines(autoadd).map {|line| line.sub("\xef\xbb\xbf",'').strip}
end
return _("az => start a game if none is running, show the current word range otherwise; you can say 'az <language>' if you want to play in a language different from the current bot default")
end
langs = @rules.keys
- wls = Wordlist.list
+ wls = Wordlist.list(@bot)
return [
_("az topics: play, rules, cancel, manage, check"),
_("available languages: %{langs}") % { :langs => langs.join(", ") },
params[:word].join(" ")
elsif params[:wordlist]
begin
- wordlist = Wordlist.get(params[:wordlist].join("/"), :spaces => true)
+ wordlist = Wordlist.get(@bot, params[:wordlist].join("/"), :spaces => true)
rescue
raise _("no such wordlist")
end
unless ruleset.has_key?(:words)
if ruleset.has_key?(:wordlist_file)
begin
- ruleset[:words] =
- File.new(datafile(ruleset[:wordlist_file])).grep(
- ruleset[:listen]) {|l| ruleset[:normalize].call l.chomp}
+ ruleset[:words] = Wordlist.get(@bot, ruleset[:wordlist_file], :spaces => true)
+ .grep(ruleset[:listen]) {|l| ruleset[:normalize].call l.chomp}
rescue
raise "unable to load word list"
end
module ::Irc
class Bot
class Wordlist
- def self.wordlist_base
- @@wordlist_base ||= Utils.bot.path 'wordlists'
- end
-
- def self.get(where, options={})
+ def self.get(bot, where, options={})
+ wordlist_base = bot.path('wordlists')
opts = { :spaces => false }.merge(options)
wordlist_path = File.join(wordlist_base, where)
# Return an array with the list of available wordlists.
# Available options:
# pattern:: pattern that should be matched by the wordlist filename
- def self.list(options={})
+ def self.list(bot, options={})
+ wordlist_base = bot.path('wordlists')
pattern = options[:pattern] || "**"
# refuse patterns that contain ../
return [] if pattern =~ /\.\.\//
- striplen = self.wordlist_base.length+1
- Dir.glob(File.join(self.wordlist_base, pattern)).map { |name|
+ striplen = wordlist_base.length+1
+ Dir.glob(File.join(wordlist_base, pattern)).map { |name|
name[striplen..-1]
}
end
- def self.exist?(path)
+ def self.exist?(bot, path)
+ wordlist_base = bot.path('wordlists')
fn = path.to_s
# refuse to check outside of the wordlist base directory
return false if fn =~ /\.\.\//
- File.exist?(File.join(self.wordlist_base, fn))
+ File.exist?(File.join(wordlist_base, fn))
end
end
end
def do_list(m, p)
- found = Wordlist.list(p)
+ found = Wordlist.list(@bot, p)
if found.empty?
- m.reply _("no wordlist found")
+ m.reply _("no wordlists found in %{path}") % {
+ path: @bot.path('wordlists')
+ }
else
m.reply _("Wordlists: %{found}") % {
- :found => found.sort.join(', ')
+ found: found.sort.join(', ')
}
end
end