From 8538e56167676b9bfa600c489caf3f94b2a33e50 Mon Sep 17 00:00:00 2001 From: Giuseppe Bilotta Date: Wed, 7 Jun 2006 14:43:22 +0000 Subject: New features (private addressing) and cleanup for the topic plugin --- data/rbot/plugins/topic.rb | 220 ++++++++++++++++++++++++--------------------- 1 file changed, 120 insertions(+), 100 deletions(-) (limited to 'data/rbot') diff --git a/data/rbot/plugins/topic.rb b/data/rbot/plugins/topic.rb index 075b6942..c3e5bf24 100755 --- a/data/rbot/plugins/topic.rb +++ b/data/rbot/plugins/topic.rb @@ -1,145 +1,165 @@ # Author: Giuseppe "Oblomov" Bilotta # Add a bunch of topic manipulation features -# NOTE: topic separator is defined by the global symbol SEPARATOR - -SEPARATOR=" | " class TopicPlugin < Plugin def initialize super - @addtopic = /(?:topic(?:append|add)|(?:append|add)topic)/ - @prependtopic = /(?:topicprepend|prependtopic)/ - @addtopicat = /(?:(?:addtopic|topicadd)at)/ - @deltopic = /(?:deltopic|topicdel)/ + @separator = "|" # default separator end def help(plugin, topic="") case plugin when "topic" case topic - when @addtopic - return "#{topic} => add at the end the topic" - when @prependtopic - return "#{topic} => add at the beginning of the topic" - when @addtopicat - return "#{topic} => add at position of the topic" - when @deltopic - return "#{topic} => remove section from the topic" - when "learntopic" - return "learntopic => remembers the topic for later" - when "resumetopic" - return "resumetopic => resets the topic to the latest remembered one" - when "settopic" - return "settopic => sets the topic to " + when "add" + return "topic add => add at the end the topic" + when "prepend" + return "topic prepend => add at the beginning of the topic" + when "addat" + return "topic addat => add at position of the topic" + when "del" + return "topic del => remove section from the topic" + when "separator" + return "topic sep(arator) [] => get or set the topic section separator" + when "learn" + return "topic learn => remembers the topic for later" + when "restore" + return "topic restore => resets the topic to the latest remembered one" + when "set" + return "topic set => sets the topic to " else - return "topic commands: addtopic, prependtopic, addtopicat, deltopic, learntopic, resumetopic, settopic" + return "topic add(at)|prepend|del|sep(arator)|learn|restore|set: " + \ + "manipulate the topic of the current channel; use topic <#channel> " + \ + "for private addressing" + end + end + end + + def handletopic(m, param) + return unless m.kind_of?(PrivMessage) + if m.public? + ch = m.channel.downcase + else + ch = param[:channel].downcase + end + cmd = param[:command] + txt = param[:text].join(" ") + case cmd + when /a(dd|ppend)/ + topicappend(m, ch, txt) + when 'prepend' + topicprepend(m, ch, txt) + when 'addat' + if txt =~ /\s*(-?\d+)\s+(.*)\s*/ + num = $1.to_i - 1 + num += 1 if num < 0 + txt = $2 + topicaddat(m, ch, num, txt) + end + when /del(ete)?/ + if txt =~ /\s*(-?\d+)\s*/ + num=$1.to_i - 1 + num += 1 if num < 0 + topicdel(m, ch, num) + end + when /set/ + topicset(m, ch, txt) + when /sep(arator)?/ + topicsep(m, ch, txt) + when /learn/ + learntopic(m, ch) + when /restore/ + restoretopic(m, ch) + else + m.reply 'unknown command' + end + end + + def topicsep(m, ch, txt) + if txt + sep = txt.strip + if sep != "" + setsep(ch, sep) end - when "learntopic" - return "learntopic => remembers the topic for later" - when "resumetopic" - return "resumetopic => resets the topic to the latest remembered one" - when "settopic" - return "settopic => sets the topic to " end + m.reply "Topic separator set to #{getsep(ch)}" + end + + def setsep(ch, sep) + if @registry.has_key?(ch) + data = @registry[ch] + else + data = Hash.new + end + data[:separator] = sep + @registry[ch] = data end - def listen(m) - return unless m.kind_of?(PrivMessage) && m.public? - command = m.message.dup - debug command - if m.address? || command.gsub!(/^!/, "") - case command - when /^#{@addtopic}\s+(.*)\s*/ - txt=$1 - debug txt - if @bot.auth.allow?("topic", m.source, m.replyto) - topicappend(m, txt) - end - when /^#{@prependtopic}\s+(.*)\s*/ - txt=$1 - debug txt - if @bot.auth.allow?("topic", m.source, m.replyto) - topicaddat(m, 0, txt) - end - when /^#{@addtopicat}\s+(-?\d+)\s+(.*)\s*/ - num=$1.to_i - 1 - num += 1 if num < 0 - txt=$2 - debug txt - if @bot.auth.allow?("topic", m.source, m.replyto) - topicaddat(m, num, txt) - end - when /^#{@deltopic}\s+(-?\d+)\s*/ - num=$1.to_i - 1 - num += 1 if num < 0 - debug num - if @bot.auth.allow?("topic", m.source, m.replyto) - topicdel(m, num) - end + def getsep(ch) + if @registry.has_key?(ch) + if @registry[ch].has_key?(:separator) + return @registry[ch][:separator] end end + return @separator end - def topicaddat(m, num, txt) - channel = m.channel.downcase - topic = @bot.channels[m.channel].topic.to_s - topicarray = topic.split(SEPARATOR) + def topicaddat(m, channel, num, txt) + sep = getsep(channel) + topic = @bot.channels[channel].topic.to_s + topicarray = topic.split(/\s+#{sep}\s*/) topicarray.insert(num, txt) - newtopic = topicarray.join(SEPARATOR) + newtopic = topicarray.join(" #{sep} ") @bot.topic channel, newtopic end - def topicappend(m, txt) - channel = m.channel.downcase - topic = @bot.channels[m.channel].topic.to_s - topicarray = topic.split(SEPARATOR) - topicarray << txt - newtopic = topicarray.join(SEPARATOR) - @bot.topic channel, newtopic + def topicappend(m, ch, txt) + topicaddat(m, ch, -1, txt) end - def topicdel(m, num) - channel = m.channel.downcase - topic = @bot.channels[m.channel].topic.to_s - topicarray = topic.split(SEPARATOR) + def topicprepend(m, ch, txt) + topicaddat(m, ch, 0, txt) + end + + def topicdel(m, channel, num) + sep = getsep(channel) + topic = @bot.channels[channel].topic.to_s + topicarray = topic.split(/\s+#{sep}\s*/) topicarray.delete_at(num) - newtopic = topicarray.join(SEPARATOR) + newtopic = topicarray.join(" #{sep} ") @bot.topic channel, newtopic end - def learntopic(m, param) + def learntopic(m, channel) return if !@bot.auth.allow?("learntopic", m.source, m.replyto) - channel = m.channel.downcase - debug channel - topic = @bot.channels[m.channel].topic.to_s - @registry[channel] = topic - @bot.say channel, "Ok" + topic = @bot.channels[channel].topic.to_s + if @registry.has_key?(channel) + data = @registry[channel] + else + data = Hash.new + end + data[:topic] = topic + @registry[channel] = data + m.okay end - def resumetopic(m, param) - return if !@bot.auth.allow?("resumetopic", m.source, m.replyto) - channel = m.channel.downcase - debug "Channel: #{channel}" - if @registry.has_key?(channel) - topic = @registry[channel] - debug "Channel: #{channel}, topic: #{topic}" + def restoretopic(m, channel) + return if !@bot.auth.allow?("restoretopic", m.source, m.replyto) + if @registry.has_key?(channel) && @registry[channel].has_key?(:topic) + topic = @registry[channel][:topic] @bot.topic channel, topic else - @bot.say channel, "Non ricordo nulla" + m.reply "I don't remember any topic for this channel" end end - def settopic(m, param) + def topicset(m, channel, text) return if !@bot.auth.allow?("topic", m.source, m.replyto) - channel = m.channel.downcase - debug "Channel: #{channel}" - @bot.topic channel, param[:text].to_s + @bot.topic channel, text end end plugin = TopicPlugin.new -plugin.register 'topic' -plugin.map 'settopic *text', :action => 'settopic' -plugin.map 'resumetopic' -plugin.map 'learntopic' +plugin.map 'topic :command *text', :action => 'handletopic', :public => true, :private => false +plugin.map 'topic :channel :command *text', :action => 'handletopic', :public => false, :private => true -- cgit v1.2.3