diff options
| author | dickmao <rchiang@cs.stonybrook.edu> | 2018-08-28 21:48:31 -0400 | 
|---|---|---|
| committer | dickmao <dick.r.chiang@gmail.com> | 2018-08-30 00:14:42 -0400 | 
| commit | 800dd7677276f9e425c5db37b3e31e56ab1dad32 (patch) | |
| tree | 09eb145ffcbaf89d873c89e8346ee8d38a88ebbe /chess-ics.el | |
| parent | 5bd1e7248bb9bf3b335cbd6bec250866bd165af1 (diff) | |
Add tests for castling legality and ics response handling.
Fixes misinterpretation of "e1-b1" as a valid queenside castle, and
makes more sense of ics basic response handling #21.
`make test` should run the historic.pgn test and the new ecukes tests.
Diffstat (limited to 'chess-ics.el')
| -rw-r--r-- | chess-ics.el | 24 | 
1 files changed, 14 insertions, 10 deletions
| diff --git a/chess-ics.el b/chess-ics.el index 24162be..51ce1e0 100644 --- a/chess-ics.el +++ b/chess-ics.el @@ -314,7 +314,12 @@ standard position).  In those cases, this variable should be set to nil.")  		  (white (match-string-no-properties 2))  		  (black (match-string-no-properties 3)))  	      (message "Creating game %d (%s vs. %s)" game-number white black) -	      (chess-ics-game game-number :White white :Black black))))) +              ; chess-module-set-game* would add event handlers +              ; to the game as if it were an engine game +              ; We just need (chess-engine-game nil) to return the game. +              (setq chess-engine-opponent-name (if (string= white chess-ics-handle) black white)) +              (setq chess-module-game (chess-ics-game game-number :White white :Black black)) +))))     (cons "^<10>$" (function (lambda () (chess-ics-send "style 12\nrefresh"))))     (cons "^Game \\([0-9]+\\): \\S-+ backs up \\([0-9]+\\).$"  	 (function @@ -369,17 +374,17 @@ standard position).  In those cases, this variable should be set to nil.")     (cons "\\S-+ would like to take back \\([0-9]+\\) half move(s)."  	 (function  	  (lambda () -	    (funcall chess-engine-response-handler 'undo +	    (funcall #'chess-engine-default-handler 'undo  		     (string-to-number (match-string 1))))))     (cons "The game has been aborted on move [^.]+\\."  	 (function  	  (lambda ()  	    (let ((chess-engine-pending-offer 'abort)) -	      (funcall chess-engine-response-handler 'accept))))) +	      (funcall #'chess-engine-default-handler 'accept)))))     (cons "\\S-+ accepts the takeback request\\."  	 (function  	  (lambda () -	    (funcall chess-engine-response-handler 'accept)))) +	    (funcall #'chess-engine-default-handler 'accept))))     (cons ;; resign announcement      "{Game \\([0-9]+\\) (\\(\\S-+\\) vs\\. \\(\\S-+\\)) \\(\\S-+\\) resigns}"      (function @@ -391,7 +396,7 @@ standard position).  In those cases, this variable should be set to nil.")  				   :Black (match-string 3))))  	 (with-current-buffer (chess-game-data game 'engine)  	   (if opponent-p -	       (funcall chess-engine-response-handler 'resign) +	       (funcall #'chess-engine-default-handler 'resign)  	     (unless (chess-game-status game)  	       (chess-game-end game :resign))))  	 t)))) @@ -399,19 +404,19 @@ standard position).  In those cases, this variable should be set to nil.")  	 (function  	  (lambda ()  	    (if (string= (match-string 1) chess-engine-opponent-name) -		(funcall chess-engine-response-handler 'flag-fell) -	      (funcall chess-engine-response-handler 'call-flag t))))) +		(funcall #'chess-engine-default-handler 'flag-fell) +	      (funcall #'chess-engine-default-handler 'call-flag t)))))     (cons "Illegal move (\\([^)]+\\))\\."  	 (function  	  (lambda () -	    (funcall chess-engine-response-handler 'illegal +	    (funcall #'chess-engine-default-handler 'illegal  		     (match-string 1)))))     (cons "Challenge: \\(\\S-+\\) \\S-+ \\S-+ \\S-+ .+"  	 (function  	  (lambda ()  	    (let ((opponent (match-string 1)))  	      (if (y-or-n-p (chess-string 'want-to-play opponent)) -		  (chess-ics-send (concat "accept " opponent)) +                  (chess-ics-send (concat "accept " opponent))  		(chess-ics-send "decline match"))))))     ;; Buttonize URLs.     (cons "\"?\\(\\(https?\\|ftp\\)://[^ \t\n\r\"]+\\)\"?" @@ -470,7 +475,6 @@ See `chess-ics-game'.")         (chess-game-set-data game 'ics-game-number game-number)         (chess-game-set-data game 'ics-buffer (current-buffer))         (chess-game-set-tag game "Site" chess-ics-server) -       (chess-engine-set-response-handler (current-buffer))         (while tags  	 (cl-assert (keywordp (car tags)))  	 (chess-game-set-tag | 
