From: Giuseppe Bilotta Date: Sun, 20 Aug 2006 21:53:02 +0000 (+0000) Subject: Improve NOTICE and PRIVMSG robustness when target is not a simple channel or user X-Git-Url: https://git.netwichtig.de/gitweb/?a=commitdiff_plain;h=a0ab9e6d8022db22dd66412bb7a9087098e2faa2;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git Improve NOTICE and PRIVMSG robustness when target is not a simple channel or user --- diff --git a/ChangeLog b/ChangeLog index bcfd7a45..2006c958 100644 --- a/ChangeLog +++ b/ChangeLog @@ -2,6 +2,10 @@ * Topic plugin: fix a bug that prevented it from loading correctly. + * New IRC Framework: make sure that NOTICEs and PRIVMSGs do not + raise an exception when the target is in one of the special forms + # or $. Needs some work, though, since this case should be + handled specifically. 2006-08-17 Giuseppe Bilotta diff --git a/lib/rbot/rfc2812.rb b/lib/rbot/rfc2812.rb index e56c76bc..26549539 100644 --- a/lib/rbot/rfc2812.rb +++ b/lib/rbot/rfc2812.rb @@ -1095,7 +1095,15 @@ module Irc # parse it yourself, or you can bind to 'MSG', 'PUBLIC', # etc and get it all nicely split up for you. - data[:target] = @server.user_or_channel(argv[0]) + begin + data[:target] = @server.user_or_channel(argv[0]) + rescue + # The previous may fail e.g. when the target is a server or something + # like that (e.g. $). In any of these cases, we just use the + # String as a target + # FIXME we probably want to explicitly check for the # $ + data[:target] = argv[0] + end data[:message] = argv[1] handle(:privmsg, data) @@ -1106,7 +1114,15 @@ module Irc handle(:msg, data) end when 'NOTICE' - data[:target] = @server.user_or_channel(argv[0]) + begin + data[:target] = @server.user_or_channel(argv[0]) + rescue + # The previous may fail e.g. when the target is a server or something + # like that (e.g. $). In any of these cases, we just use the + # String as a target + # FIXME we probably want to explicitly check for the # $ + data[:target] = argv[0] + end data[:message] = argv[1] case data[:source] when User