summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/rbot/core/irclog.rb26
1 files changed, 22 insertions, 4 deletions
diff --git a/lib/rbot/core/irclog.rb b/lib/rbot/core/irclog.rb
index fcaf1b75..0c024ddd 100644
--- a/lib/rbot/core/irclog.rb
+++ b/lib/rbot/core/irclog.rb
@@ -8,6 +8,8 @@
# License:: GPL v2
class IrcLogModule < CoreBotModule
+
+ MAX_OPEN_FILES = 20 # XXX: maybe add a config value
def initialize
super
@@ -15,23 +17,39 @@ class IrcLogModule < CoreBotModule
Dir.mkdir("#{@bot.botclass}/logs") unless File.exist?("#{@bot.botclass}/logs")
end
+ def logfile_close(where_str, reason = 'unknown reason')
+ f = @logs.delete(where_str) or return
+ stamp = Time.now.strftime '%Y/%m/%d %H:%M:%S'
+ f[1].puts "[#{stamp}] @ Log closed by #{@bot.myself.nick} (#{reason})"
+ f[1].close
+ end
+
# log IRC-related message +message+ to a file determined by +where+.
# +where+ can be a channel name, or a nick for private message logging
def irclog(message, where="server")
message = message.chomp
- stamp = Time.now.strftime("%Y/%m/%d %H:%M:%S")
+ now = Time.now
+ stamp = now.strftime("%Y/%m/%d %H:%M:%S")
if where.class <= Server
where_str = "server"
else
where_str = where.downcase.gsub(/[:!?$*()\/\\<>|"']/, "_")
end
- unless(@logs.has_key?(where_str))
+ unless @logs.has_key? where_str
+ if @logs.size > MAX_OPEN_FILES
+ @logs.keys.sort do |a, b|
+ @logs[a][0] <=> @logs[b][0]
+ end.slice(0, @logs.size - MAX_OPEN_FILES).each do |w|
+ logfile_close w, "idle since #{@logs[w][0]}"
+ end
+ end
f = File.new("#{@bot.botclass}/logs/#{where_str}", "a")
f.sync = true
f.puts "[#{stamp}] @ Log started by #{@bot.myself.nick}"
- @logs[where_str] = f
+ @logs[where_str] = [now, f]
end
- @logs[where_str].puts "[#{stamp}] #{message}"
+ @logs[where_str][1].puts "[#{stamp}] #{message}"
+ @logs[where_str][0] = now
#debug "[#{stamp}] <#{where}> #{message}"
end