1 # Author: Michael Brailsford <brailsmt@yahoo.com>
3 # Purpose: Provide for humorous larts and praises
4 # Copyright: 2002 Michael Brailsford. All rights reserved.
5 # License: This plugin is licensed under the BSD license. The terms of
8 # Redistribution and use in source and binary forms, with or without
9 # modification, are permitted provided that the following conditions
12 # 1. Redistributions of source code must retain the above copyright notice,
13 # this list of conditions and the following disclaimer.
15 # 2. Redistributions in binary form must reproduce the above copyright
16 # notice, this list of conditions and the following disclaimer in the
17 # documentation and/or other materials provided with the distribution.
19 class LartPlugin < Plugin
21 # Keep a 1:1 relation between commands and handlers
23 "lart" => "handle_lart",
24 "praise" => "handle_praise",
25 "addlart" => "handle_addlart",
26 "rmlart" => "handle_rmlart",
27 "addpraise" => "handle_addpraise",
28 "rmpraise" => "handle_rmpraise"
36 #read in the lart and praise files
37 if File.exists? "#{@bot.botclass}/lart/larts"
38 IO.foreach("#{@bot.botclass}/lart/larts") { |line|
42 if File.exists? "#{@bot.botclass}/lart/praises"
43 IO.foreach("#{@bot.botclass}/lart/praises") { |line|
44 @praises << line.chomp
55 Dir.mkdir("#{@bot.botclass}/lart") if not FileTest.directory? "#{@bot.botclass}/lart"
56 File.open("#{@bot.botclass}/lart/larts", "w") { |file|
59 File.open("#{@bot.botclass}/lart/praises", "w") { |file|
67 m.reply "What a crazy fool! Did you mean |help stats?"
71 meth = self.method(@@handlers[m.plugin])
72 meth.call(m) if(@bot.auth.allow?(m.plugin, m.source, m.replyto))
76 def help(plugin, topic="")
77 "Lart: The lart plugin allows you to punish/praise someone in the channel. You can also add new punishments and new praises as well as delete them. For the curious, LART is an acronym for Luser Attitude Readjustment Tool.\nUsage: punish/lart <nick> <reason> -- punishes <nick> for <reason>. The reason is optional.\n praise <nick> <reason> -- praises <nick> for <reason>. The reason is optional.\n mod[lart|punish|praise] [add|remove] -- Add or remove a lart or praise."
80 # The following are command handlers {{{
83 for_idx = m.params =~ /\s+\bfor\b/
85 nick = m.params[0, for_idx]
89 lart = @larts[get_msg_idx(@larts.length)]
91 m.reply "I dunno any larts"
95 lart = replace_who lart, m.sourcenick
96 lart << " for trying to make me lart myself"
98 lart = replace_who lart, nick
99 lart << m.params[for_idx, m.params.length] if for_idx
102 @bot.action m.replyto, lart
107 for_idx = m.params =~ /\s+\bfor\b/
109 nick = m.params[0, for_idx]
113 praise = @praises[get_msg_idx(@praises.length)]
115 m.reply "I dunno any praises"
119 if nick == m.sourcenick
120 praise = @larts[get_msg_idx(@larts.length)]
121 praise = replace_who praise, nick
123 praise = replace_who praise, nick
124 praise << m.params.gsub(/#{nick}/, "")
127 @bot.action m.replyto, praise
131 def handle_addlart(m)
138 @larts.delete m.params
143 def handle_addpraise(m)
149 def handle_rmpraise(m)
150 @praises.delete m.params
156 # The following are utils for larts/praises {{{
158 def replace_who(msg, nick)
159 msg.gsub(/<who>/i, "#{nick}")
169 plugin = LartPlugin.new
170 plugin.register("lart")
171 plugin.register("praise")
173 plugin.register("addlart")
174 plugin.register("addpraise")
176 plugin.register("rmlart")
177 plugin.register("rmpraise")