]> git.eshelyaron.com Git - emacs.git/commitdiff
(gomoku-buffer-name): New constant.
authorGlenn Morris <rgm@gnu.org>
Sat, 12 Apr 2003 15:51:57 +0000 (15:51 +0000)
committerGlenn Morris <rgm@gnu.org>
Sat, 12 Apr 2003 15:51:57 +0000 (15:51 +0000)
(gomoku-mode): Doc fix.  Add call to kill-all-local-variables,
for global-font-lock-mode.
(gomoku): Do not call gomoku-switch-to-window directly, else the
player is asked the startup questions twice after a killed game.
(gomoku-prompt-for-other-game): Throw an error if no new game,
since otherwise answering no after a killed game has no effect.
(gomoku-switch-to-window): Use gomoku-buffer-name.

lisp/ChangeLog
lisp/play/gomoku.el

index 3113adfc023f73846b6e5e5d62793553d2bda04a..5b4616a27eefa4005da32f0e4a21deb0e5327621 100644 (file)
@@ -1,3 +1,17 @@
+2003-04-12  Glenn Morris  <gmorris@ast.cam.ac.uk>
+
+       * play/gomoku.el (gomoku-buffer-name): New constant.
+       (gomoku-mode): Doc fix.  Add call to kill-all-local-variables.
+       (gomoku): Do not call gomoku-switch-to-window directly.
+       (gomoku-prompt-for-other-game): Throw an error if no new game.
+       (gomoku-switch-to-window): Use gomoku-buffer-name.
+
+       * progmodes/f90.el (f90-abbrev-start): Only offer help if
+       abbrev-mode is active.
+
+       * progmodes/fortran.el (fortran-abbrev-start): Only offer help if
+       abbrev-mode is active.
+
 2003-04-12  John Paul Wallington  <jpw@gnu.org>
 
        * help-fns.el (help-add-fundoc-usage): Pass an empty string to
index c644672356a4e34f67b30252d444b349c1c30c6b..7340f4d9d6bd4b1a8b9d1503a09b8adb1583bf3f 100644 (file)
@@ -84,6 +84,9 @@ One useful value to include is `turn-on-font-lock' to highlight the pieces."
 ;;; CONSTANTS FOR BOARD
 ;;;
 
+(defconst gomoku-buffer-name "*Gomoku*"
+  "Name of the Gomoku buffer.")
+
 ;; You may change these values if you have a small screen or if the squares
 ;; look rectangular, but spacings SHOULD be at least 2 (MUST BE at least 1).
 
@@ -193,8 +196,9 @@ You play by moving the cursor over the square you choose and hitting \\[gomoku-h
 Other useful commands:
 \\{gomoku-mode-map}
 Entry to this mode calls the value of `gomoku-mode-hook' if that value
-is non-nil.  One interesting value is `turn-on-font-lock'."
+is non-nil."
   (interactive)
+  (kill-all-local-variables)
   (setq major-mode 'gomoku-mode
        mode-name "Gomoku")
   (gomoku-display-statistics)
@@ -747,7 +751,17 @@ Use \\[describe-mode] for more info."
   (interactive (if current-prefix-arg
                   (list (prefix-numeric-value current-prefix-arg)
                         (eval (read-minibuffer "Height: ")))))
-  (gomoku-switch-to-window)
+  ;; gomoku-switch-to-window, but without the potential call to gomoku
+  ;; from gomoku-prompt-for-other-game.
+  (if (get-buffer gomoku-buffer-name)
+      (switch-to-buffer gomoku-buffer-name)
+    (when gomoku-game-in-progress
+      (setq gomoku-emacs-is-computing nil)
+      (gomoku-terminate-game 'crash-game)
+      (sit-for 4)
+      (or (y-or-n-p "Another game ") (error "Chicken !")))
+    (switch-to-buffer gomoku-buffer-name)
+    (gomoku-mode))
   (cond
    (gomoku-emacs-is-computing
     (gomoku-crash-game))
@@ -934,7 +948,7 @@ If the game is finished, this command requests for another game."
   "Ask for another game, and start it."
   (if (y-or-n-p "Another game ")
       (gomoku gomoku-board-width gomoku-board-height)
-    (message "Chicken !")))
+    (error "Chicken !")))
 
 (defun gomoku-offer-a-draw ()
   "Offer a draw and return t if Human accepted it."
@@ -1067,13 +1081,12 @@ If the game is finished, this command requests for another game."
 (defun gomoku-switch-to-window ()
   "Find or create the Gomoku buffer, and display it."
   (interactive)
-  (let ((buff (get-buffer "*Gomoku*")))
-    (if buff                           ; Buffer exists:
-       (switch-to-buffer buff)         ;   no problem.
-      (if gomoku-game-in-progress
-         (gomoku-crash-game))          ;   buffer has been killed or something
-      (switch-to-buffer "*Gomoku*")    ; Anyway, start anew.
-      (gomoku-mode))))
+  (if (get-buffer gomoku-buffer-name)       ; Buffer exists:
+      (switch-to-buffer gomoku-buffer-name) ;   no problem.
+    (if gomoku-game-in-progress
+        (gomoku-crash-game))            ;   buffer has been killed or something
+    (switch-to-buffer gomoku-buffer-name)   ; Anyway, start anew.
+    (gomoku-mode)))
 \f
 ;;;
 ;;; CROSSING WINNING QTUPLES.