diff options
author | Tom Gilbert <tom@linuxbrit.co.uk> | 2005-07-27 15:59:13 +0000 |
---|---|---|
committer | Tom Gilbert <tom@linuxbrit.co.uk> | 2005-07-27 15:59:13 +0000 |
commit | 21949774b91eaec6ecde4eaa8ad121e2c0a36b87 (patch) | |
tree | 41a7601e168018ac203bad7ca8d7f9f82515bc28 /rbot/plugins/tube.rb | |
parent | 51cf09ec02d089bfdd80e5f728cfc92a234dc437 (diff) |
rearrange repo for packaging
Diffstat (limited to 'rbot/plugins/tube.rb')
-rw-r--r-- | rbot/plugins/tube.rb | 77 |
1 files changed, 0 insertions, 77 deletions
diff --git a/rbot/plugins/tube.rb b/rbot/plugins/tube.rb deleted file mode 100644 index 77ca5227..00000000 --- a/rbot/plugins/tube.rb +++ /dev/null @@ -1,77 +0,0 @@ -#Tube Status Enquiry plugin for rbot -#Plugin by Colm Linehan - -require 'rexml/document' -require 'uri/common' - -class TubePlugin < Plugin - include REXML - def help(plugin, topic="") - "tube [district|circle|metropolitan|central|jubilee|bakerloo|waterloo_city|hammersmith_city|victoria|eastlondon|northern|piccadilly] => display tube service status for the specified line(Docklands Light Railway is not currently supported), tube stations => list tube stations (not lines) with problems" - end - def privmsg(m) - if m.params && m.params =~ /^stations$/ - check_stations m - elsif m.params && m.params =~ /^(.*)$/ - line = $1.downcase.capitalize - check_tube m, line - end - end - - def check_tube(m, line) - begin - tube_page = @bot.httputil.get(URI.parse("http://www.tfl.gov.uk/tfl/service_rt_tube.shtml"), 1, 1) - rescue URI::InvalidURIError, URI::BadURIError => e - m.reply "Cannot contact Tube Service Status page" - return - end - unless tube_page - m.reply "Cannot contact Tube Service Status page" - return - end - next_line = false - tube_page.each_line {|l| - next if l == "\r\n" - next if l == "\n" - if (next_line) - if (l =~ /^<tr valign=top> <td>\s*(.*)<\/td><\/tr>/i) - m.reply $1.split(/<[^>]+>| /i).join(" ") - return - else - m.reply "There are problems on the #{line} line, but I didn't understand the page format. You should check out http://www.tfl.gov.uk/tfl/service_rt_tube.shtml for more details." - return - end - end - next_line = true if (l =~ /class="#{line}"/i) - } - m.reply "No Problems on the #{line} line." - end - - def check_stations(m) - begin - tube_page = @bot.httputil.get(URI.parse("http://www.tfl.gov.uk/tfl/service_rt_tube.shtml")) - rescue URI::InvalidURIError, URI::BadURIError => e - m.reply "Cannot contact Tube Service Status page" - return - end - unless tube_page - m.reply "Cannot contact Tube Service Status page" - return - end - stations_array = Array.new - tube_page.each_line {|l| - if (l =~ /<tr valign=top> <td valign="middle" class="Station"><b>(.*)<\/b><\/td><\/tr>\s*/i) - stations_array.push $1 - end - } - if stations_array.empty? - m.reply "There are no station-specific announcements" - return - else - m.reply stations_array.join(", ") - return - end - end -end -plugin = TubePlugin.new -plugin.register("tube") |