création d'un dispatcher d'événement central.
[minwii.git] / src / app / eventutils.py
index 10ddbad..1741579 100755 (executable)
@@ -27,28 +27,61 @@ $Id$
 $URL$
 """
 import types
+import pygame
+
+class _EventDispatcher :
+    def __init__(self) :
+        self.registry = {}
+        
+    def addEventListener(self, eventType, listener) :
+        if self.registry.has_key(eventType) :
+            self.registry[eventType].append(listener)
+        else :
+            self.registry[eventType] = [listener]
+    
+    def dispatchEvents(self) :
+        events = pygame.event.get()
+        for event in events :
+            listeners = self.registry.get(event.type, [])
+            for listener in listeners :
+                listener(event)
+
+EventDispatcher = _EventDispatcher()
 
 def event_handler(eventType) :
-    def doRename(m) :
-        m.__name__ = 'eventHandler%s' % eventType
+    def markFunctionAsListener(m) :
+        m.__islistener__ = True
+        m.__eventtype__ = eventType
         return m
-    return doRename
+    return markFunctionAsListener
 
 
-class MetaRenamer(type):
-    def __new__(mcs, name, bases, dict) :
-        for k, v in dict.items() :
-            if isinstance(v, types.FunctionType) :
-                if k != v.__name__ :
-                    print 'renommage de %s en %s' % (k, v.__name__)
-                    dict[v.__name__] = v
-                    del dict[k]
-        return type.__new__(mcs, name, bases, dict)
+class EventInitializer(type):
+    
+    def __init__(cls, name, bases, dict) :
+        def init_listeners(self) :
+            for k, v in dict.items() :
+                if isinstance(v, types.FunctionType) and hasattr(v, '__islistener__') :
+                    listener = getattr(self, k)
+                    EventDispatcher.addEventListener(v.__eventtype__, listener)
+                    del v.__islistener__
+                    del v.__eventtype__
+        
+        def ctor(self, *args, **kw) :
+            init_listeners(self)
+            default_ctor = dict.get('__init__')
+            if not default_ctor :
+                super(cls, self).__init__(*args, **kw)
+            else :
+                default_ctor(self, *args, **kw)
+        
+        cls.__init__ = ctor
 
 
 class EventHandlerMixin(object) :
-    __metaclass__ = MetaRenamer
+    __metaclass__ = EventInitializer
     
-    def input(self, event) :
-        handler = getattr(self, 'eventHandler%s' % event.type, lambda e:None)
-        handler(event)
+    #def input(self) :
+    #    event = pygame.event.wait()
+    #    handler = getattr(self, 'eventHandler%s' % event.type, lambda e:None)
+    #    handler(event)