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"
40 #read in the lart and praise files
41 if File.exists? "#{@bot.botclass}/lart/larts"
42 IO.foreach("#{@bot.botclass}/lart/larts") { |line|
46 if File.exists? "#{@bot.botclass}/lart/praises"
47 IO.foreach("#{@bot.botclass}/lart/praises") { |line|
48 @praises << line.chomp
59 Dir.mkdir("#{@bot.botclass}/lart") if not FileTest.directory? "#{@bot.botclass}/lart"
60 # TODO implement safe saving here too
61 File.open("#{@bot.botclass}/lart/larts", "w") { |file|
64 File.open("#{@bot.botclass}/lart/praises", "w") { |file|
72 m.reply "What a crazy fool! Did you mean |help stats?"
76 meth = self.method(@@handlers[m.plugin])
77 meth.call(m) if(@bot.auth.allow?(m.plugin, m.source, m.replyto))
81 def help(plugin, topic="")
82 "Lart: The lart plugin allows you to lart/praise someone in the channel. You can also add new larts and new praises as well as delete them. For the curious, LART is an acronym for Luser Attitude Readjustment Tool. Usage: lart <who> [<reason>] -- larts <who> for <reason>. praise <who> [<reason>] -- praises <who> for <reason>. [add|rm][lart|praise] -- Add or remove a lart or praise."
85 # The following are command handlers {{{
88 for_idx = m.params =~ /\s+\bfor\b/
90 nick = m.params[0, for_idx]
94 lart = @larts[get_msg_idx(@larts.length)]
96 m.reply "I dunno any larts"
100 lart = replace_who lart, m.sourcenick
101 lart << " for trying to make me lart myself"
103 lart = replace_who lart, nick
104 lart << m.params[for_idx, m.params.length] if for_idx
107 @bot.action m.replyto, lart
112 for_idx = m.params =~ /\s+\bfor\b/
114 nick = m.params[0, for_idx]
118 praise = @praises[get_msg_idx(@praises.length)]
120 m.reply "I dunno any praises"
124 if nick == m.sourcenick
125 praise = @larts[get_msg_idx(@larts.length)]
126 praise = replace_who praise, nick
128 praise = replace_who praise, nick
129 praise << m.params.gsub(/#{nick}/, "")
132 @bot.action m.replyto, praise
136 def handle_addlart(m)
143 @larts.delete m.params
148 def handle_addpraise(m)
154 def handle_rmpraise(m)
155 @praises.delete m.params
161 # The following are utils for larts/praises {{{
163 def replace_who(msg, nick)
164 msg.gsub(/<who>/i, "#{nick}")
174 plugin = LartPlugin.new
175 plugin.register("lart")
176 plugin.register("praise")
178 plugin.register("addlart")
179 plugin.register("addpraise")
181 plugin.register("rmlart")
182 plugin.register("rmpraise")