From fcfd2064b5de9a33f34e8060194baaa750f01900 Mon Sep 17 00:00:00 2001 From: Giuseppe Bilotta Date: Tue, 18 Jul 2006 22:30:34 +0000 Subject: Improve SIG(INT|TERM|HUP) handling and shutting down sequence --- lib/rbot/ircbot.rb | 73 ++++++++++++++++++++++++++++++++------------------- lib/rbot/ircsocket.rb | 2 ++ 2 files changed, 48 insertions(+), 27 deletions(-) diff --git a/lib/rbot/ircbot.rb b/lib/rbot/ircbot.rb index aebb7db4..7c95e52e 100644 --- a/lib/rbot/ircbot.rb +++ b/lib/rbot/ircbot.rb @@ -15,6 +15,9 @@ def debug(message=nil) #yield end +# The following global is used for the improved signal handling. +$interrupted = 0 + # these first require 'rbot/rbotconfig' require 'rbot/config' @@ -315,14 +318,27 @@ class IrcBot } end + def got_sig(sig) + debug "received #{sig}, queueing quit" + $interrupted += 1 + debug "interrupted #{$interrupted} times" + if $interrupted >= 5 + debug "drastic!" + exit 2 + elsif $interrupted >= 3 + debug "quitting" + quit + end + end + # connect the bot to IRC def connect begin - trap("SIGINT") { quit } - trap("SIGTERM") { quit } - trap("SIGHUP") { quit } - rescue - debug "failed to trap signals, probably running on windows?" + trap("SIGINT") { got_sig("SIGINT") } + trap("SIGTERM") { got_sig("SIGTERM") } + trap("SIGHUP") { got_sig("SIGHUP") } + rescue => e + debug "failed to trap signals: #{e.inspect}\nProbably running on windows?" end begin @socket.connect @@ -346,11 +362,12 @@ class IrcBot break unless reply = @socket.gets @client.process reply end + quit if $interrupted > 0 end + # I despair of this. Some of my users get "connection reset by peer" # exceptions that ARENT SocketError's. How am I supposed to handle # that? - #rescue TimeoutError, SocketError => e rescue SystemExit exit 0 rescue TimeoutError, SocketError => e @@ -468,29 +485,19 @@ class IrcBot # disconnect from the server and cleanup all plugins and modules def shutdown(message = nil) - begin - trap("SIGINT", "DEFAULT") - trap("SIGTERM", "DEFAULT") - trap("SIGHUP", "DEFAULT") - rescue - debug "failed to trap signals, probably running on windows?" - end + debug "Shutting down ..." + ## No we don't restore them ... let everything run through + # begin + # trap("SIGINT", "DEFAULT") + # trap("SIGTERM", "DEFAULT") + # trap("SIGHUP", "DEFAULT") + # rescue => e + # debug "failed to restore signals: #{e.inspect}\nProbably running on windows?" + # end message = @lang.get("quit") if (message.nil? || message.empty?) - debug "Clearing socket" - @socket.clearq - debug "Saving" - save - debug "Cleaning up" - @plugins.cleanup - debug "Logging quits" - @channels.each_value {|v| - log "@ quit (#{message})", v.name - } - # debug "Closing registries" - # @registry.close - debug "Cleaning up the db environment" - DBTree.cleanup_env if @socket.connected? + debug "Clearing socket" + @socket.clearq debug "Sending quit message" @socket.puts "QUIT :#{message}" debug "Flushing socket" @@ -498,6 +505,18 @@ class IrcBot debug "Shutting down socket" @socket.shutdown end + debug "Logging quits" + @channels.each_value {|v| + log "@ quit (#{message})", v.name + } + debug "Saving" + save + debug "Cleaning up" + @plugins.cleanup + # debug "Closing registries" + # @registry.close + debug "Cleaning up the db environment" + DBTree.cleanup_env puts "rbot quit (#{message})" end diff --git a/lib/rbot/ircsocket.rb b/lib/rbot/ircsocket.rb index 2f66835f..5e0c797b 100644 --- a/lib/rbot/ircsocket.rb +++ b/lib/rbot/ircsocket.rb @@ -170,6 +170,8 @@ module Irc @sendq.clear end end + else + debug "Clearing socket while disconnected" end end -- cgit v1.2.3