diff options
author | Dmitry Kim <dmitry point kim at gmail point com> | 2007-04-05 09:09:35 +0000 |
---|---|---|
committer | Dmitry Kim <dmitry point kim at gmail point com> | 2007-04-05 09:09:35 +0000 |
commit | e67353c23940b892e0546c8451facb54064561aa (patch) | |
tree | 939637cbe4c53d57a072f04e15a91abb5c0cfa14 /data/rbot/plugins | |
parent | 23b75487b51e7bb0850c66e320eda586658aed80 (diff) |
+ (fish) webpage translation support
Diffstat (limited to 'data/rbot/plugins')
-rw-r--r-- | data/rbot/plugins/fish.rb | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/data/rbot/plugins/fish.rb b/data/rbot/plugins/fish.rb index d7dda52b..68e6d29c 100644 --- a/data/rbot/plugins/fish.rb +++ b/data/rbot/plugins/fish.rb @@ -5,7 +5,7 @@ Net::HTTP.version_1_2 class BabelPlugin < Plugin LANGS = %w{en fr de it pt es nl ru zh zt el ja ko} def help(plugin, topic="") - "translate to <lang> <string> => translate from english to <lang>, translate from <lang> <string> => translate to english from <lang>, translate <fromlang> <tolang> <string> => translate from <fromlang> to <tolang>. Languages: #{LANGS.join(', ')}" + "translate to <lang> <string> => translate from english to <lang>, translate from <lang> <string> => translate to english from <lang>, translate <fromlang> <tolang> <string> => translate from <fromlang> to <tolang>. If <string> is an http url, translates the referenced webpage and returns the 1st content paragraph. Languages: #{LANGS.join(', ')}" end def translate(m, params) langs = LANGS @@ -13,7 +13,6 @@ class BabelPlugin < Plugin trans_to = params[:tolang] ? params[:tolang] : 'en' trans_text = params[:phrase].to_s - query = "/babelfish/tr" lang_match = langs.join("|") unless(trans_from =~ /^(#{lang_match})$/ && trans_to =~ /^(#{lang_match})$/) m.reply "invalid language: valid languagess are: #{langs.join(' ')}" @@ -22,6 +21,14 @@ class BabelPlugin < Plugin data_text = URI.escape trans_text trans_pair = "#{trans_from}_#{trans_to}" + + if (trans_text =~ /^http:\/\//) && (URI.parse(trans_text) rescue nil) + url = 'http://babelfish.altavista.com/babelfish/trurl_pagecontent' + + "?lp=#{trans_pair}&url=#{data_text}" + + return Utils.get_first_pars([url], 1, :message => m) + end + data = "lp=#{trans_pair}&doit=done&intl=1&tt=urltext&urltext=#{data_text}" # check cache for previous lookups @@ -34,6 +41,8 @@ class BabelPlugin < Plugin "content-type" => "application/x-www-form-urlencoded; charset=utf-8" } + query = "/babelfish/tr" + begin resp = @bot.httputil.get_response('http://babelfish.altavista.com'+query, :method => :post, |