@cache = cache
end
-
+
# whether the translator supports this direction
def support?(from, to)
from != to && @directions[from].include?(to)
end
def do_translate(text, from, to)
- @form.radiobuttons_with(:name => 'langpair').first.value = "#{from},#{to}".upcase
+ @radio = @form.radiobuttons_with(:name => 'langpair').first
+ @radio.value = "#{from},#{to}".upcase
+ @radio.check
@form.fields_with(:name => 'sourceText').last.value = text
@form.submit(@form.buttons_with(:name => 'translate').last).
end
def do_translate(text, from, to)
- if @form.fields_with(:name => 'trtext').first.empty?
+ if @form.fields_with(:name => 'trtext').empty?
@form.add_field!('trtext', text)
else
@form.fields_with(:name => 'trtext').first.value = text
end
@lang_list.value = "#{from}_#{to}"
- @form.submit.parser.search("td.s/div[@style]").inner_html
+ @form.submit.parser.search("div[@id='result']/div[@style]").inner_html
end
end
Config.register Config::IntegerValue.new('translator.timeout',
:default => 30, :validate => Proc.new{|v| v > 0},
:desc => _("Number of seconds to wait for the translation service before timeout"))
+ Config.register Config::StringValue.new('translator.destination',
+ :default => "en",
+ :desc => _("Default destination language to be used with translate command"))
TRANSLATORS = {
'nifty' => NiftyTranslator,
end
end
+ def languages
+ @languages ||= @translators.map { |t| t.last.directions.keys }.flatten.uniq
+ end
+
def update_default
- @default_translators = bot.config['translator.default_list'] & @translators.keys
+ @default_translators = bot.config['translator.default_list'] & @translators.keys
end
def cmd_translator(m, params)
- from, to = params[:from], params[:to]
- translator = @default_translators.find {|t| @translators[t].support?(from, to)}
+ params[:to] = @bot.config['translator.destination'] if params[:to].nil?
+
+ # Use google translate as translator if source language has not been given
+ # and auto-detect it
+ if params[:from].nil?
+ params[:from] = "auto"
+ translator = "google_translate"
+ else
+ translator = @default_translators.find {|t| @translators[t].support?(params[:from], params[:to])}
+ end
+
if translator
cmd_translate m, params.merge({:translator => translator, :show_provider => true})
else
end
m.reply(if params[:show_provider]
_('%{translation} (provided by %{translator})') %
- {:translation => translation, :translator => tname}
+ {:translation => translation, :translator => tname.gsub("_", " ")}
else
translation
end)
end
plugin = TranslatorPlugin.new
-plugin.map 'translator :from :to *phrase',
- :action => :cmd_translator, :thread => true
+req = Hash[*%w(from to).map { |e| [e.to_sym, /#{plugin.languages.join("|")}/] }.flatten]
+
+plugin.map 'translate [:from] [:to] *phrase',
+ :action => :cmd_translator, :thread => true, :requirements => req
+plugin.map 'translator [:from] [:to] *phrase',
+ :action => :cmd_translator, :thread => true, :requirements => req