summaryrefslogtreecommitdiff
path: root/chess-clock.el
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2002-04-19 07:53:38 +0000
committerJohn Wiegley <johnw@newartisans.com>2002-04-19 07:53:38 +0000
commit4e0af8d85ed9c1c8feb025abafe2dba87604ccb5 (patch)
tree5f1c83d3829350475e41abb3d3d5647f3dc276e6 /chess-clock.el
parent5e7133d9e7a77ea970f5ba1cbf60fe5a2d26cf17 (diff)
Fixes and other work.
Diffstat (limited to 'chess-clock.el')
-rw-r--r--chess-clock.el48
1 files changed, 29 insertions, 19 deletions
diff --git a/chess-clock.el b/chess-clock.el
index 4adea68..1494d93 100644
--- a/chess-clock.el
+++ b/chess-clock.el
@@ -33,31 +33,41 @@
(defun chess-clock-handler (game event &rest args)
(cond
((eq event 'initialize)
- (unless (chess-game-data game 'white-remaining)
- (chess-game-set-data game 'white-remaining (float (or (car args) 0))))
- (unless (chess-game-data game 'black-remaining)
- (chess-game-set-data game 'black-remaining (float (or (car args) 0))))
- (setq chess-clock-timer
- (run-with-timer 0 1 'chess-clock-tick-tock (current-buffer)))
+ (unless (or (null (car args))
+ (chess-game-data game 'white-remaining))
+ (chess-game-set-data game 'white-remaining (float (car args)))
+ (chess-game-set-data game 'black-remaining (float (car args))))
t)
((eq event 'post-undo)
- (let ((last-ply (car (last (chess-game-plies game) 2))))
- (chess-game-set-data game 'white-remaining
- (chess-ply-keyword last-ply :white))
- (chess-game-set-data game 'black-remaining
- (chess-ply-keyword last-ply :black))))
+ (let* ((last-ply (car (last (chess-game-plies game) 2)))
+ (white (chess-ply-keyword last-ply :white))
+ (black (chess-ply-keyword last-ply :black)))
+ (when (and white black)
+ (chess-game-set-data game 'white-remaining white)
+ (chess-game-set-data game 'black-remaining black))))
((eq event 'move)
- (when (> (chess-game-index game) 0)
- (let ((last-ply (car (last (chess-game-plies game) 2))))
- (chess-ply-set-keyword last-ply :white
- (chess-game-data game 'white-remaining))
- (chess-ply-set-keyword last-ply :black
- (chess-game-data game 'black-remaining)))))
+ (let ((white (chess-game-data game 'white-remaining))
+ (black (chess-game-data game 'black-remaining)))
+ (when (and white black (> (chess-game-index game) 0))
+ (setq chess-clock-timer
+ (run-with-timer 0 1 'chess-clock-tick-tock (current-buffer)))
+ (let ((last-ply (car (last (chess-game-plies game) 2))))
+ (chess-ply-set-keyword last-ply :white white)
+ (chess-ply-set-keyword last-ply :black black))))
+ (if (chess-game-over-p game)
+ (chess-clock-handler game 'destroy)))
- ((eq event 'destroy)
- (cancel-timer chess-clock-timer))))
+ ((eq event 'set-data)
+ (if (and (eq (car args) 'active)
+ (null (chess-game-data game 'active)))
+ (chess-clock-handler game 'destroy)))
+
+ ((memq event '(destroy resign drawn))
+ (when chess-clock-timer
+ (cancel-timer chess-clock-timer)
+ (setq chess-clock-timer)))))
(defvar chess-clock-tick-tocking nil)