Mercurial > emacs
annotate lisp/novice.el @ 1016:817b0ce337d7
* window.c (Fset_window_configuration): Removed #if 0'd code which
assumes that minibuf_window is on the same frame as the window
configuration. Removed special case for windows whose prevs
point to themselves.
* window.c (Fset_window_configuration): Rename the argument from
ARG to CONFIGURATION, so it matches the docstring. The
make-docfile program cares.
* window.c [MULTI_FRAME] (syms_of_window): Don't staticpro
minibuf_window; the frame list will take care of it.
* window.c (window_loop): This used to keep track of the first
window processed and wait until we came back around to it. Sadly,
this doesn't work if that window gets deleted. So instead, use
Fprevious_window to find the last window to process, and loop
until we've done that one.
* window.c [not MULTI_FRAME] (init_window_once): Don't forget to
set the `mini_p' flag on the new minibuffer window to t.
* window.c (Fwindow_at): Don't check the type of the frame
argument.
* window.c [not MULTI_FRAME] (window_loop): Set frame to zero,
instead of trying to decode it.
* window.c (init_window_once): Initialize minibuf_window before
FRAME_ROOT_WINDOW, so the latter actually points to something.
author | Jim Blandy <jimb@redhat.com> |
---|---|
date | Wed, 19 Aug 1992 06:40:02 +0000 |
parents | 213978acbc1e |
children | 4f9d60f7de9d |
rev | line source |
---|---|
659
505130d1ddf8
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
282
diff
changeset
|
1 ;;; novice.el --- handling of disabled commands ("novice mode") for Emacs. |
505130d1ddf8
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
282
diff
changeset
|
2 |
845 | 3 ;; Copyright (C) 1985, 1986, 1987 Free Software Foundation, Inc. |
4 | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
659
diff
changeset
|
5 ;; Maintainer: FSF |
814
38b2499cb3e9
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
807
diff
changeset
|
6 ;; Keywords: internal, help |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
659
diff
changeset
|
7 |
36 | 8 ;; This file is part of GNU Emacs. |
9 | |
10 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
11 ;; it under the terms of the GNU General Public License as published by | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
659
diff
changeset
|
12 ;; the Free Software Foundation; either version 2, or (at your option) |
36 | 13 ;; any later version. |
14 | |
15 ;; GNU Emacs is distributed in the hope that it will be useful, | |
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
18 ;; GNU General Public License for more details. | |
19 | |
20 ;; You should have received a copy of the GNU General Public License | |
21 ;; along with GNU Emacs; see the file COPYING. If not, write to | |
22 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | |
23 | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
659
diff
changeset
|
24 ;; Code: |
36 | 25 |
26 ;; This function is called (by autoloading) | |
27 ;; to handle any disabled command. | |
28 ;; The command is found in this-command | |
29 ;; and the keys are returned by (this-command-keys). | |
30 | |
256 | 31 ;;;###autoload |
268 | 32 (setq disabled-command-hook 'disabled-command-hook) |
33 | |
282 | 34 ;;;###autoload |
36 | 35 (defun disabled-command-hook (&rest ignore) |
36 (let (char) | |
37 (save-window-excursion | |
38 (with-output-to-temp-buffer "*Help*" | |
39 (if (= (aref (this-command-keys) 0) ?\M-x) | |
40 (princ "You have invoked the disabled command ") | |
41 (princ "You have typed ") | |
42 (princ (key-description (this-command-keys))) | |
43 (princ ", invoking disabled command ")) | |
44 (princ this-command) | |
45 (princ ":\n") | |
46 ;; Print any special message saying why the command is disabled. | |
47 (if (stringp (get this-command 'disabled)) | |
48 (princ (get this-command 'disabled))) | |
49 (princ (or (condition-case () | |
50 (documentation this-command) | |
51 (error nil)) | |
52 "<< not documented >>")) | |
53 ;; Keep only the first paragraph of the documentation. | |
54 (save-excursion | |
55 (set-buffer "*Help*") | |
56 (goto-char (point-min)) | |
57 (if (search-forward "\n\n" nil t) | |
58 (delete-region (1- (point)) (point-max)) | |
59 (goto-char (point-max)))) | |
60 (princ "\n\n") | |
61 (princ "You can now type | |
62 Space to try the command just this once, | |
63 but leave it disabled, | |
64 Y to try it and enable it (no questions if you use it again), | |
65 N to do nothing (command remains disabled).")) | |
66 (message "Type y, n or Space: ") | |
67 (let ((cursor-in-echo-area t)) | |
68 (while (not (memq (setq char (downcase (read-char))) | |
69 '(? ?y ?n))) | |
70 (ding) | |
71 (message "Please type y, n or Space: ")))) | |
72 (if (= char ?y) | |
73 (if (y-or-n-p "Enable command for future editing sessions also? ") | |
74 (enable-command this-command) | |
75 (put this-command 'disabled nil))) | |
76 (if (/= char ?n) | |
77 (call-interactively this-command)))) | |
78 | |
256 | 79 ;;;###autoload |
36 | 80 (defun enable-command (command) |
81 "Allow COMMAND to be executed without special confirmation from now on. | |
82 The user's .emacs file is altered so that this will apply | |
83 to future sessions." | |
84 (interactive "CEnable command: ") | |
85 (put command 'disabled nil) | |
86 (save-excursion | |
87 (set-buffer (find-file-noselect (substitute-in-file-name "~/.emacs"))) | |
88 (goto-char (point-min)) | |
89 (if (search-forward (concat "(put '" (symbol-name command) " ") nil t) | |
90 (delete-region | |
91 (progn (beginning-of-line) (point)) | |
92 (progn (forward-line 1) (point))) | |
93 ;; Must have been disabled by default. | |
94 (goto-char (point-max)) | |
95 (insert "\n(put '" (symbol-name command) " 'disabled nil)\n")) | |
96 (setq foo (buffer-modified-p)) | |
97 (save-buffer))) | |
98 | |
256 | 99 ;;;###autoload |
36 | 100 (defun disable-command (command) |
101 "Require special confirmation to execute COMMAND from now on. | |
102 The user's .emacs file is altered so that this will apply | |
103 to future sessions." | |
104 (interactive "CDisable command: ") | |
105 (put command 'disabled t) | |
106 (save-excursion | |
107 (set-buffer (find-file-noselect (substitute-in-file-name "~/.emacs"))) | |
108 (goto-char (point-min)) | |
109 (if (search-forward (concat "(put '" (symbol-name command) " ") nil t) | |
110 (delete-region | |
111 (progn (beginning-of-line) (point)) | |
112 (progn (forward-line 1) (point)))) | |
113 (goto-char (point-max)) | |
114 (insert "(put '" (symbol-name command) " 'disabled t)\n") | |
115 (save-buffer))) | |
116 | |
659
505130d1ddf8
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
282
diff
changeset
|
117 ;;; novice.el ends here |