X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=lib%2Frbot%2Fmessage.rb;h=155f9038b34640c9a9e6a704cb6a9bb2c49ea2c1;hb=744be8fffda676653475d3034786e8ee246de609;hp=64c4b6bbd95e94aed368e5290cdfc44440078ac7;hpb=783ffa4235330029d661752b1023db635b26f2b3;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/lib/rbot/message.rb b/lib/rbot/message.rb index 64c4b6bb..155f9038 100644 --- a/lib/rbot/message.rb +++ b/lib/rbot/message.rb @@ -30,7 +30,7 @@ module Irc end - # Define standard IRC attriubtes (not so standard actually, + # Define standard IRC attributes (not so standard actually, # but the closest thing we have ...) Bold = "\002" Underline = "\037" @@ -72,7 +72,7 @@ module Irc :dark_gray => 14, :lightgray => 15, :light_gray => 15, - :white => 16 + :white => 0 } # Convert a String or Symbol into a color number @@ -159,7 +159,11 @@ module Irc ret << ' plainmessage=' << plainmessage.inspect ret << fields if fields ret << ' (identified)' if identified? - ret << ' (addressed to me)' if address? + if address? + ret << ' (addressed to me' + ret << ', with prefix' if prefixed? + ret << ')' + end ret << ' (replied)' if replied? ret << ' (ignored)' if ignored? ret << ' (in thread)' if in_thread? @@ -179,6 +183,7 @@ module Irc @bot = bot @source = source @address = false + @prefixed = false @target = target @message = message || "" @replied = false @@ -237,6 +242,12 @@ module Irc return @address end + # returns true if the messaged was addressed to the bot via the address + # prefix. This can be used to tell appart "!do this" from "botname, do this" + def prefixed? + return @prefixed + end + # strip mIRC colour escapes from a string def BasicUserMessage.stripcolour(string) return "" unless string @@ -342,6 +353,7 @@ module Irc bot.config['core.address_prefix'].each {|mprefix| if @message.gsub!(/^#{Regexp.escape(mprefix)}\s*/, "") @address = true + @prefixed = true break end } @@ -403,19 +415,27 @@ module Irc reply string, {:nick => true}.merge(options) end + # Same as nickreply, but always prepend the target's nick. + def nickreply!(string, options={}) + reply string, {:nick => true, :forcenick => true}.merge(options) + end + # The general way to reply to a command. The following options are available: # :nick [false, true, :auto] # state if the nick of the user calling the command should be prepended # :auto uses core.reply_with_nick # + # :forcenick [false, true] + # if :nick is true, always prepend the target's nick, even if the nick + # already appears in the reply. Defaults to false. + # # :to [:private, :public, :auto] # where should the bot reply? # :private always reply to the nick # :public reply to the channel (if available) # :auto uses core.private_replies - def reply(string, options={}) - opts = {:nick => :auto, :to => :auto}.merge options + opts = {:nick => :auto, :forcenick => false, :to => :auto}.merge options if opts[:nick] == :auto opts[:nick] = @bot.config['core.reply_with_nick'] @@ -429,7 +449,8 @@ module Irc if (opts[:nick] && opts[:to] != :private && - string !~ /(?:^|\W)#{Regexp.escape(@source.to_s)}(?:$|\W)/) + (string !~ /(?:^|\W)#{Regexp.escape(@source.to_s)}(?:$|\W)/ || + opts[:forcenick])) string = "#{@source}#{@bot.config['core.nick_postfix']} #{string}" end to = (opts[:to] == :private) ? source : @channel @@ -453,15 +474,14 @@ module Irc @bot.ctcp_notice @source, @ctcp, string, options end - # convenience method to reply "okay" in the current language to the - # message - def plainokay - self.reply @bot.lang.get("okay"), :nick => false + # convenience method to reply a literal message in the current language to the message + def plain_literal(ident) + self.reply @bot.lang.get(ident), :nick => false end # Like the above, but append the username - def nickokay - str = @bot.lang.get("okay").dup + def nick_literal(ident) + str = @bot.lang.get(ident).dup if self.public? # remove final punctuation str.gsub!(/[!,.]$/,"") @@ -471,9 +491,13 @@ module Irc end # the default okay style is the same as the default reply style - # def okay - @bot.config['core.reply_with_nick'] ? nickokay : plainokay + @bot.config['core.reply_with_nick'] ? nick_literal('okay') : plain_literal('okay') + end + + # thanks the user in reply + def thanks + @bot.config['core.reply_with_nick'] ? nick_literal('thanks') : plain_literal('thanks') end # send a NOTICE to the message source @@ -591,6 +615,21 @@ module Irc end end + # class to manage LIST replies + class ListMessage < BasicUserMessage + attr_accessor :list + def initialize(bot, server, source, target, list=Hash.new) + super(bot, server, source, target, "") + @list = [] + end + + def inspect + fields = ' list=' << list.inspect + super(fields) + end + end + + # class to manage NAME replies class NamesMessage < BasicUserMessage attr_accessor :users @@ -605,6 +644,22 @@ module Irc end end + # class to manager Ban list replies + class BanlistMessage < BasicUserMessage + # the bans + attr_accessor :bans + + def initialize(bot, server, source, target, message="") + super(bot, server, source, target, message) + @bans = [] + end + + def inspect + fields = ' bans=' << bans.inspect + super(fields) + end + end + class QuitMessage < BasicUserMessage attr_accessor :was_on def initialize(bot, server, source, target, message="") @@ -661,6 +716,18 @@ module Irc class PartMessage < JoinMessage end + # class to handle ERR_NOSUCHNICK and ERR_NOSUCHCHANNEL + class NoSuchTargetMessage < BasicUserMessage + # the channel or nick that was not found + attr_reader :target + + def initialize(bot, server, source, target, message='') + super(bot, server, source, target, message) + + @target = target + end + end + class UnknownMessage < BasicUserMessage end end