diff options
| author | Mario Lang <mlang@delysid.org> | 2014-03-24 10:08:02 +0100 | 
|---|---|---|
| committer | Mario Lang <mlang@delysid.org> | 2014-03-24 10:08:02 +0100 | 
| commit | 5a2cd0a0a96e38fd440055c2672b8a8ed0cc2b92 (patch) | |
| tree | 8c5d75ecdd54a587ed11935a2225ad5fd6814714 | |
| parent | 0e811560c1a7f374ea1eccb878b0b64adf54675d (diff) | |
More UCI engines: fruit and glaurung.
| -rw-r--r-- | chess-fruit.el | 68 | ||||
| -rw-r--r-- | chess-glaurung.el | 68 | ||||
| -rw-r--r-- | chess.el | 7 | 
3 files changed, 141 insertions, 2 deletions
| diff --git a/chess-fruit.el b/chess-fruit.el new file mode 100644 index 0000000..1067470 --- /dev/null +++ b/chess-fruit.el @@ -0,0 +1,68 @@ +;;; chess-fruit.el --- Play against fruit! + +;; Copyright (C) 2014  Free Software Foundation, Inc. + +;; Author: Mario Lang <mlang@delysid.org> +;; Keywords: games + +;; This file is free software; you can redistribute it and/or modify +;; it under the terms of the GNU General Public License as published by +;; the Free Software Foundation; either version 2, or (at your option) +;; any later version. + +;; This file is distributed in the hope that it will be useful, +;; but WITHOUT ANY WARRANTY; without even the implied warranty of +;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +;; GNU General Public License for more details. + +;; You should have received a copy of the GNU General Public License +;; along with GNU Emacs; see the file COPYING.  If not, write to +;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +;; Boston, MA 02111-1307, USA. + +;;; Code: + +(require 'chess-uci) + +(defgroup chess-fruit nil +  "The publically available chess engine 'fruit'." +  :group 'chess-engine +  :link '(url-link "http://www.fruitchess.com/")) + +(defcustom chess-fruit-path (executable-find "fruit") +  "*The path to the fruit executable." +  :type 'file +  :group 'chess-fruit) + +(defvar chess-fruit-regexp-alist +  (list +   (cons (concat "^bestmove\\s-+\\(" chess-algebraic-regexp "\\)") +	 (function +	  (lambda () +	    (funcall chess-engine-response-handler 'move +		     (chess-engine-convert-algebraic (match-string 1) t))))) +   (cons "^id\\s-+name\\s-+\\(.+\\)$" +	 (function +	  (lambda () +	    (setq-local chess-engine-opponent-name (match-string 1))))))) + +(defun chess-fruit-handler (game event &rest args) +  (unless chess-engine-handling-event +    (cond +     ((eq event 'initialize) +      (let ((proc (chess-uci-handler game 'initialize "fruit"))) +	(when (and proc (processp proc) (eq (process-status proc) 'run)) +	  (process-send-string proc "uci\n") +	  (setq chess-engine-process proc) +	  t))) + +     (t +      (if (and (eq event 'undo) +	       (= 1 (mod (car args) 2))) +	  (error "Cannot undo until after fruit moves")) + +      (apply 'chess-uci-handler game event args))))) + +(provide 'chess-fruit) + +;;; chess-fruit.el ends here diff --git a/chess-glaurung.el b/chess-glaurung.el new file mode 100644 index 0000000..5ce6042 --- /dev/null +++ b/chess-glaurung.el @@ -0,0 +1,68 @@ +;;; chess-glaurung.el --- Play against glaurung! + +;; Copyright (C) 2014  Free Software Foundation, Inc. + +;; Author: Mario Lang <mlang@delysid.org> +;; Keywords: games + +;; This file is free software; you can redistribute it and/or modify +;; it under the terms of the GNU General Public License as published by +;; the Free Software Foundation; either version 2, or (at your option) +;; any later version. + +;; This file is distributed in the hope that it will be useful, +;; but WITHOUT ANY WARRANTY; without even the implied warranty of +;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +;; GNU General Public License for more details. + +;; You should have received a copy of the GNU General Public License +;; along with GNU Emacs; see the file COPYING.  If not, write to +;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +;; Boston, MA 02111-1307, USA. + +;;; Code: + +(require 'chess-uci) + +(defgroup chess-glaurung nil +  "The publically available chess engine 'glaurung'." +  :group 'chess-engine +  :link '(url-link "http://www.glaurungchess.com/")) + +(defcustom chess-glaurung-path (executable-find "glaurung") +  "*The path to the glaurung executable." +  :type 'file +  :group 'chess-glaurung) + +(defvar chess-glaurung-regexp-alist +  (list +   (cons (concat "^bestmove\\s-+\\(" chess-algebraic-regexp "\\)") +	 (function +	  (lambda () +	    (funcall chess-engine-response-handler 'move +		     (chess-engine-convert-algebraic (match-string 1) t))))) +   (cons "^id\\s-+name\\s-+\\(.+\\)$" +	 (function +	  (lambda () +	    (setq-local chess-engine-opponent-name (match-string 1))))))) + +(defun chess-glaurung-handler (game event &rest args) +  (unless chess-engine-handling-event +    (cond +     ((eq event 'initialize) +      (let ((proc (chess-uci-handler game 'initialize "glaurung"))) +	(when (and proc (processp proc) (eq (process-status proc) 'run)) +	  (process-send-string proc "uci\n") +	  (setq chess-engine-process proc) +	  t))) + +     (t +      (if (and (eq event 'undo) +	       (= 1 (mod (car args) 2))) +	  (error "Cannot undo until after glaurung moves")) + +      (apply 'chess-uci-handler game event args))))) + +(provide 'chess-glaurung) + +;;; chess-glaurung.el ends here @@ -107,7 +107,10 @@ These can do just about anything."    :group 'chess)  (defcustom chess-default-engine -  '(chess-crafty chess-gnuchess chess-phalanx chess-ai) +  '(chess-crafty +    chess-stockfish chess-glaurung chess-fruit +    chess-gnuchess chess-phalanx +    chess-ai)    "Default engine to be used when starting a chess session.  A list indicates a series of alternatives if the first engine is not  available." @@ -158,7 +161,7 @@ If an element of MODULE-LIST is a sublist, treat it as alternatives."  	  (while module  	    (if (setq object (condition-case nil  				 (apply create-func (car module) args) -			       ((error nil)))) +			       (error nil)))  		(progn  		  (push object objects)  		  (setq module nil)) | 
