diff options
| author | 2018-09-29 15:05:50 +0100 | |
|---|---|---|
| committer | 2018-09-29 15:05:50 +0100 | |
| commit | bcb67db3fdf33a81b7702e96c204b4085a7cc691 (patch) | |
| tree | 36fa0c3d0c721353564d1fec5c92228e0abbd85f /src | |
| parent | Actually get "item" when a cached item expires (diff) | |
| signature | ||
Add !reloadscripts to modules/scripts.py
Diffstat (limited to 'src')
| -rw-r--r-- | src/EventManager.py | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/src/EventManager.py b/src/EventManager.py index 2c4f3125..b8a5ecfb 100644 --- a/src/EventManager.py +++ b/src/EventManager.py @@ -59,12 +59,16 @@ class EventHookContext(object): self.context = context def hook(self, function, priority=DEFAULT_PRIORITY, replay=False, **kwargs): - self._parent._context_hook(self.context, function, priority, replay, - kwargs) + return self._parent._context_hook(self.context, function, priority, + replay, kwargs) + def unhook(self, callback): + self._parent.unhook(callback) + def on(self, subevent, *extra_subevents, delimiter=DEFAULT_EVENT_DELIMITER): return self._parent._context_on(self.context, subevent, extra_subevents, delimiter) + def call_for_result(self, default=None, **kwargs): return self._parent.call_for_result(default, **kwargs) def assure_call(self, **kwargs): @@ -73,6 +77,7 @@ class EventHookContext(object): return self._parent.call(**kwargs) def call_limited(self, maximum, **kwargs): return self._parent.call_limited(maximum, **kwargs) + def get_hooks(self): return self._parent.get_hooks() def get_children(self): @@ -104,9 +109,9 @@ class EventHook(object): def hook(self, function, priority=DEFAULT_PRIORITY, replay=False, **kwargs): - self._hook(function, None, priority, replay, kwargs) + return self._hook(function, None, priority, replay, kwargs) def _context_hook(self, context, function, priority, replay, kwargs): - self._hook(function, context, priority, replay, kwargs) + return self._hook(function, context, priority, replay, kwargs) def _hook(self, function, context, priority, replay, kwargs): callback = EventCallback(function, priority, kwargs) @@ -121,6 +126,20 @@ class EventHook(object): for kwargs in self._stored_events: self._call(kwargs) self._stored_events = None + return callback + + def unhook(self, callback): + if callback in self._hooks: + self._hooks.remove(callback) + + empty = [] + for context, hooks in self._context_hooks.items(): + if callback in hooks: + hooks.remove(callback) + if not hooks: + empty.append(context) + for context in empty: + del self._context_hooks[context] def _make_multiple_hook(self, source, context, events): multiple_event_hook = MultipleEventHook() |
