summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/rbot/ircbot.rb40
1 files changed, 26 insertions, 14 deletions
diff --git a/lib/rbot/ircbot.rb b/lib/rbot/ircbot.rb
index 92f5fe55..5713d175 100644
--- a/lib/rbot/ircbot.rb
+++ b/lib/rbot/ircbot.rb
@@ -801,6 +801,7 @@ class Bot
:purge_split => @config['send.purge_split'],
:truncate_text => @config['send.truncate_text'].dup
+ @signals = []
trap_sigs
end
@@ -904,26 +905,35 @@ class Bot
end
# things to do when we receive a signal
- def got_sig(sig, func=:quit)
- debug "received #{sig}, queueing #{func}"
- # this is not an interruption if we just need to reconnect
- $interrupted += 1 unless func == :reconnect
- self.send(func) unless @quit_mutex.locked?
- debug "interrupted #{$interrupted} times"
- if $interrupted >= 3
- debug "drastic!"
- log_session_end
- exit 2
+ def handle_sigs
+ while sig = @signals.shift
+ func = case sig
+ when 'SIGHUP'
+ :restart
+ when 'SIGUSR1'
+ :reconnect
+ else
+ :quit
+ end
+ debug "received #{sig}, queueing #{func}"
+ # this is not an interruption if we just need to reconnect
+ $interrupted += 1 unless func == :reconnect
+ self.send(func) unless @quit_mutex.locked?
+ debug "interrupted #{$interrupted} times"
+ if $interrupted >= 3
+ debug "drastic!"
+ log_session_end
+ exit 2
+ end
end
end
# trap signals
def trap_sigs
begin
- trap("SIGINT") { got_sig("SIGINT") }
- trap("SIGTERM") { got_sig("SIGTERM") }
- trap("SIGHUP") { got_sig("SIGHUP", :restart) }
- trap("SIGUSR1") { got_sig("SIGUSR1", :reconnect) }
+ %w(SIGINT SIGTERM SIGHUP SIGUSR1).each do |sig|
+ trap(sig) { @signals << sig }
+ end
rescue ArgumentError => e
debug "failed to trap signals (#{e.pretty_inspect}): running on Windows?"
rescue Exception => e
@@ -1006,10 +1016,12 @@ class Bot
quit_msg = nil
valid_recv = false # did we receive anything (valid) from the server yet?
begin
+ handle_sigs
reconnect(quit_msg, too_fast)
quit if $interrupted > 0
valid_recv = false
while @socket.connected?
+ handle_sigs
quit if $interrupted > 0
# Wait for messages and process them as they arrive. If nothing is