Mercurial > hg > xemacs-beta
annotate lisp/help-macro.el @ 5524:e05d98bf9644
Style and indentation corrections, behavior.el.
2011-06-19 Aidan Kehoe <kehoea@parhasard.net>
* behavior.el (enable-behavior):
* behavior.el (disable-behavior):
Remove a couple of redundant lambdas here, and remove a cond
clause that was never tripped (because nil is a list.)
* behavior.el (behavior-menu-filter):
Correct some indentation here.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sun, 19 Jun 2011 19:15:52 +0100 |
parents | 308d34e9f07d |
children | 3bc58dc9d688 |
rev | line source |
---|---|
428 | 1 ;;; help-macro.el --- Makes command line help such as help-for-help |
2 | |
3 ;; Copyright (C) 1993, 1994, 1997 Free Software Foundation, Inc. | |
4 | |
5 ;; Author: Lynn Slater <lrs@indetech.com> | |
6 ;; Maintainer: FSF | |
7 ;; Created: : Mon Oct 1 11:42:39 1990 | |
8 ;; Adapted-By: ESR | |
9 | |
10 ;; This file is part of XEmacs. | |
11 | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
12 ;; XEmacs is free software: you can redistribute it and/or modify it |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
13 ;; under the terms of the GNU General Public License as published by the |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
14 ;; Free Software Foundation, either version 3 of the License, or (at your |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
15 ;; option) any later version. |
428 | 16 |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
17 ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
18 ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
19 ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
20 ;; for more details. |
428 | 21 |
22 ;; You should have received a copy of the GNU General Public License | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2275
diff
changeset
|
23 ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>. |
428 | 24 |
25 ;;; Commentary: | |
26 | |
27 ;;; Synched up with: FSF 20.2. | |
28 | |
29 ;; This file supplies the macro make-help-screen which constructs | |
30 ;; single character dispatching with browsable help such as that provided | |
31 ;; by help-for-help. This can be used to make many modes easier to use; for | |
32 ;; example, the Gnu Emacs Empire Tool uses this for every "nested" mode map | |
33 ;; called from the main mode map. | |
34 | |
35 ;; The name of this package was changed from help-screen.el to | |
36 ;; help-macro.el in order to fit in a 14-character limit. | |
37 | |
38 ;;-> *********************** Example of use ********************************* | |
39 | |
40 ;;->(make-help-screen help-for-empire-redistribute-map | |
41 ;;-> "c:civ m:mil p:population f:food ?" | |
42 ;;-> "You have discovered the GEET redistribution commands | |
43 ;;-> From here, you can use the following options: | |
44 ;;-> | |
45 ;;->c Redistribute civs from overfull sectors into connected underfull ones | |
46 ;;-> The functions typically named by empire-ideal-civ-fcn control | |
47 ;;-> based in part on empire-sector-civ-threshold | |
48 ;;->m Redistribute military using levels given by empire-ideal-mil-fcn | |
49 ;;->p Redistribute excess population to highways for max pop growth | |
50 ;;-> Excess is any sector so full babies will not be born. | |
51 ;;->f Even out food on highways to highway min and leave levels | |
52 ;;-> This is good to pump max food to all warehouses/dist pts | |
53 ;;-> | |
54 ;;-> | |
55 ;;->Use \\[help-for-empire-redistribute-map] for help on redistribution. | |
56 ;;->Use \\[help-for-empire-extract-map] for help on data extraction. | |
57 ;;->Please use \\[describe-key] to find out more about any of the other keys." | |
58 ;;-> empire-shell-redistribute-map) | |
59 | |
60 ;;-> (define-key c-mp "\C-h" 'help-for-empire-redistribute-map) | |
61 ;;-> (define-key c-mp help-character 'help-for-empire-redistribute-map) | |
62 | |
63 ;;; Code: | |
64 | |
65 (provide 'help-macro) | |
66 | |
67 ;;;###autoload | |
68 (defcustom three-step-help t | |
69 "*Non-nil means give more info about Help command in three steps. | |
70 The three steps are simple prompt, prompt with all options, | |
71 and window listing and describing the options. | |
72 A value of nil means skip the middle step, so that | |
73 \\[help-command] \\[help-command] gives the window that lists the options." | |
74 :type 'boolean | |
75 :group 'help-appearance) | |
76 | |
77 (defmacro make-help-screen (fname help-line help-text helped-map) | |
78 "Construct help-menu function name FNAME. | |
502 | 79 When invoked, FNAME shows HELP-LINE and reads a command using |
80 HELPED-MAP. If the command is the help character, FNAME displays | |
81 HELP-TEXT and continues trying to read a command using HELPED-MAP. | |
82 When FNAME finally does get a command, it executes that command and | |
83 then returns. As of 21.5 (or 21.4?), HELP-LINE and HELP-TEXT are | |
84 `eval'd, just like for a function call. This allows you to place | |
85 Lisp expressions in those arguments." | |
428 | 86 `(defun ,fname () |
502 | 87 ,(eval help-text) |
428 | 88 (interactive) |
89 (flet ((help-read-key (prompt) | |
90 ;; This is in `flet' to avoid problems with autoloading. | |
91 ;; #### The function is ill-conceived -- there should be | |
92 ;; a way to do it without all the hassle! | |
93 (let (events) | |
94 (while (not (key-press-event-p | |
95 (aref (setq events (read-key-sequence prompt)) 0))) | |
96 ;; Mouse clicks are not part of the help feature, so | |
97 ;; reexecute them in the standard environment. | |
98 (mapc 'dispatch-event events)) | |
99 (let ((key (nconc (event-modifiers (aref events 0)) | |
100 (list (event-key (aref events 0)))))) | |
101 ;; Make the HELP key translate to C-h. | |
102 (when (lookup-key function-key-map key) | |
103 (setq key (lookup-key function-key-map key))) | |
104 (if (eq (length key) 1) | |
105 (car key) | |
106 key))))) | |
107 (let ((line-prompt | |
502 | 108 (substitute-command-keys ,(eval help-line)))) |
428 | 109 (when three-step-help |
110 (message "%s" line-prompt)) | |
2275 | 111 (let* ((help-screen |
112 (condition-case nil | |
113 (documentation (quote ,fname)) | |
114 (void-function "(alias for undefined function)") | |
115 (error "(unexpected error from `documention')"))) | |
428 | 116 ;; We bind overriding-local-map for very small |
117 ;; sections, *excluding* where we switch buffers and | |
118 ;; where we execute the chosen help command. | |
119 (local-map (make-sparse-keymap)) | |
120 (minor-mode-map-alist nil) | |
121 (prev-frame (selected-frame)) | |
122 config new-frame key) | |
123 (unwind-protect | |
124 (progn | |
125 (set-keymap-parents local-map (list ,helped-map)) | |
126 (cond (three-step-help | |
127 (let* ((overriding-local-map local-map)) | |
128 (setq key (help-read-key nil)))) | |
129 (t | |
130 (setq key ??))) | |
131 (when (or (equal key ??) | |
132 (equal key (list help-char))) | |
133 (setq config (current-window-configuration)) | |
134 (switch-to-buffer-other-window "*Help*") | |
135 (and (not (eq (window-frame (selected-window)) | |
136 prev-frame)) | |
137 (setq new-frame (window-frame (selected-window)) | |
138 config nil)) | |
139 (setq buffer-read-only nil) | |
140 (erase-buffer) | |
141 (insert help-screen) | |
142 (help-mode) | |
143 (goto-char (point-min)) | |
144 (while (member key `((,help-char) ?? (control v) space ?\177 | |
145 delete backspace (meta v))) | |
146 (ignore-errors | |
147 (cond ((member key '((control v) space)) | |
148 (scroll-up)) | |
149 ((member key '(?\177 delete (meta v) backspace)) | |
150 (scroll-down)))) | |
151 (let ((cursor-in-echo-area t) | |
152 (overriding-local-map local-map)) | |
153 (setq key (help-read-key | |
154 (format "Type one of the options listed%s: " | |
155 (if (pos-visible-in-window-p | |
156 (point-max)) | |
157 "" " or Space to scroll"))))))) | |
158 ;; We don't need the prompt any more. | |
159 (message nil) | |
160 (let ((defn (lookup-key local-map key))) | |
161 (cond (defn | |
162 (when config | |
163 (set-window-configuration config) | |
164 (setq config nil)) | |
165 (when new-frame | |
166 (iconify-frame new-frame) | |
167 (setq new-frame nil)) | |
168 (call-interactively defn)) | |
169 (t | |
170 (ding))))) | |
171 (and (get-buffer "*Help*") | |
172 (bury-buffer "*Help*")) | |
173 (and new-frame (iconify-frame new-frame)) | |
174 (and config | |
175 (set-window-configuration config)))))))) | |
176 | |
177 ;;; help-macro.el | |
178 |