From 56e8b9b9f1c37a68b93cf09e790d6c8ed238e683 Mon Sep 17 00:00:00 2001 From: panxinmiao Date: Fri, 6 Sep 2024 14:02:03 +0800 Subject: [PATCH] update --- wgpu/gui/base.py | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/wgpu/gui/base.py b/wgpu/gui/base.py index 54d3640f..e6bb5bc1 100644 --- a/wgpu/gui/base.py +++ b/wgpu/gui/base.py @@ -276,10 +276,9 @@ def handle_event(self, event): event_type = event.get("event_type") callbacks = self._event_handlers[event_type] + self._event_handlers["*"] # Dispatch - for callback in callbacks: + for _, callback in callbacks: with log_exception(f"Error during handling {event['event_type']} event"): if event.get("stop_propagation", False): - del event["stop_propagation"] break callback(event) @@ -334,13 +333,9 @@ def my_handler(event): raise TypeError(f"Event types must be str, but got {type}") def decorator(_callback): - _callback.__dict__["__event_order"] = order for type in types: - self._event_handlers[type].append(_callback) - self._event_handlers[type].sort( - key=lambda x: x.__dict__["__event_order"] - ) - + self._event_handlers[type].append((order, _callback)) + self._event_handlers[type].sort(key=lambda x: x[0]) return _callback if decorating: