From c27fee93082200ec068ae73bee1a5cb85431c67d Mon Sep 17 00:00:00 2001 From: Alexander Beisig Date: Mon, 26 Jun 2006 15:09:08 +0000 Subject: applied patch to topic.rb by [dmp] for #100 --- data/rbot/plugins/topic.rb | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) (limited to 'data/rbot/plugins') diff --git a/data/rbot/plugins/topic.rb b/data/rbot/plugins/topic.rb index e1c81808..c97eab2d 100755 --- a/data/rbot/plugins/topic.rb +++ b/data/rbot/plugins/topic.rb @@ -23,12 +23,14 @@ class TopicPlugin < Plugin return "topic sep(arator) [] => get or set the topic section separator" when "learn" return "topic learn => remembers the topic for later" + when "replace" + return "topic replace => Replaces section with " 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 add(at)|prepend|del|sep(arator)|learn|restore|set: " + \ + return "topic add(at)|prepend|del|sep(arator)|learn|replace|restore|set: " + \ "manipulate the topic of the current channel; use topic <#channel> " + \ "for private addressing" end @@ -68,6 +70,13 @@ class TopicPlugin < Plugin topicsep(m, ch, txt) when 'learn' learntopic(m, ch) + when 'replace' + if txt =~ /\s*(-?\d+)\s+(.*)\s*/ + num = $1.to_i - 1 + num += 1 if num < 0 + txt = $2 + replacetopic(m, ch, num, txt) + end when 'restore' restoretopic(m, ch) else @@ -143,6 +152,16 @@ class TopicPlugin < Plugin m.okay end + def replacetopic(m, channel, num, txt) + return if !@bot.auth.allow?("topic", m.source, m.replyto) + sep = getsep(channel) + topic = @bot.channels[channel].topic.to_s + topicarray = topic.split(/\s+#{Regexp.escape(sep)}\s*/) + topicarray[num] = txt + newtopic = topicarray.join(" #{sep} ") + @bot.topic channel, newtopic + end + def restoretopic(m, channel) return if !@bot.auth.allow?("restoretopic", m.source, m.replyto) if @registry.has_key?(channel) && @registry[channel].has_key?(:topic) -- cgit v1.2.3