Mercurial > emacs
annotate lisp/emacs-lisp/helper.el @ 30408:e3e2c9051c5f
Got rid of all byte-compiler warnings on Emacs.
Add to the menu when the file is loaded, not in ada-mode-hook.
Add -toolbar to the default ddd command Switches moved from
ada-prj-default-comp-cmd and ada-prj-default-make-cmd to
ada-prj-default-comp-opt
(ada-add-ada-menu): Remove the map and name parameters Add the Ada
Reference Manual to the menu
(ada-check-current): rewritten as a call to ada-compile-current
(ada-compile): Removed.
(ada-compile-application, ada-compile-current, ada-check-current):
Set the compilation-search-path so that compile.el automatically
finds the sources in src_dir. Automatic scrollong of the
compilation buffer. C-uC-cC-c asks for confirmation before
compiling
(ada-compile-current): New parameter, prj-field
(ada-complete-identifier): Load the .ali file before doing
processing
(ada-find-ali-file-in-dir): prepend build_dir to obj_dir to
conform to gnatmake's behavior.
(ada-find-file-in-dir): New function
(ada-find-references): Set the environment variables for gnatfind
(ada-find-src-file-in-dir): New function.
(ada-first-non-nil): Removed
(ada-gdb-application): Add support for jdb, the java debugger.
(ada-get-ada-file-name): Load the original-file first if not done
yet.
(ada-get-all-references): Handles the new ali syntax (parent types
are found between <>).
(ada-initialize-runtime-library): New function
(ada-mode-hook): Always load a project file when a file is opened,
so that the casing exceptions are correctly read.
(ada-operator-re): Add all missing operators ("abs", "rem", "**").
(ada-parse-prj-file): Use find-file-noselect instead of find-file
to open the project file, since the latter does not work with
speedbar Get default values before loading the prj file, or the
default executable file name is wrong. Use the absolute value of
src_dir to initialize ada-search-directories and
compilation-search-path,... Add the standard runtime library to
the search path for find-file.
(ada-prj-default-debugger): Was missing an opening '{'
(ada-prj-default-bind-opt, ada-prj-default-link-opt): New
variables.
(ada-prj-default-gnatmake-opt): New variable
(ada-prj-find-prj-file): Handles non-file buffers For non-Ada
buffers, the project file is the default one Save the windows
configuration before displaying the menu.
(ada-prj-src-dir, ada-prj-obj-dir, ada-prj-comp-opt,...): Removed
(ada-read-identifier): Fix xrefs on operators (for "mod", "and",
...) regexp-quote identifiers names to support operators +,
-,... in regexps.
(ada-remote): New function.
(ada-run-application): Erase the output buffer before starting the
run Support remote execution of the application. Use
call-process, or the arguments are incorrectly parsed
(ada-set-default-project-file): Reread the content of the active
project file, not the one from the current buffer When a project
file is set as the default project, all directories are
automatically associated with it.
(ada-set-environment): New function
(ada-treat-cmd-string): New special variable ${current}
(ada-treat-cmd-string): Revised. The substitution is now done for
any ${...} substring
(ada-xref-current): If no body was found, compiles the spec
instead. Setup ADA_{SOURCE,OBJECTS}_PATH before running the
compiler to get rid of command line length limitations.
(ada-xref-get-project-field): New function
(ada-xref-project-files): New variable
(ada-xref-runtime-library-specs-path)
(ada-xref-runtime-library-ali-path): New variables
(ada-xref-set-default-prj-values): Default run command now does a
cd to the build directory. New field: main_unit Provide a default
file name even if the current buffer has no prj file.
author | Gerd Moellmann <gerd@gnu.org> |
---|---|
date | Mon, 24 Jul 2000 11:13:11 +0000 |
parents | cc746270613e |
children | 253f761ad37b |
rev | line source |
---|---|
660
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
584
diff
changeset
|
1 ;;; helper.el --- utility help package supporting help in electric modes |
36 | 2 |
845 | 3 ;; Copyright (C) 1985 Free Software Foundation, Inc. |
4 | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
5 ;; Author: K. Shane Hartman |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
6 ;; Maintainer: FSF |
811
e694e0879463
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
807
diff
changeset
|
7 ;; Keywords: help |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
8 |
36 | 9 ;; This file is part of GNU Emacs. |
10 | |
11 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
12 ;; 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:
660
diff
changeset
|
13 ;; the Free Software Foundation; either version 2, or (at your option) |
36 | 14 ;; any later version. |
15 | |
16 ;; GNU Emacs is distributed in the hope that it will be useful, | |
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 ;; GNU General Public License for more details. | |
20 | |
21 ;; You should have received a copy of the GNU General Public License | |
14169 | 22 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
23 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
24 ;; Boston, MA 02111-1307, USA. | |
36 | 25 |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
26 ;;; Code: |
36 | 27 |
14169 | 28 ;; hey, here's a helping hand. |
36 | 29 |
30 ;; Bind this to a string for <blank> in "... Other keys <blank>". | |
31 ;; Helper-help uses this to construct help string when scrolling. | |
32 ;; Defaults to "return" | |
33 (defvar Helper-return-blurb nil) | |
34 | |
35 ;; Keymap implementation doesn't work too well for non-standard loops. | |
36 ;; But define it anyway for those who can use it. Non-standard loops | |
37 ;; will probably have to use Helper-help. You can't autoload the | |
38 ;; keymap either. | |
39 | |
40 | |
41 (defvar Helper-help-map nil) | |
42 (if Helper-help-map | |
43 nil | |
44 (setq Helper-help-map (make-keymap)) | |
45 ;(fillarray Helper-help-map 'undefined) | |
46 (define-key Helper-help-map "m" 'Helper-describe-mode) | |
47 (define-key Helper-help-map "b" 'Helper-describe-bindings) | |
48 (define-key Helper-help-map "c" 'Helper-describe-key-briefly) | |
49 (define-key Helper-help-map "k" 'Helper-describe-key) | |
50 ;(define-key Helper-help-map "f" 'Helper-describe-function) | |
51 ;(define-key Helper-help-map "v" 'Helper-describe-variable) | |
52 (define-key Helper-help-map "?" 'Helper-help-options) | |
53 (define-key Helper-help-map (char-to-string help-char) 'Helper-help-options) | |
54 (fset 'Helper-help-map Helper-help-map)) | |
55 | |
56 (defun Helper-help-scroller () | |
57 (let ((blurb (or (and (boundp 'Helper-return-blurb) | |
58 Helper-return-blurb) | |
59 "return"))) | |
60 (save-window-excursion | |
61 (goto-char (window-start (selected-window))) | |
62 (if (get-buffer-window "*Help*") | |
63 (pop-to-buffer "*Help*") | |
64 (switch-to-buffer "*Help*")) | |
65 (goto-char (point-min)) | |
66 (let ((continue t) state) | |
67 (while continue | |
68 (setq state (+ (* 2 (if (pos-visible-in-window-p (point-max)) 1 0)) | |
69 (if (pos-visible-in-window-p (point-min)) 1 0))) | |
70 (message | |
71 (nth state | |
72 '("Space forward, Delete back. Other keys %s" | |
73 "Space scrolls forward. Other keys %s" | |
74 "Delete scrolls back. Other keys %s" | |
75 "Type anything to %s")) | |
76 blurb) | |
77 (setq continue (read-char)) | |
78 (cond ((and (memq continue '(?\ ?\C-v)) (< state 2)) | |
79 (scroll-up)) | |
80 ((= continue ?\C-l) | |
81 (recenter)) | |
82 ((and (= continue ?\177) (zerop (% state 2))) | |
83 (scroll-down)) | |
84 (t (setq continue nil)))))))) | |
85 | |
86 (defun Helper-help-options () | |
87 "Describe help options." | |
88 (interactive) | |
89 (message "c (key briefly), m (mode), k (key), b (bindings)") | |
90 ;(message "c (key briefly), m (mode), k (key), v (variable), f (function)") | |
91 (sit-for 4)) | |
92 | |
93 (defun Helper-describe-key-briefly (key) | |
208 | 94 "Briefly describe binding of KEY." |
36 | 95 (interactive "kDescribe key briefly: ") |
96 (describe-key-briefly key) | |
97 (sit-for 4)) | |
98 | |
99 (defun Helper-describe-key (key) | |
208 | 100 "Describe binding of KEY." |
36 | 101 (interactive "kDescribe key: ") |
102 (save-window-excursion (describe-key key)) | |
103 (Helper-help-scroller)) | |
104 | |
105 (defun Helper-describe-function () | |
106 "Describe a function. Name read interactively." | |
107 (interactive) | |
108 (save-window-excursion (call-interactively 'describe-function)) | |
109 (Helper-help-scroller)) | |
110 | |
111 (defun Helper-describe-variable () | |
112 "Describe a variable. Name read interactively." | |
113 (interactive) | |
114 (save-window-excursion (call-interactively 'describe-variable)) | |
115 (Helper-help-scroller)) | |
116 | |
117 (defun Helper-describe-mode () | |
118 "Describe the current mode." | |
119 (interactive) | |
120 (let ((name mode-name) | |
121 (documentation (documentation major-mode))) | |
122 (save-excursion | |
123 (set-buffer (get-buffer-create "*Help*")) | |
27854
cc746270613e
(Helper-describe-mode): Make buffer writable.
Gerd Moellmann <gerd@gnu.org>
parents:
14169
diff
changeset
|
124 (setq buffer-read-only nil) |
36 | 125 (erase-buffer) |
9853
2018a5a1da69
(Helper-describe-mode): Set help-mode in *Help* buffer.
Karl Heuer <kwzh@gnu.org>
parents:
845
diff
changeset
|
126 (insert name " Mode\n" documentation) |
2018a5a1da69
(Helper-describe-mode): Set help-mode in *Help* buffer.
Karl Heuer <kwzh@gnu.org>
parents:
845
diff
changeset
|
127 (help-mode))) |
36 | 128 (Helper-help-scroller)) |
129 | |
258 | 130 ;;;###autoload |
36 | 131 (defun Helper-describe-bindings () |
132 "Describe local key bindings of current mode." | |
133 (interactive) | |
134 (message "Making binding list...") | |
135 (save-window-excursion (describe-bindings)) | |
136 (Helper-help-scroller)) | |
137 | |
258 | 138 ;;;###autoload |
36 | 139 (defun Helper-help () |
140 "Provide help for current mode." | |
141 (interactive) | |
142 (let ((continue t) c) | |
143 (while continue | |
144 (message "Help (Type ? for further options)") | |
11758
eb208ec6d216
(Helper-help): Use read-key-sequence.
Richard M. Stallman <rms@gnu.org>
parents:
9853
diff
changeset
|
145 (setq c (read-key-sequence nil)) |
36 | 146 (setq c (lookup-key Helper-help-map c)) |
147 (cond ((eq c 'Helper-help-options) | |
148 (Helper-help-options)) | |
149 ((commandp c) | |
150 (call-interactively c) | |
151 (setq continue nil)) | |
152 (t | |
153 (ding) | |
154 (setq continue nil)))))) | |
155 | |
660
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
584
diff
changeset
|
156 (provide 'helper) |
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
584
diff
changeset
|
157 |
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
584
diff
changeset
|
158 ;;; helper.el ends here |