1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
import signal
from src import Config, ModuleManager, utils
class Module(ModuleManager.BaseModule):
def on_load(self):
self._exited = False
signal.signal(signal.SIGINT, self.SIGINT)
signal.signal(signal.SIGUSR1, self.SIGUSR1)
signal.signal(signal.SIGHUP, self.SIGHUP)
def SIGINT(self, signum, frame):
print()
self.bot.trigger(lambda: self._kill(signum))
def _kill(self, signum):
if self._exited:
return
self._exited = True
self.events.on("signal.interrupt").call(signum=signum)
for server in self.bot.servers.values():
server.socket.clear_send_buffer()
line = server.send_quit("Shutting down")
server.send_enabled = False
line.on_send(self._make_hook(server))
def _make_hook(self, server):
return lambda: self.bot.disconnect(server)
def SIGUSR1(self, signum, frame):
self.bot.trigger(self._reload_config)
def SIGHUP(self, signum, frame):
self.bot.trigger(self._SIGHUP)
def _SIGHUP(self):
self._reload_config()
self._reload_modules()
def _reload_config(self):
self.bot.log.info("Reloading config file", [])
self.bot.config.load()
self.bot.log.info("Reloaded config file", [])
def _reload(self, name):
self.bot.modules.unload_module(name)
self.bot.modules.load_module(self.bot, name)
def _reload_modules(self):
self.bot.log.info("Reloading modules", [])
reloaded = []
failed = []
for name in list(self.bot.modules.modules.keys()):
try:
self._reload(name)
except ModuleManager.ModuleWarning:
continue
except Exception as e:
failed.append(name)
continue
reloaded.append(name)
self.bot.log.info("Reloaded %d modules (%d failed)",
[len(reloaded), len(failed)])
|