Mercurial > fife-parpg
annotate engine/extensions/timer.py @ 234:e4dfdf4c11fd
Workaround for a crash on Win32 when trying to print an event.
author | cheesesucker@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Mon, 23 Mar 2009 16:54:16 +0000 |
parents | fbc55c6f57cf |
children |
rev | line source |
---|---|
165
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
1 import fife |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
2 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
3 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
4 Convenient timers |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
5 ================= |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
6 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
7 Usage:: |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
8 import timer |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
9 timer.init( my_fife_engine.getTimeManager() ) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
10 def spam(): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
11 print "SPAM SPAM ", |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
12 return "More spam?" # a string is a true value, so it's repeated. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
13 repeater = timer.repeatCall(500,spam) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
14 def stop_spam(): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
15 repeater.stop() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
16 print "BACON EGGS AND SPAM" |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
17 timer.delayCall(50000,stop_spam) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
18 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
19 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
20 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
21 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
22 _manager = None |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
23 _alltimers = {} |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
24 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
25 def init(timemanager): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
26 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
27 Initialize timers. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
28 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
29 @param timemanager: A L{fife.TimeManager} as retuned by L{fife.Engine.getTimeManager}. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
30 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
31 global _manager |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
32 _manager = timemanager |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
33 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
34 class Timer(fife.TimeEvent): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
35 def __init__(self,delay=0,callback=None): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
36 super(Timer,self).__init__(0) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
37 self.is_registered = False |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
38 self.callback = callback |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
39 self.setPeriod(delay) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
40 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
41 def start(self): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
42 if self.is_registered: |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
43 return |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
44 self.is_registered = True |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
45 global _alltimers |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
46 _alltimers[self]=1 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
47 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
48 _manager.registerEvent(self) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
49 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
50 def stop(self): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
51 if not self.is_registered: |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
52 return |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
53 self.is_registered = False |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
54 global _alltimers |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
55 del _alltimers[self] |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
56 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
57 _manager.unregisterEvent(self) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
58 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
59 def updateEvent(self,delta): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
60 if callable(self.callback): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
61 self.callback() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
62 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
63 def delayCall(delay,callback): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
64 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
65 Delay a function call by a number of milliseconds. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
66 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
67 @param delay Delay in milliseconds. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
68 @param callback The function to call. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
69 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
70 @return The timer. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
71 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
72 timer = Timer(delay) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
73 def real_callback(): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
74 timer.stop() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
75 callback() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
76 timer.callback = real_callback |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
77 timer.start() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
78 return timer |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
79 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
80 from traceback import print_exc |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
81 def repeatCall(period,callback): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
82 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
83 Repeat a function call. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
84 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
85 @param period Period between calls in milliseconds. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
86 @param callback The function to call. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
87 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
88 @return The timer. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
89 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
90 The call is repeated until the callback returns a False |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
91 value (i.e. None) or the timer is stopped. |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
92 """ |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
93 timer = Timer(period) |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
94 def real_callback(): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
95 try: |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
96 if not callback(): |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
97 timer.stop() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
98 except Exception: |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
99 print_exc() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
100 timer.stop() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
101 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
102 timer.callback = real_callback |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
103 timer.start() |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
104 return timer |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
105 |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
106 __all__ = [init,Timer,delayCall,repeatCall] |
fbc55c6f57cf
(Convenient) Timers.
phoku@33b003aa-7bff-0310-803a-e67f0ece8222
parents:
diff
changeset
|
107 |