Mercurial > emacs
annotate lisp/progmodes/compile.el @ 25709:ba4e2a641663
(SXHASH_COMBINE): Add missing parentheses.
(Fchar_table_range, Fset_char_table_default, mapcar1,
Fyes_or_no_p, sweep_weak_hash_tables): Remove unused variable(s).
| author | Gerd Moellmann <gerd@gnu.org> |
|---|---|
| date | Tue, 14 Sep 1999 13:09:25 +0000 |
| parents | 0f4f299cebb2 |
| children | 35c7eab893ab |
| rev | line source |
|---|---|
| 727 | 1 ;;; compile.el --- run compiler as inferior of Emacs, parse error messages. |
|
712
16823e891d56
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
621
diff
changeset
|
2 |
|
24264
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
3 ;; Copyright (C) 1985, 86, 87, 93, 94, 95, 96, 97, 98, 1999 Free Software Foundation, Inc. |
|
846
20674ae6bf52
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
811
diff
changeset
|
4 |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
5 ;; Author: Roland McGrath <roland@gnu.org> |
|
795
c693d56ef36d
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
6 ;; Maintainer: FSF |
|
2247
2c7997f249eb
Add or correct keywords
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
1846
diff
changeset
|
7 ;; Keywords: tools, processes |
|
795
c693d56ef36d
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
8 |
| 71 | 9 ;; This file is part of GNU Emacs. |
| 10 | |
| 804 | 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 | |
| 13 ;; the Free Software Foundation; either version 2, or (at your option) | |
| 14 ;; any later version. | |
| 71 | 15 |
| 804 | 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. | |
| 71 | 25 |
|
2337
2ee64176069c
Fix library headers.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
26 ;;; Commentary: |
|
2ee64176069c
Fix library headers.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
27 |
|
2ee64176069c
Fix library headers.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
28 ;; This package provides the compile and grep facilities documented in |
|
2ee64176069c
Fix library headers.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
29 ;; the Emacs user's manual. |
|
2ee64176069c
Fix library headers.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
30 |
|
795
c693d56ef36d
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
31 ;;; Code: |
|
c693d56ef36d
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
32 |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
33 (defgroup compilation nil |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
34 "Run compiler as inferior of Emacs, parse error messages." |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
35 :group 'tools |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
36 :group 'processes) |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
37 |
| 569 | 38 |
| 39 ;;;###autoload | |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
40 (defcustom compilation-mode-hook nil |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
41 "*List of hook functions run by `compilation-mode' (see `run-hooks')." |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
42 :type 'hook |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
43 :group 'compilation) |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
44 |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
45 ;;;###autoload |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
46 (defcustom compilation-window-height nil |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
47 "*Number of lines in a compilation window. If nil, use Emacs default." |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
48 :type '(choice (const :tag "Default" nil) |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
49 integer) |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
50 :group 'compilation) |
| 418 | 51 |
|
24288
b563359187fd
(compile-auto-highlight): Customize.
Richard M. Stallman <rms@gnu.org>
parents:
24284
diff
changeset
|
52 (defcustom compile-auto-highlight nil |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
53 "*Specify how many compiler errors to highlight (and parse) initially. |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
54 \(Highlighting applies to an error message when the mouse is over it.) |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
55 If this is a number N, all compiler error messages in the first N lines |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
56 are highlighted and parsed as soon as they arrive in Emacs. |
|
16519
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
57 If t, highlight and parse the whole compilation output as soon as it arrives. |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
58 If nil, don't highlight or parse any of the buffer until you try to |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
59 move to the error messages. |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
60 |
|
16519
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
61 Those messages which are not parsed and highlighted initially |
|
24288
b563359187fd
(compile-auto-highlight): Customize.
Richard M. Stallman <rms@gnu.org>
parents:
24284
diff
changeset
|
62 will be parsed and highlighted as soon as you try to move to them." |
|
b563359187fd
(compile-auto-highlight): Customize.
Richard M. Stallman <rms@gnu.org>
parents:
24284
diff
changeset
|
63 :type '(choice (const :tag "All" t) |
|
b563359187fd
(compile-auto-highlight): Customize.
Richard M. Stallman <rms@gnu.org>
parents:
24284
diff
changeset
|
64 (const :tag "None" nil) |
|
b563359187fd
(compile-auto-highlight): Customize.
Richard M. Stallman <rms@gnu.org>
parents:
24284
diff
changeset
|
65 (integer :tag "First N lines")) |
|
b563359187fd
(compile-auto-highlight): Customize.
Richard M. Stallman <rms@gnu.org>
parents:
24284
diff
changeset
|
66 :group 'compilation) |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
67 |
| 71 | 68 (defvar compilation-error-list nil |
| 69 "List of error message descriptors for visiting erring functions. | |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
70 Each error descriptor is a cons (or nil). Its car is a marker pointing to |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
71 an error message. If its cdr is a marker, it points to the text of the |
|
5606
f600a46890d1
(copmilation-error-list): Doc fix.
Roland McGrath <roland@gnu.org>
parents:
5605
diff
changeset
|
72 line the message is about. If its cdr is a cons, it is a list |
|
f600a46890d1
(copmilation-error-list): Doc fix.
Roland McGrath <roland@gnu.org>
parents:
5605
diff
changeset
|
73 \(\(DIRECTORY . FILE\) LINE [COLUMN]\). Or its cdr may be nil if that |
|
f600a46890d1
(copmilation-error-list): Doc fix.
Roland McGrath <roland@gnu.org>
parents:
5605
diff
changeset
|
74 error is not interesting. |
| 418 | 75 |
| 76 The value may be t instead of a list; this means that the buffer of | |
| 3607 | 77 error messages should be reparsed the next time the list of errors is wanted. |
| 78 | |
| 79 Some other commands (like `diff') use this list to control the error | |
|
13972
6d4e18531dd2
(compilation-error-list): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents:
13819
diff
changeset
|
80 message tracking facilities; if you change its structure, you should make |
| 3607 | 81 sure you also change those packages. Perhaps it is better not to change |
| 82 it at all.") | |
| 71 | 83 |
| 84 (defvar compilation-old-error-list nil | |
| 85 "Value of `compilation-error-list' after errors were parsed.") | |
| 86 | |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
87 (defvar compilation-parse-errors-function 'compilation-parse-errors |
| 885 | 88 "Function to call to parse error messages from a compilation. |
| 907 | 89 It takes args LIMIT-SEARCH and FIND-AT-LEAST. |
| 90 If LIMIT-SEARCH is non-nil, don't bother parsing past that location. | |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
91 If FIND-AT-LEAST is non-nil, don't bother parsing after finding that |
|
6639
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
92 many new errors. |
| 418 | 93 It should read in the source files which have errors and set |
| 94 `compilation-error-list' to a list with an element for each error message | |
| 95 found. See that variable for more info.") | |
| 71 | 96 |
| 474 | 97 ;;;###autoload |
|
16985
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
98 (defvar compilation-process-setup-function nil |
|
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
99 "*Function to call to customize the compilation process. |
|
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
100 This functions is called immediately before the compilation process is |
|
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
101 started. It can be used to set any variables or functions that are used |
|
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
102 while processing the output of the compilation process.") |
|
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
103 |
|
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
104 ;;;###autoload |
| 418 | 105 (defvar compilation-buffer-name-function nil |
| 1133 | 106 "Function to compute the name of a compilation buffer. |
| 107 The function receives one argument, the name of the major mode of the | |
| 108 compilation buffer. It should return a string. | |
| 109 nil means compute the name with `(concat \"*\" (downcase major-mode) \"*\")'.") | |
| 71 | 110 |
| 474 | 111 ;;;###autoload |
| 418 | 112 (defvar compilation-finish-function nil |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
113 "Function to call when a compilation process finishes. |
| 418 | 114 It is called with two arguments: the compilation buffer, and a string |
| 115 describing how the process finished.") | |
| 116 | |
|
16042
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
117 ;;;###autoload |
|
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
118 (defvar compilation-finish-functions nil |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
119 "Functions to call when a compilation process finishes. |
|
16042
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
120 Each function is called with two arguments: the compilation buffer, |
|
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
121 and a string describing how the process finished.") |
|
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
122 |
| 418 | 123 (defvar compilation-last-buffer nil |
| 1133 | 124 "The most recent compilation buffer. |
| 125 A buffer becomes most recent when its compilation is started | |
| 126 or when it is used with \\[next-error] or \\[compile-goto-error].") | |
| 71 | 127 |
| 740 | 128 (defvar compilation-in-progress nil |
| 129 "List of compilation processes now running.") | |
| 130 (or (assq 'compilation-in-progress minor-mode-alist) | |
| 131 (setq minor-mode-alist (cons '(compilation-in-progress " Compiling") | |
| 132 minor-mode-alist))) | |
| 133 | |
| 71 | 134 (defvar compilation-parsing-end nil |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
135 "Marker position of end of buffer when last error messages were parsed.") |
| 71 | 136 |
| 418 | 137 (defvar compilation-error-message "No more errors" |
| 1133 | 138 "Message to print when no more matches are found.") |
| 139 | |
|
17866
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
140 (defvar compilation-arguments nil |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
141 "Arguments that were given to `compile-internal'.") |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
142 |
| 1133 | 143 (defvar compilation-num-errors-found) |
| 71 | 144 |
| 418 | 145 (defvar compilation-error-regexp-alist |
| 146 '( | |
|
8359
a9f95d2ac181
(compilation-error-regexp-alist): Fix bug in Borland
Richard M. Stallman <rms@gnu.org>
parents:
8351
diff
changeset
|
147 ;; NOTE! See also grep-regexp-alist, below. |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
148 |
| 418 | 149 ;; 4.3BSD grep, cc, lint pass 1: |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
150 ;; /usr/src/foo/foo.c(8): warning: w may be used before set |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
151 ;; or GNU utilities: |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
152 ;; foo.c:8: error message |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
153 ;; or HP-UX 7.0 fc: |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
154 ;; foo.f :16 some horrible error message |
|
9888
9d7972f4657c
(compile): With prefix arg, prompt even if (not compilation-read-command).
Roland McGrath <roland@gnu.org>
parents:
9868
diff
changeset
|
155 ;; or GNU utilities with column (GNAT 1.82): |
|
9d7972f4657c
(compile): With prefix arg, prompt even if (not compilation-read-command).
Roland McGrath <roland@gnu.org>
parents:
9868
diff
changeset
|
156 ;; foo.adb:2:1: Unit name does not match file name |
|
20966
1abf4d6ec488
(compilation-error-regexp-alist): Allow initial
Dave Love <fx@gnu.org>
parents:
20877
diff
changeset
|
157 ;; or with column and program name: |
|
1abf4d6ec488
(compilation-error-regexp-alist): Allow initial
Dave Love <fx@gnu.org>
parents:
20877
diff
changeset
|
158 ;; jade:dbcommon.dsl:133:17:E: missing argument for function call |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
159 ;; |
|
1702
817bd71e0e72
* compile.el (compilation-error-regexp-alist): Tightened up
Jim Blandy <jimb@redhat.com>
parents:
1554
diff
changeset
|
160 ;; We'll insist that the number be followed by a colon or closing |
|
817bd71e0e72
* compile.el (compilation-error-regexp-alist): Tightened up
Jim Blandy <jimb@redhat.com>
parents:
1554
diff
changeset
|
161 ;; paren, because otherwise this matches just about anything |
|
817bd71e0e72
* compile.el (compilation-error-regexp-alist): Tightened up
Jim Blandy <jimb@redhat.com>
parents:
1554
diff
changeset
|
162 ;; containing a number with spaces around it. |
|
23866
b1adb6a721dd
(compilation-error-regexp-alist): Insist on a non-digit in the file name.
Karl Heuer <kwzh@gnu.org>
parents:
23865
diff
changeset
|
163 |
|
b1adb6a721dd
(compilation-error-regexp-alist): Insist on a non-digit in the file name.
Karl Heuer <kwzh@gnu.org>
parents:
23865
diff
changeset
|
164 ;; We insist on a non-digit in the file name |
|
b1adb6a721dd
(compilation-error-regexp-alist): Insist on a non-digit in the file name.
Karl Heuer <kwzh@gnu.org>
parents:
23865
diff
changeset
|
165 ;; so that we don't mistake the file name for a command name |
|
b1adb6a721dd
(compilation-error-regexp-alist): Insist on a non-digit in the file name.
Karl Heuer <kwzh@gnu.org>
parents:
23865
diff
changeset
|
166 ;; and take the line number as the file name. |
|
24824
7b6625bfb652
(compilation-error-regexp-alist): Allow
Dave Love <fx@gnu.org>
parents:
24625
diff
changeset
|
167 ("\\([a-zA-Z][-a-zA-Z._0-9]+: ?\\)?\ |
|
23866
b1adb6a721dd
(compilation-error-regexp-alist): Insist on a non-digit in the file name.
Karl Heuer <kwzh@gnu.org>
parents:
23865
diff
changeset
|
168 \\([a-zA-Z]?:?[^:( \t\n]*[^:( \t\n0-9][^:( \t\n]*\\)[:(][ \t]*\\([0-9]+\\)\ |
|
23865
e5da22ef0b94
(compilation-error-regexp-alist): Fix regexp to match
Karl Heuer <kwzh@gnu.org>
parents:
23263
diff
changeset
|
169 \\([) \t]\\|:\\(\\([0-9]+:\\)\\|[0-9]*[^:0-9]\\)\\)" 2 3 6) |
|
8398
38513039d818
(compilation-error-regexp-alist): Make separate
Richard M. Stallman <rms@gnu.org>
parents:
8359
diff
changeset
|
170 |
|
15084
01518892abad
(compilation-error-regexp-alist): Add regexp
Richard M. Stallman <rms@gnu.org>
parents:
14807
diff
changeset
|
171 ;; Microsoft C/C++: |
|
01518892abad
(compilation-error-regexp-alist): Add regexp
Richard M. Stallman <rms@gnu.org>
parents:
14807
diff
changeset
|
172 ;; keyboard.c(537) : warning C4005: 'min' : macro redefinition |
|
01518892abad
(compilation-error-regexp-alist): Add regexp
Richard M. Stallman <rms@gnu.org>
parents:
14807
diff
changeset
|
173 ;; d:\tmp\test.c(23) : error C2143: syntax error : missing ';' before 'if' |
|
18565
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
174 ;; This used to be less selective and allow characters other than |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
175 ;; parens around the line number, but that caused confusion for |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
176 ;; GNU-style error messages. |
|
19616
bc9b6200a609
(compilation-error-regexp-alist): Allow spaces in file names for Microsoft C;
Richard M. Stallman <rms@gnu.org>
parents:
19351
diff
changeset
|
177 ;; This used to reject spaces and dashes in file names, |
|
24625
5b75b8661881
(compilation-error-regexp-alist): Recognize C++Build 4.0 error message syntax.
Karl Heuer <kwzh@gnu.org>
parents:
24623
diff
changeset
|
178 ;; but they are valid now; so I made it more strict about the error |
|
19616
bc9b6200a609
(compilation-error-regexp-alist): Allow spaces in file names for Microsoft C;
Richard M. Stallman <rms@gnu.org>
parents:
19351
diff
changeset
|
179 ;; message that follows. |
|
bc9b6200a609
(compilation-error-regexp-alist): Allow spaces in file names for Microsoft C;
Richard M. Stallman <rms@gnu.org>
parents:
19351
diff
changeset
|
180 ("\\(\\([a-zA-Z]:\\)?[^:(\t\n]+\\)(\\([0-9]+\\)) \ |
|
bc9b6200a609
(compilation-error-regexp-alist): Allow spaces in file names for Microsoft C;
Richard M. Stallman <rms@gnu.org>
parents:
19351
diff
changeset
|
181 : \\(error\\|warning\\) C[0-9]+:" 1 3) |
|
15084
01518892abad
(compilation-error-regexp-alist): Add regexp
Richard M. Stallman <rms@gnu.org>
parents:
14807
diff
changeset
|
182 |
|
24625
5b75b8661881
(compilation-error-regexp-alist): Recognize C++Build 4.0 error message syntax.
Karl Heuer <kwzh@gnu.org>
parents:
24623
diff
changeset
|
183 ;; Borland C++, C++Builder: |
|
8398
38513039d818
(compilation-error-regexp-alist): Make separate
Richard M. Stallman <rms@gnu.org>
parents:
8359
diff
changeset
|
184 ;; Error ping.c 15: Unable to open include file 'sys/types.h' |
|
38513039d818
(compilation-error-regexp-alist): Make separate
Richard M. Stallman <rms@gnu.org>
parents:
8359
diff
changeset
|
185 ;; Warning ping.c 68: Call to function 'func' with no prototype |
|
24625
5b75b8661881
(compilation-error-regexp-alist): Recognize C++Build 4.0 error message syntax.
Karl Heuer <kwzh@gnu.org>
parents:
24623
diff
changeset
|
186 ;; Error E2010 ping.c 15: Unable to open include file 'sys/types.h' |
|
5b75b8661881
(compilation-error-regexp-alist): Recognize C++Build 4.0 error message syntax.
Karl Heuer <kwzh@gnu.org>
parents:
24623
diff
changeset
|
187 ;; Warning W1022 ping.c 68: Call to function 'func' with no prototype |
|
5b75b8661881
(compilation-error-regexp-alist): Recognize C++Build 4.0 error message syntax.
Karl Heuer <kwzh@gnu.org>
parents:
24623
diff
changeset
|
188 ("\\(Error\\|Warning\\) \\(\\([FEW][0-9]+\\) \\)?\ |
|
5b75b8661881
(compilation-error-regexp-alist): Recognize C++Build 4.0 error message syntax.
Karl Heuer <kwzh@gnu.org>
parents:
24623
diff
changeset
|
189 \\([a-zA-Z]?:?[^:( \t\n]+\\)\ |
|
5b75b8661881
(compilation-error-regexp-alist): Recognize C++Build 4.0 error message syntax.
Karl Heuer <kwzh@gnu.org>
parents:
24623
diff
changeset
|
190 \\([0-9]+\\)\\([) \t]\\|:[^0-9\n]\\)" 4 5) |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
191 |
| 418 | 192 ;; 4.3BSD lint pass 2 |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
193 ;; strcmp: variable # of args. llib-lc(359) :: /usr/src/foo/foo.c(8) |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
194 (".*[ \t:]\\([a-zA-Z]?:?[^:( \t\n]+\\)[:(](+[ \t]*\\([0-9]+\\))[:) \t]*$" |
|
14049
d35edcfdefc1
(compilation-error-regexp-alist, grep-regexp-alist
Roland McGrath <roland@gnu.org>
parents:
14048
diff
changeset
|
195 1 2) |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
196 |
| 418 | 197 ;; 4.3BSD lint pass 3 |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
198 ;; bloofle defined( /users/wolfgang/foo.c(4) ), but never used |
| 727 | 199 ;; This used to be |
|
14049
d35edcfdefc1
(compilation-error-regexp-alist, grep-regexp-alist
Roland McGrath <roland@gnu.org>
parents:
14048
diff
changeset
|
200 ;; ("[ \t(]+\\([a-zA-Z]?:?[^:( \t\n]+\\)[:( \t]+\\([0-9]+\\)[:) \t]+" 1 2) |
| 727 | 201 ;; which is regexp Impressionism - it matches almost anything! |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
202 (".*([ \t]*\\([a-zA-Z]?:?[^:( \t\n]+\\)[:(][ \t]*\\([0-9]+\\))" 1 2) |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
203 |
|
14048
1a0cc425fb62
Mon Nov 6 18:01:01 1995 Dave Love <d.love@dl.ac.uk>
Roland McGrath <roland@gnu.org>
parents:
14047
diff
changeset
|
204 ;; MIPS lint pass<n>; looks good for SunPro lint also |
|
1a0cc425fb62
Mon Nov 6 18:01:01 1995 Dave Love <d.love@dl.ac.uk>
Roland McGrath <roland@gnu.org>
parents:
14047
diff
changeset
|
205 ;; TrimMask (255) in solomon.c may be indistinguishable from TrimMasks (93) in solomon.c due to truncation |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
206 ("[^\n ]+ (\\([0-9]+\\)) in \\([^ \n]+\\)" 2 1) |
|
14048
1a0cc425fb62
Mon Nov 6 18:01:01 1995 Dave Love <d.love@dl.ac.uk>
Roland McGrath <roland@gnu.org>
parents:
14047
diff
changeset
|
207 ;; name defined but never used: LinInt in cmap_calc.c(199) |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
208 (".*in \\([^(\n]+\\)(\\([0-9]+\\))$" 1 2) |
|
14048
1a0cc425fb62
Mon Nov 6 18:01:01 1995 Dave Love <d.love@dl.ac.uk>
Roland McGrath <roland@gnu.org>
parents:
14047
diff
changeset
|
209 |
|
4045
a37868b332ac
(compilation-error-regexp-alist): Broaden ``Line N of "FILE": msg'' regexp
Roland McGrath <roland@gnu.org>
parents:
3940
diff
changeset
|
210 ;; Ultrix 3.0 f77: |
|
7138
cbe3820953c6
(compilation-error-regexp-alist): Add fortran pattern.
Karl Heuer <kwzh@gnu.org>
parents:
7099
diff
changeset
|
211 ;; fort: Severe: addstf.f, line 82: Missing operator or delimiter symbol |
|
11308
1401dd853db7
(compilation-error-regexp-alist): Extend Ultrix 3.0 f77 to also match SGI cc.
Roland McGrath <roland@gnu.org>
parents:
11109
diff
changeset
|
212 ;; Some SGI cc version: |
|
1401dd853db7
(compilation-error-regexp-alist): Extend Ultrix 3.0 f77 to also match SGI cc.
Roland McGrath <roland@gnu.org>
parents:
11109
diff
changeset
|
213 ;; cfe: Warning 835: foo.c, line 2: something |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
214 ("\\(cfe\\|fort\\): [^:\n]*: \\([^ \n]*\\), line \\([0-9]+\\):" 2 3) |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
215 ;; Error on line 3 of t.f: Execution error unclassifiable statement |
|
4045
a37868b332ac
(compilation-error-regexp-alist): Broaden ``Line N of "FILE": msg'' regexp
Roland McGrath <roland@gnu.org>
parents:
3940
diff
changeset
|
216 ;; Unknown who does this: |
|
13972
6d4e18531dd2
(compilation-error-list): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents:
13819
diff
changeset
|
217 ;; Line 45 of "foo.c": bloofle undefined |
|
6412
84d5a22db4c8
(compilation-error-regexp-alist): Generalize ultrix 3 f77 regexp to match
Roland McGrath <roland@gnu.org>
parents:
6240
diff
changeset
|
218 ;; Absoft FORTRAN 77 Compiler 3.1.3 |
|
84d5a22db4c8
(compilation-error-regexp-alist): Generalize ultrix 3 f77 regexp to match
Roland McGrath <roland@gnu.org>
parents:
6240
diff
changeset
|
219 ;; error on line 19 of fplot.f: spelling error? |
|
84d5a22db4c8
(compilation-error-regexp-alist): Generalize ultrix 3 f77 regexp to match
Roland McGrath <roland@gnu.org>
parents:
6240
diff
changeset
|
220 ;; warning on line 17 of fplot.f: data type is undefined for variable d |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
221 ("\\(.* on \\)?[Ll]ine[ \t]+\\([0-9]+\\)[ \t]+\ |
|
14049
d35edcfdefc1
(compilation-error-regexp-alist, grep-regexp-alist
Roland McGrath <roland@gnu.org>
parents:
14048
diff
changeset
|
222 of[ \t]+\"?\\([a-zA-Z]?:?[^\":\n]+\\)\"?:" 3 2) |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
223 |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
224 ;; Apollo cc, 4.3BSD fc: |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
225 ;; "foo.f", line 3: Error: syntax error near end of statement |
|
3825
ae1462a1a8d4
(compilation-error-regexp-alist): Generalize the
Richard M. Stallman <rms@gnu.org>
parents:
3607
diff
changeset
|
226 ;; IBM RS6000: |
|
ae1462a1a8d4
(compilation-error-regexp-alist): Generalize the
Richard M. Stallman <rms@gnu.org>
parents:
3607
diff
changeset
|
227 ;; "vvouch.c", line 19.5: 1506-046 (S) Syntax error. |
|
5215
4d6ab37798ff
(compilation-error-regexp-alist): Generalize `"foo.c", line 13:' regexp to
Roland McGrath <roland@gnu.org>
parents:
4757
diff
changeset
|
228 ;; Microtec mcc68k: |
|
4d6ab37798ff
(compilation-error-regexp-alist): Generalize `"foo.c", line 13:' regexp to
Roland McGrath <roland@gnu.org>
parents:
4757
diff
changeset
|
229 ;; "foo.c", line 32 pos 1; (E) syntax error; unexpected symbol: "lossage" |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
230 ;; GNAT (as of July 94): |
|
8288
8695e414a2b1
(compilation-error-regexp-alist): Allow `(' after
Richard M. Stallman <rms@gnu.org>
parents:
8218
diff
changeset
|
231 ;; "foo.adb", line 2(11): warning: file name does not match ... |
|
14047
2df0227ff613
(compilation-error-regexp-alist): Broaden GNAT regexp to match column numbers.
Roland McGrath <roland@gnu.org>
parents:
14046
diff
changeset
|
232 ;; IBM AIX xlc compiler: |
|
2df0227ff613
(compilation-error-regexp-alist): Broaden GNAT regexp to match column numbers.
Roland McGrath <roland@gnu.org>
parents:
14046
diff
changeset
|
233 ;; "src/swapping.c", line 30.34: 1506-342 (W) "/*" detected in comment. |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
234 (".*\"\\([^,\" \n\t]+\\)\", lines? \ |
|
14047
2df0227ff613
(compilation-error-regexp-alist): Broaden GNAT regexp to match column numbers.
Roland McGrath <roland@gnu.org>
parents:
14046
diff
changeset
|
235 \\([0-9]+\\)\\([\(.]\\([0-9]+\\)\)?\\)?[:., (-]" 1 2 4) |
|
3606
713c76a95b74
* compile.el (compilation-error-list): When we haven't yet
Jim Blandy <jimb@redhat.com>
parents:
3514
diff
changeset
|
236 |
|
19351
cf429b6a3ab8
(compilation-error-regexp-alist): New regexp for Caml.
Richard M. Stallman <rms@gnu.org>
parents:
19182
diff
changeset
|
237 ;; Caml compiler: |
|
cf429b6a3ab8
(compilation-error-regexp-alist): New regexp for Caml.
Richard M. Stallman <rms@gnu.org>
parents:
19182
diff
changeset
|
238 ;; File "foobar.ml", lines 5-8, characters 20-155: blah blah |
|
cf429b6a3ab8
(compilation-error-regexp-alist): New regexp for Caml.
Richard M. Stallman <rms@gnu.org>
parents:
19182
diff
changeset
|
239 ("^File \"\\([^,\" \n\t]+\\)\", lines? \\([0-9]+\\)[-0-9]*, characters? \\([0-9]+\\)" 1 2 3) |
|
cf429b6a3ab8
(compilation-error-regexp-alist): New regexp for Caml.
Richard M. Stallman <rms@gnu.org>
parents:
19182
diff
changeset
|
240 |
|
3606
713c76a95b74
* compile.el (compilation-error-list): When we haven't yet
Jim Blandy <jimb@redhat.com>
parents:
3514
diff
changeset
|
241 ;; MIPS RISC CC - the one distributed with Ultrix: |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
242 ;; ccom: Error: foo.c, line 2: syntax error |
|
5633
6e0443843832
(compilation-error-regexp-alist): Handle DEC AXP OSF/1.
Richard M. Stallman <rms@gnu.org>
parents:
5606
diff
changeset
|
243 ;; DEC AXP OSF/1 cc |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
244 ;; /usr/lib/cmplrs/cc/cfe: Error: foo.c: 1: blah blah |
|
21224
1581abe1a67e
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
20966
diff
changeset
|
245 ("[a-z0-9/]+: \\([eE]rror\\|[wW]arning\\): \\([^,\" \n\t]+\\)[,:] \\(line \\)?\\([0-9]+\\):" 2 4) |
|
2461
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
246 |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
247 ;; IBM AIX PS/2 C version 1.1: |
|
1ecb75748794
(compilation-error-regexp-alist): Merged HP-UX 7.0 fc regexp with the
Roland McGrath <roland@gnu.org>
parents:
2460
diff
changeset
|
248 ;; ****** Error number 140 in line 8 of file errors.c ****** |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
249 (".*in line \\([0-9]+\\) of file \\([^ \n]+[^. \n]\\)\\.? " 2 1) |
| 418 | 250 ;; IBM AIX lint is too painful to do right this way. File name |
| 251 ;; prefixes entire sections rather than being on each line. | |
|
1702
817bd71e0e72
* compile.el (compilation-error-regexp-alist): Tightened up
Jim Blandy <jimb@redhat.com>
parents:
1554
diff
changeset
|
252 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
253 ;; SPARCcompiler Pascal: |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
254 ;; 20 linjer : array[1..4] of linje; |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
255 ;; e 18480-----------^--- Inserted ';' |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
256 ;; and |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
257 ;; E 18520 line 61 - 0 is undefined |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
258 ;; These messages don't contain a file name. Instead the compiler gives |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
259 ;; a message whenever the file being compiled is changed. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
260 (" +\\([0-9]+\\) +.*\n[ew] [0-9]+-+" nil 1) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
261 ("[Ew] +[0-9]+ line \\([0-9]+\\) - " nil 1) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
262 |
|
5605
fcf3556282dc
(compilation-error-regexp-alist): Add regexp for Lucid lcc.
Roland McGrath <roland@gnu.org>
parents:
5475
diff
changeset
|
263 ;; Lucid Compiler, lcc 3.x |
|
fcf3556282dc
(compilation-error-regexp-alist): Add regexp for Lucid lcc.
Roland McGrath <roland@gnu.org>
parents:
5475
diff
changeset
|
264 ;; E, file.cc(35,52) Illegal operation on pointers |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
265 ("[EW], \\([^(\n]*\\)(\\([0-9]+\\),[ \t]*\\([0-9]+\\)" 1 2 3) |
|
5605
fcf3556282dc
(compilation-error-regexp-alist): Add regexp for Lucid lcc.
Roland McGrath <roland@gnu.org>
parents:
5475
diff
changeset
|
266 |
|
18565
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
267 ;;; This seems to be superfluous because the first pattern matches it. |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
268 ;;; ;; GNU messages with program name and optional column number. |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
269 ;;; ("[a-zA-Z]?:?[^0-9 \n\t:]+[^ \n\t:]*:[ \t]*\\([^ \n\t:]+\\):\ |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
270 ;;;\\([0-9]+\\):\\(\\([0-9]+\\)[: \t]\\)?" 1 2 4) |
|
11791
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
271 |
|
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
272 ;; Cray C compiler error messages |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
273 ("\\(cc\\| cft\\)-[0-9]+ c\\(c\\|f77\\): ERROR \\([^,\n]+, \\)* File = \ |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
274 \\([^,\n]+\\), Line = \\([0-9]+\\)" 4 5) |
|
11791
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
275 |
|
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
276 ;; IBM C/C++ Tools 2.01: |
|
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
277 ;; foo.c(2:0) : informational EDC0804: Function foo is not referenced. |
|
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
278 ;; foo.c(3:8) : warning EDC0833: Implicit return statement encountered. |
|
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
279 ;; foo.c(5:5) : error EDC0350: Syntax error. |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
280 ("\\([^( \n\t]+\\)(\\([0-9]+\\):\\([0-9]+\\)) : " 1 2 3) |
|
12767
287cc74602fa
(compilation-error-regexp-alist): Add regexp for Sun ada.
Roland McGrath <roland@gnu.org>
parents:
12256
diff
changeset
|
281 |
|
18619
5d7968727c67
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
18565
diff
changeset
|
282 ;; IAR Systems C Compiler: |
|
5d7968727c67
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
18565
diff
changeset
|
283 ;; "foo.c",3 Error[32]: Error message |
|
5d7968727c67
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
18565
diff
changeset
|
284 ;; "foo.c",3 Warning[32]: Error message |
|
5d7968727c67
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
18565
diff
changeset
|
285 ("\"\\(.*\\)\",\\([0-9]+\\)\\s-+\\(Error\\|Warning\\)\\[[0-9]+\\]:" 1 2) |
|
5d7968727c67
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
18565
diff
changeset
|
286 |
|
12767
287cc74602fa
(compilation-error-regexp-alist): Add regexp for Sun ada.
Roland McGrath <roland@gnu.org>
parents:
12256
diff
changeset
|
287 ;; Sun ada (VADS, Solaris): |
|
287cc74602fa
(compilation-error-regexp-alist): Add regexp for Sun ada.
Roland McGrath <roland@gnu.org>
parents:
12256
diff
changeset
|
288 ;; /home3/xdhar/rcds_rc/main.a, line 361, char 6:syntax error: "," inserted |
|
16923
c7f39edc6320
(compilation-parse-errors): Use looking-at on each line.
Richard M. Stallman <rms@gnu.org>
parents:
16920
diff
changeset
|
289 ("\\([^, \n\t]+\\), line \\([0-9]+\\), char \\([0-9]+\\)[:., \(-]" 1 2 3) |
|
17582
52780f61eb76
(compilation-error-regexp-alist): Add regexp for Perl -w.
Richard M. Stallman <rms@gnu.org>
parents:
17277
diff
changeset
|
290 |
|
52780f61eb76
(compilation-error-regexp-alist): Add regexp for Perl -w.
Richard M. Stallman <rms@gnu.org>
parents:
17277
diff
changeset
|
291 ;; Perl -w: |
|
52780f61eb76
(compilation-error-regexp-alist): Add regexp for Perl -w.
Richard M. Stallman <rms@gnu.org>
parents:
17277
diff
changeset
|
292 ;; syntax error at automake line 922, near "':'" |
|
25433
3141f8df24cc
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
25426
diff
changeset
|
293 ;; Perl debugging traces |
|
3141f8df24cc
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
25426
diff
changeset
|
294 ;; store::odrecall('File_A', 'x2') called at store.pm line 90 |
|
3141f8df24cc
(compilation-error-regexp-alist):
Richard M. Stallman <rms@gnu.org>
parents:
25426
diff
changeset
|
295 (".* at \\([^ \n]+\\) line \\([0-9]+\\)[,.\n]" 1 2) |
|
18477
270080940256
(compilation-error-regexp-alist): New item, for Oracle compiler.
Richard M. Stallman <rms@gnu.org>
parents:
18273
diff
changeset
|
296 |
|
270080940256
(compilation-error-regexp-alist): New item, for Oracle compiler.
Richard M. Stallman <rms@gnu.org>
parents:
18273
diff
changeset
|
297 ;; Oracle pro*c: |
|
270080940256
(compilation-error-regexp-alist): New item, for Oracle compiler.
Richard M. Stallman <rms@gnu.org>
parents:
18273
diff
changeset
|
298 ;; Semantic error at line 528, column 5, file erosacqdb.pc: |
|
270080940256
(compilation-error-regexp-alist): New item, for Oracle compiler.
Richard M. Stallman <rms@gnu.org>
parents:
18273
diff
changeset
|
299 ("Semantic error at line \\([0-9]+\\), column \\([0-9]+\\), file \\(.*\\):" |
|
270080940256
(compilation-error-regexp-alist): New item, for Oracle compiler.
Richard M. Stallman <rms@gnu.org>
parents:
18273
diff
changeset
|
300 3 1 2) |
|
18984
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
301 |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
302 ;; EPC F90 compiler: |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
303 ;; Error 24 at (2:progran.f90) : syntax error |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
304 ("Error [0-9]+ at (\\([0-9]*\\):\\([^)\n]+\\))" 2 1) |
|
20187
0ee26e03e911
(compilation-error-regexp-alist):
Karl Heuer <kwzh@gnu.org>
parents:
20059
diff
changeset
|
305 |
| 25623 | 306 ;; SGI IRIX MipsPro 7.3 compilers: |
|
25435
5ff4e59e5f02
(compilation-error-regexp-alist): New item for SGI IRIX MipsPro compilers.
Richard M. Stallman <rms@gnu.org>
parents:
25433
diff
changeset
|
307 ;; cc-1070 cc: ERROR File = linkl.c, Line = 38 |
|
5ff4e59e5f02
(compilation-error-regexp-alist): New item for SGI IRIX MipsPro compilers.
Richard M. Stallman <rms@gnu.org>
parents:
25433
diff
changeset
|
308 (".*: ERROR File = \\(.+\\), Line = \\([0-9]+\\)" 1 2) |
|
5ff4e59e5f02
(compilation-error-regexp-alist): New item for SGI IRIX MipsPro compilers.
Richard M. Stallman <rms@gnu.org>
parents:
25433
diff
changeset
|
309 (".*: WARNING File = \\(.+\\), Line = \\([0-9]+\\)" 1 2) |
|
5ff4e59e5f02
(compilation-error-regexp-alist): New item for SGI IRIX MipsPro compilers.
Richard M. Stallman <rms@gnu.org>
parents:
25433
diff
changeset
|
310 |
|
20187
0ee26e03e911
(compilation-error-regexp-alist):
Karl Heuer <kwzh@gnu.org>
parents:
20059
diff
changeset
|
311 ;; Sun F90 error messages: |
|
0ee26e03e911
(compilation-error-regexp-alist):
Karl Heuer <kwzh@gnu.org>
parents:
20059
diff
changeset
|
312 ;; cf90-113 f90comp: ERROR NSE, File = Hoved.f90, Line = 16, Column = 3 |
|
0ee26e03e911
(compilation-error-regexp-alist):
Karl Heuer <kwzh@gnu.org>
parents:
20059
diff
changeset
|
313 (".* ERROR [a-zA-Z0-9 ]+, File = \\(.+\\), Line = \\([0-9]+\\), Column = \\([0-9]+\\)" |
|
0ee26e03e911
(compilation-error-regexp-alist):
Karl Heuer <kwzh@gnu.org>
parents:
20059
diff
changeset
|
314 1 2 3) |
| 418 | 315 ) |
| 1133 | 316 "Alist that specifies how to match errors in compiler output. |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
317 Each elt has the form (REGEXP FILE-IDX LINE-IDX [COLUMN-IDX FILE-FORMAT...]) |
|
5605
fcf3556282dc
(compilation-error-regexp-alist): Add regexp for Lucid lcc.
Roland McGrath <roland@gnu.org>
parents:
5475
diff
changeset
|
318 If REGEXP matches, the FILE-IDX'th subexpression gives the file name, and |
|
fcf3556282dc
(compilation-error-regexp-alist): Add regexp for Lucid lcc.
Roland McGrath <roland@gnu.org>
parents:
5475
diff
changeset
|
319 the LINE-IDX'th subexpression gives the line number. If COLUMN-IDX is |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
320 given, the COLUMN-IDX'th subexpression gives the column number on that line. |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
321 If any FILE-FORMAT is given, each is a format string to produce a file name to |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
322 try; %s in the string is replaced by the text matching the FILE-IDX'th |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
323 subexpression.") |
| 71 | 324 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
325 (defvar compilation-enter-directory-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
326 '( |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
327 ;; Matches lines printed by the `-w' option of GNU Make. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
328 (".*: Entering directory `\\(.*\\)'$" 1) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
329 ) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
330 "Alist specifying how to match lines that indicate a new current directory. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
331 Note that the match is done at the beginning of lines. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
332 Each elt has the form (REGEXP IDX). |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
333 If REGEXP matches, the IDX'th subexpression gives the directory name. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
334 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
335 The default value matches lines printed by the `-w' option of GNU Make.") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
336 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
337 (defvar compilation-leave-directory-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
338 '( |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
339 ;; Matches lines printed by the `-w' option of GNU Make. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
340 (".*: Leaving directory `\\(.*\\)'$" 1) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
341 ) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
342 "Alist specifying how to match lines that indicate restoring current directory. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
343 Note that the match is done at the beginning of lines. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
344 Each elt has the form (REGEXP IDX). |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
345 If REGEXP matches, the IDX'th subexpression gives the name of the directory |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
346 being moved from. If IDX is nil, the last directory entered \(by a line |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
347 matching `compilation-enter-directory-regexp-alist'\) is assumed. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
348 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
349 The default value matches lines printed by the `-w' option of GNU Make.") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
350 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
351 (defvar compilation-file-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
352 '( |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
353 ;; This matches entries with date time year file-name: like |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
354 ;; Thu May 14 10:46:12 1992 mom3.p: |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
355 ("\\w\\w\\w \\w\\w\\w +[0-9]+ [0-9][0-9]:[0-9][0-9]:[0-9][0-9] [0-9][0-9][0-9][0-9] \\(.*\\):$" 1) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
356 ) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
357 "Alist specifying how to match lines that indicate a new current file. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
358 Note that the match is done at the beginning of lines. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
359 Each elt has the form (REGEXP IDX). |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
360 If REGEXP matches, the IDX'th subexpression gives the file name. This is |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
361 used with compilers that don't indicate file name in every error message.") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
362 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
363 ;; There is no generally useful regexp that will match non messages, but |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
364 ;; in special cases there might be one. The lines that are not matched by |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
365 ;; a regexp take much longer time than the ones that are recognized so if |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
366 ;; you have same regexeps here, parsing is faster. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
367 (defvar compilation-nomessage-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
368 '( |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
369 ) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
370 "Alist specifying how to match lines that have no message. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
371 Note that the match is done at the beginning of lines. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
372 Each elt has the form (REGEXP). This alist is by default empty, but if |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
373 you have some good regexps here, the parsing of messages will be faster.") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
374 |
|
23263
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
375 (defcustom compilation-error-screen-columns t |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
376 "*If non-nil, column numbers in error messages are screen columns. |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
377 Otherwise they are interpreted as character positions, with |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
378 each character occupying one column. |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
379 The default is to use screen columns, which requires that the compilation |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
380 program and Emacs agree about the display width of the characters, |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
381 especially the TAB character." |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
382 :type 'boolean |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
383 :group 'compilation |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
384 :version "20.4") |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
385 |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
386 (defcustom compilation-read-command t |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
387 "*If not nil, M-x compile reads the compilation command to use. |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
388 Otherwise, M-x compile just uses the value of `compile-command'." |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
389 :type 'boolean |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
390 :group 'compilation) |
|
5406
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
391 |
|
19766
0790c7dab24d
(compilation-ask-about-save): Add autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
19616
diff
changeset
|
392 ;;;###autoload |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
393 (defcustom compilation-ask-about-save t |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
394 "*If not nil, M-x compile asks which buffers to save before compiling. |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
395 Otherwise, it saves all modified buffers without asking." |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
396 :type 'boolean |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
397 :group 'compilation) |
|
5406
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
398 |
| 1072 | 399 (defvar grep-regexp-alist |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
400 '(("\\([a-zA-Z]?:?[^:( \t\n]+\\)[:( \t]+\\([0-9]+\\)[:) \t]" 1 2)) |
| 1072 | 401 "Regexp used to match grep hits. See `compilation-error-regexp-alist'.") |
| 402 | |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
403 (defvar grep-program |
|
18273
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
404 ;; Currently zgrep has trouble. It runs egrep instead of grep, |
|
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
405 ;; and it doesn't pass along long options right. |
|
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
406 "grep" |
|
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
407 ;;; (if (equal (condition-case nil ; in case "zgrep" isn't in exec-path |
|
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
408 ;;; (call-process "zgrep" nil nil nil |
|
22404
9862ae4f05a7
(grep-null-device): Variable deleted.
Richard M. Stallman <rms@gnu.org>
parents:
22307
diff
changeset
|
409 ;;; "foo" null-device) |
|
18273
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
410 ;;; (error nil)) |
|
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
411 ;;; 1) |
|
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
412 ;;; "zgrep" |
|
41496911055d
(grep-program): Comment out the use of zgrep.
Richard M. Stallman <rms@gnu.org>
parents:
17866
diff
changeset
|
413 ;;; "grep") |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
414 "The default grep program for `grep-command' and `grep-find-command'. |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
415 This variable's value takes effect when `grep-compute-defaults' is called.") |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
416 |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
417 ;; Use -e if grep supports it, |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
418 ;; because that avoids lossage if the pattern starts with `-'. |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
419 (defvar grep-command nil |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
420 "The default grep command for \\[grep]. |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
421 The real default value of this variable is set up by `grep-compute-defaults'; |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
422 call that function before using this variable.") |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
423 |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
424 (defvar grep-find-use-xargs nil |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
425 "Whether \\[grep-find] uses the `xargs' utility by default. |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
426 |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
427 If nil, it uses `grep -exec'; if `gnu', it uses `find -print0' and `xargs -0'; |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
428 if not nil and not `gnu', it uses `find -print' and `xargs'. |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
429 |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
430 This variable's value takes effect when `grep-compute-defaults' is called.") |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
431 |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
432 (defvar grep-find-command nil |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
433 "The default find command for \\[grep-find]. |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
434 The default value of this variable is set up by `grep-compute-defaults'; |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
435 call that function before using this variable.") |
|
5260
93a5ed7aaeb5
(grep-command): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5215
diff
changeset
|
436 |
| 569 | 437 ;;;###autoload |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
438 (defcustom compilation-search-path '(nil) |
| 569 | 439 "*List of directories to search for source files named in error messages. |
| 418 | 440 Elements should be directory names, not file names of directories. |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
441 nil as an element means to try the default directory." |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
442 :type '(repeat (choice (const :tag "Default" nil) |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
443 (string :tag "Directory"))) |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
444 :group 'compilation) |
| 71 | 445 |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
446 (defcustom compile-command "make -k " |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
447 "*Last shell command used to do a compilation; default for next compilation. |
| 71 | 448 |
| 449 Sometimes it is useful for files to supply local values for this variable. | |
| 450 You might also use mode hooks to specify it in certain modes, like this: | |
| 451 | |
|
19007
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
452 (add-hook 'c-mode-hook |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
453 (function |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
454 (lambda () |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
455 (unless (or (file-exists-p \"makefile\") |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
456 (file-exists-p \"Makefile\")) |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
457 (make-local-variable 'compile-command) |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
458 (setq compile-command |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
459 (concat \"make -k \" |
|
1606d5205bbc
(compile-command): More doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18987
diff
changeset
|
460 (file-name-sans-extension buffer-file-name)))))))" |
|
17639
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
461 :type 'string |
|
5339baa0a334
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17623
diff
changeset
|
462 :group 'compilation) |
| 71 | 463 |
| 418 | 464 (defvar compilation-directory-stack nil |
| 1133 | 465 "Stack of previous directories for `compilation-leave-directory-regexp'. |
|
21930
b84bfe98263d
* progmodes/compile.el (compilation-directory-stack): Doc fix.
Andreas Schwab <schwab@suse.de>
parents:
21224
diff
changeset
|
466 The last element is the directory the compilation was started in.") |
| 418 | 467 |
|
12920
905444ab8d92
(compilation-exit-message-function): New variable.
Roland McGrath <roland@gnu.org>
parents:
12767
diff
changeset
|
468 (defvar compilation-exit-message-function nil "\ |
|
905444ab8d92
(compilation-exit-message-function): New variable.
Roland McGrath <roland@gnu.org>
parents:
12767
diff
changeset
|
469 If non-nil, called when a compilation process dies to return a status message. |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
470 This should be a function of three arguments: process status, exit status, |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
471 and exit message; it returns a cons (MESSAGE . MODELINE) of the strings to |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
472 write into the compilation buffer, and to put in its mode line.") |
|
12920
905444ab8d92
(compilation-exit-message-function): New variable.
Roland McGrath <roland@gnu.org>
parents:
12767
diff
changeset
|
473 |
|
864
fe5f6b7c9727
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
474 ;; History of compile commands. |
|
fe5f6b7c9727
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
475 (defvar compile-history nil) |
|
fe5f6b7c9727
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
476 ;; History of grep commands. |
|
fe5f6b7c9727
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
477 (defvar grep-history nil) |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
478 (defvar grep-find-history nil) |
|
864
fe5f6b7c9727
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
479 |
|
17056
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
480 (defun compilation-mode-font-lock-keywords () |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
481 "Return expressions to highlight in Compilation mode." |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
482 (nconc |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
483 ;; |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
484 ;; Compiler warning/error lines. |
|
18984
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
485 (mapcar (function |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
486 (lambda (item) |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
487 ;; Prepend "^", adjusting FILE-IDX and LINE-IDX accordingly. |
|
20001
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
488 (let ((file-idx (nth 1 item)) |
|
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
489 (line-idx (nth 2 item)) |
|
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
490 (col-idx (nth 3 item)) |
|
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
491 keyword) |
|
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
492 (when (numberp col-idx) |
|
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
493 (setq keyword |
|
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
494 (cons (list (1+ col-idx) 'font-lock-type-face nil t) |
|
75f1bdf2c886
(compilation-mode-font-lock-keywords): Font-lock column numbers.
Karl Heuer <kwzh@gnu.org>
parents:
20000
diff
changeset
|
495 keyword))) |
|
18984
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
496 (when (numberp line-idx) |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
497 (setq keyword |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
498 (cons (list (1+ line-idx) 'font-lock-variable-name-face) |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
499 keyword))) |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
500 (when (numberp file-idx) |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
501 (setq keyword |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
502 (cons (list (1+ file-idx) 'font-lock-warning-face) |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
503 keyword))) |
|
d2c26a873eb4
(compilation-error-regexp-alist): Add elt for EPC F90.
Richard M. Stallman <rms@gnu.org>
parents:
18619
diff
changeset
|
504 (cons (concat "^\\(" (nth 0 item) "\\)") keyword)))) |
|
17056
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
505 compilation-error-regexp-alist) |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
506 (list |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
507 ;; |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
508 ;; Compiler output lines. Recognize `make[n]:' lines too. |
|
17056
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
509 '("^\\([A-Za-z_0-9/\.+-]+\\)\\(\\[\\([0-9]+\\)\\]\\)?[ \t]*:" |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
510 (1 font-lock-function-name-face) (3 font-lock-comment-face nil t))) |
|
0f7992bc968f
Rewrite Font Lock support.
Simon Marshall <simon@gnu.org>
parents:
17054
diff
changeset
|
511 )) |
|
12920
905444ab8d92
(compilation-exit-message-function): New variable.
Roland McGrath <roland@gnu.org>
parents:
12767
diff
changeset
|
512 |
| 418 | 513 ;;;###autoload |
| 71 | 514 (defun compile (command) |
| 515 "Compile the program including the current buffer. Default: run `make'. | |
| 516 Runs COMMAND, a shell command, in a separate process asynchronously | |
| 517 with output going to the buffer `*compilation*'. | |
| 418 | 518 |
| 71 | 519 You can then use the command \\[next-error] to find the next error message |
| 520 and move to the source code that caused it. | |
| 521 | |
|
9888
9d7972f4657c
(compile): With prefix arg, prompt even if (not compilation-read-command).
Roland McGrath <roland@gnu.org>
parents:
9868
diff
changeset
|
522 Interactively, prompts for the command if `compilation-read-command' is |
|
9d7972f4657c
(compile): With prefix arg, prompt even if (not compilation-read-command).
Roland McGrath <roland@gnu.org>
parents:
9868
diff
changeset
|
523 non-nil; otherwise uses `compile-command'. With prefix arg, always prompts. |
|
9d7972f4657c
(compile): With prefix arg, prompt even if (not compilation-read-command).
Roland McGrath <roland@gnu.org>
parents:
9868
diff
changeset
|
524 |
| 71 | 525 To run more than one compilation at once, start one and rename the |
| 418 | 526 \`*compilation*' buffer to some other name with \\[rename-buffer]. |
| 527 Then start the next one. | |
| 528 | |
| 529 The name used for the buffer is actually whatever is returned by | |
| 530 the function in `compilation-buffer-name-function', so you can set that | |
| 531 to a function that generates a unique name." | |
|
5406
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
532 (interactive |
|
9888
9d7972f4657c
(compile): With prefix arg, prompt even if (not compilation-read-command).
Roland McGrath <roland@gnu.org>
parents:
9868
diff
changeset
|
533 (if (or compilation-read-command current-prefix-arg) |
|
5406
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
534 (list (read-from-minibuffer "Compile command: " |
|
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
535 compile-command nil nil |
|
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
536 '(compile-history . 1))) |
|
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
537 (list compile-command))) |
| 71 | 538 (setq compile-command command) |
|
5406
d9a58377567c
(compilation-read-command, compilation-ask-about-save): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
5260
diff
changeset
|
539 (save-some-buffers (not compilation-ask-about-save) nil) |
| 418 | 540 (compile-internal compile-command "No more errors")) |
| 71 | 541 |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
542 ;;; run compile with the default command line |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
543 (defun recompile () |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
544 "Re-compile the program including the current buffer." |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
545 (interactive) |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
546 (save-some-buffers (not compilation-ask-about-save) nil) |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
547 (compile-internal compile-command "No more errors")) |
|
12256
e50e5d419c51
(grep-null-device): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
12219
diff
changeset
|
548 |
|
17054
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
549 (defun grep-process-setup () |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
550 "Set up `compilation-exit-message-function' for `grep'." |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
551 (set (make-local-variable 'compilation-exit-message-function) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
552 (lambda (status code msg) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
553 (if (eq status 'exit) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
554 (cond ((zerop code) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
555 '("finished (matches found)\n" . "matched")) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
556 ((= code 1) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
557 '("finished with no matches found\n" . "no match")) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
558 (t |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
559 (cons msg code))) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
560 (cons msg code))))) |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
561 |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
562 (defun grep-compute-defaults () |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
563 (setq grep-command |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
564 (if (equal (condition-case nil ; in case "grep" isn't in exec-path |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
565 (call-process grep-program nil nil nil |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
566 "-e" "foo" null-device) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
567 (error nil)) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
568 1) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
569 (format "%s -n -e " grep-program) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
570 (format "%s -n " grep-program))) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
571 (unless grep-find-use-xargs |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
572 (setq grep-find-use-xargs |
|
24623
a79624ba3e74
(grep-compute-defaults): If xargs -e isn't supported, use find -exec.
Karl Heuer <kwzh@gnu.org>
parents:
24558
diff
changeset
|
573 (if (and |
|
a79624ba3e74
(grep-compute-defaults): If xargs -e isn't supported, use find -exec.
Karl Heuer <kwzh@gnu.org>
parents:
24558
diff
changeset
|
574 (equal (call-process "find" nil nil nil |
|
a79624ba3e74
(grep-compute-defaults): If xargs -e isn't supported, use find -exec.
Karl Heuer <kwzh@gnu.org>
parents:
24558
diff
changeset
|
575 null-device "-print0") |
|
a79624ba3e74
(grep-compute-defaults): If xargs -e isn't supported, use find -exec.
Karl Heuer <kwzh@gnu.org>
parents:
24558
diff
changeset
|
576 0) |
|
a79624ba3e74
(grep-compute-defaults): If xargs -e isn't supported, use find -exec.
Karl Heuer <kwzh@gnu.org>
parents:
24558
diff
changeset
|
577 (equal (call-process "xargs" nil nil nil |
|
a79624ba3e74
(grep-compute-defaults): If xargs -e isn't supported, use find -exec.
Karl Heuer <kwzh@gnu.org>
parents:
24558
diff
changeset
|
578 "-0" "-e" "echo") |
|
a79624ba3e74
(grep-compute-defaults): If xargs -e isn't supported, use find -exec.
Karl Heuer <kwzh@gnu.org>
parents:
24558
diff
changeset
|
579 0)) |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
580 'gnu))) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
581 (setq grep-find-command |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
582 (cond ((eq grep-find-use-xargs 'gnu) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
583 (format "find . -type f -print0 | xargs -0 -e %s" |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
584 grep-command)) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
585 (grep-find-use-xargs |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
586 (format "find . -type f -print | xargs %s" grep-command)) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
587 (t (cons (format "find . -type f -exec %s {} /dev/null \\;" |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
588 grep-command) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
589 (+ 22 (length grep-command))))))) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
590 |
| 418 | 591 ;;;###autoload |
| 71 | 592 (defun grep (command-args) |
| 593 "Run grep, with user-specified args, and collect output in a buffer. | |
| 22966 | 594 While grep runs asynchronously, you can use \\[next-error] (M-x next-error), |
| 595 or \\<compilation-minor-mode-map>\\[compile-goto-error] in the grep \ | |
| 596 output buffer, to go to the lines | |
| 597 where grep found matches. | |
| 418 | 598 |
|
864
fe5f6b7c9727
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
599 This command uses a special history list for its arguments, so you can |
|
22208
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
600 easily repeat a grep command. |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
601 |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
602 A prefix argument says to default the argument based upon the current |
| 22307 | 603 tag the cursor is over, substituting it into the last grep command |
| 604 in the grep command history (or into `grep-command' | |
| 605 if that history list is empty)." | |
| 71 | 606 (interactive |
| 22307 | 607 (let (grep-default (arg current-prefix-arg)) |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
608 (unless grep-command |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
609 (grep-compute-defaults)) |
| 22307 | 610 (when arg |
|
22208
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
611 (let* ((tag-default |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
612 (funcall (or find-tag-default-function |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
613 (get major-mode 'find-tag-default-function) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
614 ;; We use grep-tag-default instead of |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
615 ;; find-tag-default, to avoid loading etags. |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
616 'grep-tag-default)))) |
| 22307 | 617 (setq grep-default (or (car grep-history) grep-command)) |
|
22208
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
618 ;; Replace the thing matching for with that around cursor |
| 22307 | 619 (if (string-match "[^ ]+\\s +\\(-[^ ]+\\s +\\)*\\(\"[^\"]+\"\\|[^ ]+\\)" grep-default) |
|
22208
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
620 (setq grep-default (replace-match tag-default t t |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
621 grep-default 2))))) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
622 (list (read-from-minibuffer "Run grep (like this): " |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
623 (or grep-default grep-command) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
624 nil nil 'grep-history)))) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
625 |
|
17054
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
626 ;; Setting process-setup-function makes exit-message-function work |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
627 ;; even when async processes aren't supported. |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
628 (let* ((compilation-process-setup-function 'grep-process-setup) |
|
22404
9862ae4f05a7
(grep-null-device): Variable deleted.
Richard M. Stallman <rms@gnu.org>
parents:
22307
diff
changeset
|
629 (buf (compile-internal (if null-device |
|
9862ae4f05a7
(grep-null-device): Variable deleted.
Richard M. Stallman <rms@gnu.org>
parents:
22307
diff
changeset
|
630 (concat command-args " " null-device) |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
631 command-args) |
|
17054
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
632 "No more grep hits" "grep" |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
633 ;; Give it a simpler regexp to match. |
|
84414e5f194d
(grep-process-setup): New function, sets up the
Eli Zaretskii <eliz@gnu.org>
parents:
16997
diff
changeset
|
634 nil grep-regexp-alist))))) |
| 71 | 635 |
|
22208
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
636 ;; This is a copy of find-tag-default from etags.el. |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
637 (defun grep-tag-default () |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
638 (save-excursion |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
639 (while (looking-at "\\sw\\|\\s_") |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
640 (forward-char 1)) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
641 (when (or (re-search-backward "\\sw\\|\\s_" |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
642 (save-excursion (beginning-of-line) (point)) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
643 t) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
644 (re-search-forward "\\(\\sw\\|\\s_\\)+" |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
645 (save-excursion (end-of-line) (point)) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
646 t)) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
647 (goto-char (match-end 0)) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
648 (buffer-substring (point) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
649 (progn (forward-sexp -1) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
650 (while (looking-at "\\s'") |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
651 (forward-char 1)) |
|
5b05d45bfbbf
(grep-tag-default): New function.
Richard M. Stallman <rms@gnu.org>
parents:
21930
diff
changeset
|
652 (point)))))) |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
653 |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
654 ;;;###autoload |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
655 (defun grep-find (command-args) |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
656 "Run grep via find, with user-specified args, and collect output in a buffer. |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
657 While find runs asynchronously, you can use the \\[next-error] command |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
658 to find the text that grep hits refer to. |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
659 |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
660 This command uses a special history list for its arguments, so you can |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
661 easily repeat a find command." |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
662 (interactive |
|
22556
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
663 (progn |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
664 (unless grep-find-command |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
665 (grep-compute-defaults)) |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
666 (list (read-from-minibuffer "Run find (like this): " |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
667 grep-find-command nil nil |
|
892421e6b7b4
(grep-command): Initialize to nil.
Richard M. Stallman <rms@gnu.org>
parents:
22404
diff
changeset
|
668 'grep-find-history)))) |
|
22404
9862ae4f05a7
(grep-null-device): Variable deleted.
Richard M. Stallman <rms@gnu.org>
parents:
22307
diff
changeset
|
669 (let ((null-device nil)) ; see grep |
|
17242
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
670 (grep command-args))) |
|
7dd0da53476f
(grep-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17057
diff
changeset
|
671 |
|
20877
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
672 (defcustom compilation-scroll-output nil |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
673 "*Non-nil to scroll the *compilation* buffer window as output appears. |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
674 |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
675 Setting it causes the compilation-mode commands to put point at the |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
676 end of their output window so that the end of the output is always |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
677 visible rather than the begining." |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
678 :type 'boolean |
|
22291
7c8d8ad75d43
(compilation-scroll-output): Correct the :version
Karl Heuer <kwzh@gnu.org>
parents:
22208
diff
changeset
|
679 :version "20.3" |
|
20877
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
680 :group 'compilation) |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
681 |
| 71 | 682 (defun compile-internal (command error-message |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
683 &optional name-of-mode parser |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
684 error-regexp-alist name-function |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
685 enter-regexp-alist leave-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
686 file-regexp-alist nomessage-regexp-alist) |
| 71 | 687 "Run compilation command COMMAND (low level interface). |
| 688 ERROR-MESSAGE is a string to print if the user asks to see another error | |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
689 and there are no more errors. The rest of the arguments, 3-10 are optional. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
690 For them nil means use the default. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
691 NAME-OF-MODE is the name to display as the major mode in the compilation |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
692 buffer. PARSER is the error parser function. ERROR-REGEXP-ALIST is the error |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
693 message regexp alist to use. NAME-FUNCTION is a function called to name the |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
694 buffer. ENTER-REGEXP-ALIST is the enter directory message regexp alist to use. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
695 LEAVE-REGEXP-ALIST is the leave directory message regexp alist to use. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
696 FILE-REGEXP-ALIST is the change current file message regexp alist to use. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
697 NOMESSAGE-REGEXP-ALIST is the nomessage regexp alist to use. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
698 The defaults for these variables are the global values of |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
699 \`compilation-parse-errors-function', `compilation-error-regexp-alist', |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
700 \`compilation-buffer-name-function', `compilation-enter-directory-regexp-alist', |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
701 \`compilation-leave-directory-regexp-alist', `compilation-file-regexp-alist', |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
702 \ and `compilation-nomessage-regexp-alist', respectively. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
703 For arg 7-10 a value `t' means an empty alist. |
| 894 | 704 |
| 705 Returns the compilation buffer created." | |
| 418 | 706 (let (outbuf) |
| 71 | 707 (save-excursion |
| 418 | 708 (or name-of-mode |
| 709 (setq name-of-mode "Compilation")) | |
| 710 (setq outbuf | |
| 711 (get-buffer-create | |
| 712 (funcall (or name-function compilation-buffer-name-function | |
| 713 (function (lambda (mode) | |
| 714 (concat "*" (downcase mode) "*")))) | |
| 715 name-of-mode))) | |
| 71 | 716 (set-buffer outbuf) |
| 418 | 717 (let ((comp-proc (get-buffer-process (current-buffer)))) |
| 718 (if comp-proc | |
| 719 (if (or (not (eq (process-status comp-proc) 'run)) | |
| 720 (yes-or-no-p | |
|
1554
5af75a1a9a24
* compile.el (compile-internal): Use NAME-OF-MODE in the prompt
Jim Blandy <jimb@redhat.com>
parents:
1294
diff
changeset
|
721 (format "A %s process is running; kill it? " |
|
5af75a1a9a24
* compile.el (compile-internal): Use NAME-OF-MODE in the prompt
Jim Blandy <jimb@redhat.com>
parents:
1294
diff
changeset
|
722 name-of-mode))) |
| 418 | 723 (condition-case () |
| 724 (progn | |
| 725 (interrupt-process comp-proc) | |
| 726 (sit-for 1) | |
| 727 (delete-process comp-proc)) | |
| 728 (error nil)) | |
| 729 (error "Cannot have two processes in `%s' at once" | |
| 730 (buffer-name)) | |
| 731 ))) | |
| 732 ;; In case the compilation buffer is current, make sure we get the global | |
| 733 ;; values of compilation-error-regexp-alist, etc. | |
| 734 (kill-all-local-variables)) | |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
735 (or error-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
736 (setq error-regexp-alist compilation-error-regexp-alist)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
737 (or enter-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
738 (setq enter-regexp-alist compilation-enter-directory-regexp-alist)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
739 (or leave-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
740 (setq leave-regexp-alist compilation-leave-directory-regexp-alist)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
741 (or file-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
742 (setq file-regexp-alist compilation-file-regexp-alist)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
743 (or nomessage-regexp-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
744 (setq nomessage-regexp-alist compilation-nomessage-regexp-alist)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
745 (or parser (setq parser compilation-parse-errors-function)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
746 (let ((thisdir default-directory) |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
747 outwin) |
| 418 | 748 (save-excursion |
| 749 ;; Clear out the compilation buffer and make it writable. | |
| 750 ;; Change its default-directory to the directory where the compilation | |
| 751 ;; will happen, and insert a `cd' command to indicate this. | |
| 752 (set-buffer outbuf) | |
| 753 (setq buffer-read-only nil) | |
|
11618
9702de178097
(compile-internal): Disable undo before erasing
Richard M. Stallman <rms@gnu.org>
parents:
11359
diff
changeset
|
754 (buffer-disable-undo (current-buffer)) |
| 418 | 755 (erase-buffer) |
|
11618
9702de178097
(compile-internal): Disable undo before erasing
Richard M. Stallman <rms@gnu.org>
parents:
11359
diff
changeset
|
756 (buffer-enable-undo (current-buffer)) |
| 418 | 757 (setq default-directory thisdir) |
| 758 (insert "cd " thisdir "\n" command "\n") | |
| 759 (set-buffer-modified-p nil)) | |
| 760 ;; If we're already in the compilation buffer, go to the end | |
| 761 ;; of the buffer, so point will track the compilation output. | |
| 762 (if (eq outbuf (current-buffer)) | |
| 763 (goto-char (point-max))) | |
| 764 ;; Pop up the compilation buffer. | |
| 765 (setq outwin (display-buffer outbuf)) | |
|
3514
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
766 (save-excursion |
|
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
767 (set-buffer outbuf) |
|
21930
b84bfe98263d
* progmodes/compile.el (compilation-directory-stack): Doc fix.
Andreas Schwab <schwab@suse.de>
parents:
21224
diff
changeset
|
768 (compilation-mode name-of-mode) |
|
4757
c21680a58d1e
(compile-internal): Back out jimb change of making buffer read-only. It
Brian Fox <bfox@gnu.org>
parents:
4612
diff
changeset
|
769 ;; (setq buffer-read-only t) ;;; Non-ergonomic. |
|
3514
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
770 (set (make-local-variable 'compilation-parse-errors-function) parser) |
|
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
771 (set (make-local-variable 'compilation-error-message) error-message) |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
772 (set (make-local-variable 'compilation-error-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
773 error-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
774 (set (make-local-variable 'compilation-enter-directory-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
775 enter-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
776 (set (make-local-variable 'compilation-leave-directory-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
777 leave-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
778 (set (make-local-variable 'compilation-file-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
779 file-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
780 (set (make-local-variable 'compilation-nomessage-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
781 nomessage-regexp-alist) |
|
17866
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
782 (set (make-local-variable 'compilation-arguments) |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
783 (list command error-message |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
784 name-of-mode parser |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
785 error-regexp-alist name-function |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
786 enter-regexp-alist leave-regexp-alist |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
787 file-regexp-alist nomessage-regexp-alist)) |
|
20877
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
788 (make-local-variable 'lazy-lock-defer-on-scrolling) |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
789 ;; This proves a good idea if the buffer's going to scroll |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
790 ;; with lazy-lock on. |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
791 (setq lazy-lock-defer-on-scrolling t) |
|
3514
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
792 (setq default-directory thisdir |
|
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
793 compilation-directory-stack (list default-directory)) |
|
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
794 (set-window-start outwin (point-min)) |
|
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
795 (or (eq outwin (selected-window)) |
|
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
796 (set-window-point outwin (point-min))) |
|
8483
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
797 (compilation-set-window-height outwin) |
|
16985
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
798 (if compilation-process-setup-function |
|
b0d8e7c0f906
* (compilation-process-setup-function): New variable.
Eli Zaretskii <eliz@gnu.org>
parents:
16950
diff
changeset
|
799 (funcall compilation-process-setup-function)) |
|
3514
7a3e241a2917
(compile-internal): Alter current buffer only temporarily.
Richard M. Stallman <rms@gnu.org>
parents:
3147
diff
changeset
|
800 ;; Start the compilation. |
|
5456
b34aaec781fc
(compile-internal): Extended to work without asynchronous subprocesses.
Richard M. Stallman <rms@gnu.org>
parents:
5406
diff
changeset
|
801 (if (fboundp 'start-process) |
|
8810
6ca3e0d3b7ca
(compile-internal): Set EMACS=t in process-environment.
Richard M. Stallman <rms@gnu.org>
parents:
8795
diff
changeset
|
802 (let* ((process-environment (cons "EMACS=t" process-environment)) |
|
6ca3e0d3b7ca
(compile-internal): Set EMACS=t in process-environment.
Richard M. Stallman <rms@gnu.org>
parents:
8795
diff
changeset
|
803 (proc (start-process-shell-command (downcase mode-name) |
|
6ca3e0d3b7ca
(compile-internal): Set EMACS=t in process-environment.
Richard M. Stallman <rms@gnu.org>
parents:
8795
diff
changeset
|
804 outbuf |
|
6ca3e0d3b7ca
(compile-internal): Set EMACS=t in process-environment.
Richard M. Stallman <rms@gnu.org>
parents:
8795
diff
changeset
|
805 command))) |
|
5456
b34aaec781fc
(compile-internal): Extended to work without asynchronous subprocesses.
Richard M. Stallman <rms@gnu.org>
parents:
5406
diff
changeset
|
806 (set-process-sentinel proc 'compilation-sentinel) |
|
b34aaec781fc
(compile-internal): Extended to work without asynchronous subprocesses.
Richard M. Stallman <rms@gnu.org>
parents:
5406
diff
changeset
|
807 (set-process-filter proc 'compilation-filter) |
|
b34aaec781fc
(compile-internal): Extended to work without asynchronous subprocesses.
Richard M. Stallman <rms@gnu.org>
parents:
5406
diff
changeset
|
808 (set-marker (process-mark proc) (point) outbuf) |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
809 (setq compilation-in-progress |
|
5456
b34aaec781fc
(compile-internal): Extended to work without asynchronous subprocesses.
Richard M. Stallman <rms@gnu.org>
parents:
5406
diff
changeset
|
810 (cons proc compilation-in-progress))) |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
811 ;; No asynchronous processes available. |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
812 (message "Executing `%s'..." command) |
|
13819
57cd7ef01dc7
(compile-internal): On systems with no asynchronous
Richard M. Stallman <rms@gnu.org>
parents:
13755
diff
changeset
|
813 ;; Fake modeline display as if `start-process' were run. |
|
57cd7ef01dc7
(compile-internal): On systems with no asynchronous
Richard M. Stallman <rms@gnu.org>
parents:
13755
diff
changeset
|
814 (setq mode-line-process ":run") |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
815 (force-mode-line-update) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
816 (sit-for 0) ; Force redisplay |
|
5456
b34aaec781fc
(compile-internal): Extended to work without asynchronous subprocesses.
Richard M. Stallman <rms@gnu.org>
parents:
5406
diff
changeset
|
817 (let ((status (call-process shell-file-name nil outbuf nil "-c" |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
818 command))) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
819 (cond ((numberp status) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
820 (compilation-handle-exit 'exit status |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
821 (if (zerop status) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
822 "finished\n" |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
823 (format "\ |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
824 exited abnormally with code %d\n" |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
825 status)))) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
826 ((stringp status) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
827 (compilation-handle-exit 'signal status |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
828 (concat status "\n"))) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
829 (t |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
830 (compilation-handle-exit 'bizarre status status)))) |
|
20877
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
831 (message "Executing `%s'...done" command))) |
|
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
832 (if compilation-scroll-output |
|
24326
0c8191e60c80
(compile-internal): Use save-selected-window.
Richard M. Stallman <rms@gnu.org>
parents:
24288
diff
changeset
|
833 (save-selected-window |
|
20877
4b22b9a5bd8e
(compilation-scroll-output): New variable.
Dave Love <fx@gnu.org>
parents:
20187
diff
changeset
|
834 (select-window outwin) |
|
24326
0c8191e60c80
(compile-internal): Use save-selected-window.
Richard M. Stallman <rms@gnu.org>
parents:
24288
diff
changeset
|
835 (goto-char (point-max))))) |
| 418 | 836 ;; Make it so the next C-x ` will use this buffer. |
| 837 (setq compilation-last-buffer outbuf))) | |
| 71 | 838 |
|
8483
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
839 ;; Set the height of WINDOW according to compilation-window-height. |
|
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
840 (defun compilation-set-window-height (window) |
|
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
841 (and compilation-window-height |
|
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
842 (= (window-width window) (frame-width (window-frame window))) |
|
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
843 ;; If window is alone in its frame, aside from a minibuffer, |
|
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
844 ;; don't change its height. |
|
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
845 (not (eq window (frame-root-window (window-frame window)))) |
|
8522
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
846 ;; This save-excursion prevents us from changing the current buffer, |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
847 ;; which might not be the same as the selected window's buffer. |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
848 (save-excursion |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
849 (let ((w (selected-window))) |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
850 (unwind-protect |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
851 (progn |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
852 (select-window window) |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
853 (enlarge-window (- compilation-window-height |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
854 (window-height)))) |
|
593457877265
(compilation-set-window-height): Add save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
8483
diff
changeset
|
855 (select-window w)))))) |
|
8483
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
856 |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
857 (defvar compilation-minor-mode-map |
| 71 | 858 (let ((map (make-sparse-keymap))) |
|
6595
7fbc171fd1b5
(compile-mouse-goto-error): New command.
Richard M. Stallman <rms@gnu.org>
parents:
6412
diff
changeset
|
859 (define-key map [mouse-2] 'compile-mouse-goto-error) |
| 71 | 860 (define-key map "\C-c\C-c" 'compile-goto-error) |
|
10268
84777124c262
(compilation-minor-mode-map): Bind C-m to compilation-goto-error.
Richard M. Stallman <rms@gnu.org>
parents:
10096
diff
changeset
|
861 (define-key map "\C-m" 'compile-goto-error) |
| 418 | 862 (define-key map "\C-c\C-k" 'kill-compilation) |
| 894 | 863 (define-key map "\M-n" 'compilation-next-error) |
| 864 (define-key map "\M-p" 'compilation-previous-error) | |
| 946 | 865 (define-key map "\M-{" 'compilation-previous-file) |
| 866 (define-key map "\M-}" 'compilation-next-file) | |
| 71 | 867 map) |
|
2760
1c7595e3089b
(Setting minor-mode-map-alist):
Richard M. Stallman <rms@gnu.org>
parents:
2603
diff
changeset
|
868 "Keymap for `compilation-minor-mode'.") |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
869 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
870 (defvar compilation-shell-minor-mode-map |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
871 (let ((map (make-sparse-keymap))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
872 (define-key map [mouse-2] 'compile-mouse-goto-error) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
873 (define-key map "\M-\C-m" 'compile-goto-error) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
874 (define-key map "\M-\C-n" 'compilation-next-error) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
875 (define-key map "\M-\C-p" 'compilation-previous-error) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
876 (define-key map "\M-{" 'compilation-previous-file) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
877 (define-key map "\M-}" 'compilation-next-file) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
878 ;; Set up the menu-bar |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
879 (define-key map [menu-bar errors-menu] |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
880 (cons "Errors" (make-sparse-keymap "Errors"))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
881 (define-key map [menu-bar errors-menu stop-subjob] |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
882 '("Stop" . comint-interrupt-subjob)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
883 (define-key map [menu-bar errors-menu compilation-mode-separator2] |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
884 '("----" . nil)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
885 (define-key map [menu-bar errors-menu compilation-mode-first-error] |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
886 '("First Error" . first-error)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
887 (define-key map [menu-bar errors-menu compilation-mode-previous-error] |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
888 '("Previous Error" . previous-error)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
889 (define-key map [menu-bar errors-menu compilation-mode-next-error] |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
890 '("Next Error" . next-error)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
891 map) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
892 "Keymap for `compilation-shell-minor-mode'.") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
893 |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
894 (defvar compilation-mode-map |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
895 (let ((map (cons 'keymap compilation-minor-mode-map))) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
896 (define-key map " " 'scroll-up) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
897 (define-key map "\^?" 'scroll-down) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
898 ;; Set up the menu-bar |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
899 (define-key map [menu-bar compilation-menu] |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
900 (cons "Compile" (make-sparse-keymap "Compile"))) |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
901 |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
902 (define-key map [menu-bar compilation-menu compilation-mode-kill-compilation] |
|
12029
42da35386c5d
(compilation-mode-map): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents:
12021
diff
changeset
|
903 '("Stop Compilation" . kill-compilation)) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
904 (define-key map [menu-bar compilation-menu compilation-mode-separator2] |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
905 '("----" . nil)) |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
906 (define-key map [menu-bar compilation-menu compilation-mode-first-error] |
|
12029
42da35386c5d
(compilation-mode-map): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents:
12021
diff
changeset
|
907 '("First Error" . first-error)) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
908 (define-key map [menu-bar compilation-menu compilation-mode-previous-error] |
|
12029
42da35386c5d
(compilation-mode-map): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents:
12021
diff
changeset
|
909 '("Previous Error" . previous-error)) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
910 (define-key map [menu-bar compilation-menu compilation-mode-next-error] |
|
12029
42da35386c5d
(compilation-mode-map): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents:
12021
diff
changeset
|
911 '("Next Error" . next-error)) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
912 (define-key map [menu-bar compilation-menu compilation-separator2] |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
913 '("----" . nil)) |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
914 (define-key map [menu-bar compilation-menu compilation-mode-grep] |
|
20000
ccccaf435fdd
(compilation-mode-map): Use more meaningful menu name.
Karl Heuer <kwzh@gnu.org>
parents:
19887
diff
changeset
|
915 '("Search Files (grep)" . grep)) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
916 (define-key map [menu-bar compilation-menu compilation-mode-recompile] |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
917 '("Recompile" . recompile)) |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
918 (define-key map [menu-bar compilation-menu compilation-mode-compile] |
|
17057
e54588a6cea9
Add ... to relevant menu entries.
Simon Marshall <simon@gnu.org>
parents:
17056
diff
changeset
|
919 '("Compile..." . compile)) |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
920 map) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
921 "Keymap for compilation log buffers. |
|
2760
1c7595e3089b
(Setting minor-mode-map-alist):
Richard M. Stallman <rms@gnu.org>
parents:
2603
diff
changeset
|
922 `compilation-minor-mode-map' is a cdr of this.") |
| 71 | 923 |
|
17653
b7810d4fb620
(compilation-mode): Add a mode-class property.
Richard M. Stallman <rms@gnu.org>
parents:
17639
diff
changeset
|
924 (put 'compilation-mode 'mode-class 'special) |
|
b7810d4fb620
(compilation-mode): Add a mode-class property.
Richard M. Stallman <rms@gnu.org>
parents:
17639
diff
changeset
|
925 |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
926 ;;;###autoload |
|
21930
b84bfe98263d
* progmodes/compile.el (compilation-directory-stack): Doc fix.
Andreas Schwab <schwab@suse.de>
parents:
21224
diff
changeset
|
927 (defun compilation-mode (&optional name-of-mode) |
| 71 | 928 "Major mode for compilation log buffers. |
| 929 \\<compilation-mode-map>To visit the source for a line-numbered error, | |
| 418 | 930 move point to the error message line and type \\[compile-goto-error]. |
| 569 | 931 To kill the compilation, type \\[kill-compilation]. |
| 932 | |
| 933 Runs `compilation-mode-hook' with `run-hooks' (which see)." | |
| 71 | 934 (interactive) |
|
9376
f0ac347309e2
(compilation-mode-font-lock-keywords): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8976
diff
changeset
|
935 (kill-all-local-variables) |
| 71 | 936 (use-local-map compilation-mode-map) |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
937 (setq major-mode 'compilation-mode |
|
21930
b84bfe98263d
* progmodes/compile.el (compilation-directory-stack): Doc fix.
Andreas Schwab <schwab@suse.de>
parents:
21224
diff
changeset
|
938 mode-name (or name-of-mode "Compilation")) |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
939 (compilation-setup) |
|
9473
b0cc803bf367
* compile.el: (compilation-mode): Set font-lock-defaults.
Simon Marshall <simon@gnu.org>
parents:
9376
diff
changeset
|
940 (set (make-local-variable 'font-lock-defaults) |
|
b0cc803bf367
* compile.el: (compilation-mode): Set font-lock-defaults.
Simon Marshall <simon@gnu.org>
parents:
9376
diff
changeset
|
941 '(compilation-mode-font-lock-keywords t)) |
|
17866
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
942 (set (make-local-variable 'revert-buffer-function) |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
943 'compilation-revert-buffer) |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
944 (run-hooks 'compilation-mode-hook)) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
945 |
|
17866
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
946 (defun compilation-revert-buffer (ignore-auto noconfirm) |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
947 (if (or noconfirm (yes-or-no-p (format "Restart compilation? "))) |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
948 (apply 'compile-internal compilation-arguments))) |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
949 |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
950 ;; Prepare the buffer for the compilation parsing commands to work. |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
951 (defun compilation-setup () |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
952 ;; Make the buffer's mode line show process state. |
|
7072
5da29eb68c82
(compilation-setup, compilation-sentinel):
Richard M. Stallman <rms@gnu.org>
parents:
6989
diff
changeset
|
953 (setq mode-line-process '(":%s")) |
| 418 | 954 (set (make-local-variable 'compilation-error-list) nil) |
| 955 (set (make-local-variable 'compilation-old-error-list) nil) | |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
956 (set (make-local-variable 'compilation-parsing-end) (copy-marker 1)) |
|
24284
c8a762e57cf6
(compilation-setup): Set value of
Richard M. Stallman <rms@gnu.org>
parents:
24264
diff
changeset
|
957 (set (make-local-variable 'compilation-directory-stack) |
|
c8a762e57cf6
(compilation-setup): Set value of
Richard M. Stallman <rms@gnu.org>
parents:
24264
diff
changeset
|
958 (list default-directory)) |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
959 (setq compilation-last-buffer (current-buffer))) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
960 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
961 (defvar compilation-shell-minor-mode nil |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
962 "Non-nil when in compilation-shell-minor-mode. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
963 In this minor mode, all the error-parsing commands of the |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
964 Compilation major mode are available but bound to keys that don't |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
965 collide with Shell mode.") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
966 (make-variable-buffer-local 'compilation-shell-minor-mode) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
967 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
968 (or (assq 'compilation-shell-minor-mode minor-mode-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
969 (setq minor-mode-alist |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
970 (cons '(compilation-shell-minor-mode " Shell-Compile") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
971 minor-mode-alist))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
972 (or (assq 'compilation-shell-minor-mode minor-mode-map-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
973 (setq minor-mode-map-alist (cons (cons 'compilation-shell-minor-mode |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
974 compilation-shell-minor-mode-map) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
975 minor-mode-map-alist))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
976 |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
977 (defvar compilation-minor-mode nil |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
978 "Non-nil when in compilation-minor-mode. |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
979 In this minor mode, all the error-parsing commands of the |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
980 Compilation major mode are available.") |
|
4445
a1e412873732
(compilation-minor-mode): Make variable buffer-local.
Roland McGrath <roland@gnu.org>
parents:
4350
diff
changeset
|
981 (make-variable-buffer-local 'compilation-minor-mode) |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
982 |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
983 (or (assq 'compilation-minor-mode minor-mode-alist) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
984 (setq minor-mode-alist (cons '(compilation-minor-mode " Compilation") |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
985 minor-mode-alist))) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
986 (or (assq 'compilation-minor-mode minor-mode-map-alist) |
|
2760
1c7595e3089b
(Setting minor-mode-map-alist):
Richard M. Stallman <rms@gnu.org>
parents:
2603
diff
changeset
|
987 (setq minor-mode-map-alist (cons (cons 'compilation-minor-mode |
|
1c7595e3089b
(Setting minor-mode-map-alist):
Richard M. Stallman <rms@gnu.org>
parents:
2603
diff
changeset
|
988 compilation-minor-mode-map) |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
989 minor-mode-map-alist))) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
990 |
|
4445
a1e412873732
(compilation-minor-mode): Make variable buffer-local.
Roland McGrath <roland@gnu.org>
parents:
4350
diff
changeset
|
991 ;;;###autoload |
|
24053
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
992 (defun compilation-shell-minor-mode (&optional arg) |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
993 "Toggle compilation shell minor mode. |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
994 With arg, turn compilation mode on if and only if arg is positive. |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
995 See `compilation-mode'. |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
996 Turning the mode on runs the normal hook `compilation-shell-minor-mode-hook'." |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
997 (interactive "P") |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
998 (if (setq compilation-shell-minor-mode (if (null arg) |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
999 (null compilation-shell-minor-mode) |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
1000 (> (prefix-numeric-value arg) 0))) |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
1001 (let ((mode-line-process)) |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
1002 (compilation-setup) |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
1003 (run-hooks 'compilation-shell-minor-mode-hook)))) |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
1004 |
|
551467b8a092
(compilation-shell-minor-mode): New function.
Richard M. Stallman <rms@gnu.org>
parents:
23866
diff
changeset
|
1005 ;;;###autoload |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
1006 (defun compilation-minor-mode (&optional arg) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
1007 "Toggle compilation minor mode. |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
1008 With arg, turn compilation mode on if and only if arg is positive. |
|
14607
3c86ac6a871a
(compilation-minor-mode): Run compilation-minor-mode-hook.
Roland McGrath <roland@gnu.org>
parents:
14562
diff
changeset
|
1009 See `compilation-mode'. |
|
3c86ac6a871a
(compilation-minor-mode): Run compilation-minor-mode-hook.
Roland McGrath <roland@gnu.org>
parents:
14562
diff
changeset
|
1010 Turning the mode on runs the normal hook `compilation-minor-mode-hook'." |
|
2603
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
1011 (interactive "P") |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
1012 (if (setq compilation-minor-mode (if (null arg) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
1013 (null compilation-minor-mode) |
|
f80a342fd945
Add compilation-minor-mode to minor-mode-alist and minor-mode-map-alist.
Roland McGrath <roland@gnu.org>
parents:
2478
diff
changeset
|
1014 (> (prefix-numeric-value arg) 0))) |
|
21930
b84bfe98263d
* progmodes/compile.el (compilation-directory-stack): Doc fix.
Andreas Schwab <schwab@suse.de>
parents:
21224
diff
changeset
|
1015 (let ((mode-line-process)) |
|
14607
3c86ac6a871a
(compilation-minor-mode): Run compilation-minor-mode-hook.
Roland McGrath <roland@gnu.org>
parents:
14562
diff
changeset
|
1016 (compilation-setup) |
|
14643
9a31b6a37efd
(compilation-minor-mode): Add missing `)'.
Erik Naggum <erik@naggum.no>
parents:
14607
diff
changeset
|
1017 (run-hooks 'compilation-minor-mode-hook)))) |
| 71 | 1018 |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1019 ;; Write msg in the current buffer and hack its mode-line-process. |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1020 (defun compilation-handle-exit (process-status exit-status msg) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1021 (let ((buffer-read-only nil) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1022 (status (if compilation-exit-message-function |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1023 (funcall compilation-exit-message-function |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1024 process-status exit-status msg) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1025 (cons msg exit-status))) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1026 (omax (point-max)) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1027 (opoint (point))) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1028 ;; Record where we put the message, so we can ignore it |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1029 ;; later on. |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1030 (goto-char omax) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1031 (insert ?\n mode-name " " (car status)) |
|
24558
ea8a9509b52f
(compilation-handle-exit): Do right thing
Richard M. Stallman <rms@gnu.org>
parents:
24326
diff
changeset
|
1032 (if (bolp) |
|
ea8a9509b52f
(compilation-handle-exit): Do right thing
Richard M. Stallman <rms@gnu.org>
parents:
24326
diff
changeset
|
1033 (forward-char -1)) |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1034 (insert " at " (substring (current-time-string) 0 19)) |
|
24558
ea8a9509b52f
(compilation-handle-exit): Do right thing
Richard M. Stallman <rms@gnu.org>
parents:
24326
diff
changeset
|
1035 (goto-char (point-max)) |
|
14260
4577848d3ef2
(compilation-handle-exit): Undo previous change.
Karl Heuer <kwzh@gnu.org>
parents:
14250
diff
changeset
|
1036 (setq mode-line-process (format ":%s [%s]" process-status (cdr status))) |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1037 ;; Force mode line redisplay soon. |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1038 (force-mode-line-update) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1039 (if (and opoint (< opoint omax)) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1040 (goto-char opoint)) |
|
16519
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1041 ;; Automatically parse (and mouse-highlight) error messages: |
|
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1042 (cond ((eq compile-auto-highlight t) |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1043 (compile-reinitialize-errors nil (point-max))) |
|
16519
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1044 ((numberp compile-auto-highlight) |
|
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1045 (compile-reinitialize-errors nil |
|
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1046 (save-excursion |
|
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1047 (goto-line compile-auto-highlight) |
|
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1048 (point))))) |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1049 (if compilation-finish-function |
|
16042
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
1050 (funcall compilation-finish-function (current-buffer) msg)) |
|
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
1051 (let ((functions compilation-finish-functions)) |
|
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
1052 (while functions |
|
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
1053 (funcall (car functions) (current-buffer) msg) |
|
18414e324084
(compilation-finish-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15084
diff
changeset
|
1054 (setq functions (cdr functions)))))) |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1055 |
| 71 | 1056 ;; Called when compilation process changes state. |
| 1057 (defun compilation-sentinel (proc msg) | |
| 418 | 1058 "Sentinel for compilation buffers." |
| 1059 (let ((buffer (process-buffer proc))) | |
| 740 | 1060 (if (memq (process-status proc) '(signal exit)) |
| 1061 (progn | |
| 1062 (if (null (buffer-name buffer)) | |
| 1063 ;; buffer killed | |
| 1064 (set-process-buffer proc nil) | |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1065 (let ((obuf (current-buffer))) |
| 740 | 1066 ;; save-excursion isn't the right thing if |
| 1067 ;; process-buffer is current-buffer | |
| 1068 (unwind-protect | |
| 1069 (progn | |
| 1070 ;; Write something in the compilation buffer | |
| 1071 ;; and hack its mode line. | |
| 1072 (set-buffer buffer) | |
|
14045
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1073 (compilation-handle-exit (process-status proc) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1074 (process-exit-status proc) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1075 msg) |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1076 ;; Since the buffer and mode line will show that the |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1077 ;; process is dead, we can delete it now. Otherwise it |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1078 ;; will stay around until M-x list-processes. |
|
1300c7703f67
(compilation-handle-exit): New function, broken out of compilation-sentinel.
Roland McGrath <roland@gnu.org>
parents:
13972
diff
changeset
|
1079 (delete-process proc)) |
| 1133 | 1080 (set-buffer obuf)))) |
| 740 | 1081 (setq compilation-in-progress (delq proc compilation-in-progress)) |
| 1082 )))) | |
| 71 | 1083 |
|
2472
f911936cec3f
(compilation-filter): New function.
Roland McGrath <roland@gnu.org>
parents:
2471
diff
changeset
|
1084 (defun compilation-filter (proc string) |
|
f911936cec3f
(compilation-filter): New function.
Roland McGrath <roland@gnu.org>
parents:
2471
diff
changeset
|
1085 "Process filter for compilation buffers. |
|
2760
1c7595e3089b
(Setting minor-mode-map-alist):
Richard M. Stallman <rms@gnu.org>
parents:
2603
diff
changeset
|
1086 Just inserts the text, but uses `insert-before-markers'." |
|
9511
3b5dbd9c44f5
(compilation-filter): Do nothing if buffer is dead.
Richard M. Stallman <rms@gnu.org>
parents:
9473
diff
changeset
|
1087 (if (buffer-name (process-buffer proc)) |
|
2472
f911936cec3f
(compilation-filter): New function.
Roland McGrath <roland@gnu.org>
parents:
2471
diff
changeset
|
1088 (save-excursion |
|
9511
3b5dbd9c44f5
(compilation-filter): Do nothing if buffer is dead.
Richard M. Stallman <rms@gnu.org>
parents:
9473
diff
changeset
|
1089 (set-buffer (process-buffer proc)) |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1090 (let ((buffer-read-only nil) |
|
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1091 (end (marker-position compilation-parsing-end))) |
|
9511
3b5dbd9c44f5
(compilation-filter): Do nothing if buffer is dead.
Richard M. Stallman <rms@gnu.org>
parents:
9473
diff
changeset
|
1092 (save-excursion |
|
3b5dbd9c44f5
(compilation-filter): Do nothing if buffer is dead.
Richard M. Stallman <rms@gnu.org>
parents:
9473
diff
changeset
|
1093 (goto-char (process-mark proc)) |
|
3b5dbd9c44f5
(compilation-filter): Do nothing if buffer is dead.
Richard M. Stallman <rms@gnu.org>
parents:
9473
diff
changeset
|
1094 (insert-before-markers string) |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1095 (set-marker compilation-parsing-end end) ;don't move it |
|
14455
1ce19c0594b1
(compilation-filter): Run compilation-filter-hook.
Richard M. Stallman <rms@gnu.org>
parents:
14260
diff
changeset
|
1096 (run-hooks 'compilation-filter-hook) |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1097 ;; this seems redundant since we insert-before-marks -stefan |
|
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1098 ;;(set-marker (process-mark proc) (point)) |
|
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1099 ))))) |
|
2472
f911936cec3f
(compilation-filter): New function.
Roland McGrath <roland@gnu.org>
parents:
2471
diff
changeset
|
1100 |
| 920 | 1101 ;; Return the cdr of compilation-old-error-list for the error containing point. |
| 1102 (defun compile-error-at-point () | |
| 1103 (compile-reinitialize-errors nil (point)) | |
| 1104 (let ((errors compilation-old-error-list)) | |
| 1105 (while (and errors | |
| 1106 (> (point) (car (car errors)))) | |
| 1107 (setq errors (cdr errors))) | |
| 1108 errors)) | |
| 1109 | |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1110 (defsubst compilation-buffer-p (buffer) |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1111 (save-excursion |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1112 (set-buffer buffer) |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1113 (or compilation-shell-minor-mode compilation-minor-mode |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1114 (eq major-mode 'compilation-mode)))) |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1115 |
| 894 | 1116 (defun compilation-next-error (n) |
| 1117 "Move point to the next error in the compilation buffer. | |
| 1118 Does NOT find the source line like \\[next-error]." | |
| 1119 (interactive "p") | |
| 1120 (or (compilation-buffer-p (current-buffer)) | |
| 1121 (error "Not in a compilation buffer.")) | |
| 1122 (setq compilation-last-buffer (current-buffer)) | |
| 1123 | |
| 920 | 1124 (let ((errors (compile-error-at-point))) |
| 894 | 1125 |
| 920 | 1126 ;; Move to the error after the one containing point. |
| 1127 (goto-char (car (if (< n 0) | |
| 1128 (let ((i 0) | |
| 1129 (e compilation-old-error-list)) | |
| 1130 ;; See how many cdrs away ERRORS is from the start. | |
| 1131 (while (not (eq e errors)) | |
| 1132 (setq i (1+ i) | |
| 1133 e (cdr e))) | |
| 1134 (if (> (- n) i) | |
| 1135 (error "Moved back past first error") | |
| 1136 (nth (+ i n) compilation-old-error-list))) | |
| 1137 (let ((compilation-error-list (cdr errors))) | |
| 1138 (compile-reinitialize-errors nil nil n) | |
| 1139 (if compilation-error-list | |
| 1140 (nth (1- n) compilation-error-list) | |
| 1141 (error "Moved past last error")))))))) | |
| 894 | 1142 |
| 1143 (defun compilation-previous-error (n) | |
| 1144 "Move point to the previous error in the compilation buffer. | |
| 1145 Does NOT find the source line like \\[next-error]." | |
| 1146 (interactive "p") | |
| 1147 (compilation-next-error (- n))) | |
| 1148 | |
| 1149 | |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1150 ;; Given an elt of `compilation-error-list', return an object representing |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1151 ;; the referenced file which is equal to (but not necessarily eq to) what |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1152 ;; this function would return for another error in the same file. |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1153 (defsubst compilation-error-filedata (data) |
| 920 | 1154 (setq data (cdr data)) |
| 1155 (if (markerp data) | |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1156 (marker-buffer data) |
|
3875
c5b6f641698a
* compile.el (compile-file-of-error): Remember that
Jim Blandy <jimb@redhat.com>
parents:
3825
diff
changeset
|
1157 (car data))) |
| 920 | 1158 |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1159 ;; Return a string describing a value from compilation-error-filedata. |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1160 ;; This value is not necessarily useful as a file name, but should be |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1161 ;; indicative to the user of what file's errors are being referred to. |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1162 (defsubst compilation-error-filedata-file-name (filedata) |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1163 (if (bufferp filedata) |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1164 (buffer-file-name filedata) |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1165 (car filedata))) |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1166 |
| 920 | 1167 (defun compilation-next-file (n) |
| 1168 "Move point to the next error for a different file than the current one." | |
| 1169 (interactive "p") | |
| 1170 (or (compilation-buffer-p (current-buffer)) | |
| 1171 (error "Not in a compilation buffer.")) | |
| 1172 (setq compilation-last-buffer (current-buffer)) | |
| 1173 | |
| 1174 (let ((reversed (< n 0)) | |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1175 errors filedata) |
| 920 | 1176 |
| 1177 (if (not reversed) | |
| 1178 (setq errors (or (compile-error-at-point) | |
| 1179 (error "Moved past last error"))) | |
| 1180 | |
| 1181 ;; Get a reversed list of the errors up through the one containing point. | |
| 1182 (compile-reinitialize-errors nil (point)) | |
| 1183 (setq errors (reverse compilation-old-error-list) | |
| 1184 n (- n)) | |
| 1185 | |
| 1186 ;; Ignore errors after point. (car ERRORS) will be the error | |
| 1187 ;; containing point, (cadr ERRORS) the one before it. | |
| 1188 (while (and errors | |
| 1189 (< (point) (car (car errors)))) | |
| 1190 (setq errors (cdr errors)))) | |
| 1191 | |
| 1192 (while (> n 0) | |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1193 (setq filedata (compilation-error-filedata (car errors))) |
| 920 | 1194 |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1195 ;; Skip past the following errors for this file. |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1196 (while (equal filedata |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1197 (compilation-error-filedata |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1198 (car (or errors |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1199 (if reversed |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1200 (error "%s the first erring file" |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1201 (compilation-error-filedata-file-name |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1202 filedata)) |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1203 (let ((compilation-error-list nil)) |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1204 ;; Parse some more. |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1205 (compile-reinitialize-errors nil nil 2) |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1206 (setq errors compilation-error-list))) |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
1207 (error "%s is the last erring file" |
|
4153
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1208 (compilation-error-filedata-file-name |
|
787df5416fba
(compilation-error-list): An elt's cdr's car is again a cons (DIRECTORY .
Roland McGrath <roland@gnu.org>
parents:
4093
diff
changeset
|
1209 filedata)))))) |
| 920 | 1210 (setq errors (cdr errors))) |
| 1211 | |
| 1212 (setq n (1- n))) | |
| 1213 | |
| 1214 ;; Move to the following error. | |
| 1215 (goto-char (car (car (or errors | |
| 1216 (if reversed | |
| 1217 (error "This is the first erring file") | |
| 1218 (let ((compilation-error-list nil)) | |
| 1219 ;; Parse the last one. | |
| 1220 (compile-reinitialize-errors nil nil 1) | |
| 1221 compilation-error-list)))))))) | |
| 1222 | |
| 1223 (defun compilation-previous-file (n) | |
| 1224 "Move point to the previous error for a different file than the current one." | |
| 1225 (interactive "p") | |
| 1226 (compilation-next-file (- n))) | |
| 1227 | |
| 1228 | |
| 71 | 1229 (defun kill-compilation () |
| 1230 "Kill the process made by the \\[compile] command." | |
| 1231 (interactive) | |
| 418 | 1232 (let ((buffer (compilation-find-buffer))) |
| 71 | 1233 (if (get-buffer-process buffer) |
| 418 | 1234 (interrupt-process (get-buffer-process buffer)) |
| 1235 (error "The compilation process is not running.")))) | |
| 71 | 1236 |
| 418 | 1237 |
| 1238 ;; Parse any new errors in the compilation buffer, | |
| 1239 ;; or reparse from the beginning if the user has asked for that. | |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1240 (defun compile-reinitialize-errors (reparse |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1241 &optional limit-search find-at-least) |
| 418 | 1242 (save-excursion |
| 1243 (set-buffer compilation-last-buffer) | |
| 1244 ;; If we are out of errors, or if user says "reparse", | |
| 1245 ;; discard the info we have, to force reparsing. | |
| 1246 (if (or (eq compilation-error-list t) | |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1247 reparse) |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1248 (compilation-forget-errors)) |
| 907 | 1249 (if (and compilation-error-list |
| 920 | 1250 (or (not limit-search) |
| 1251 (> compilation-parsing-end limit-search)) | |
| 907 | 1252 (or (not find-at-least) |
|
4757
c21680a58d1e
(compile-internal): Back out jimb change of making buffer read-only. It
Brian Fox <bfox@gnu.org>
parents:
4612
diff
changeset
|
1253 (>= (length compilation-error-list) find-at-least))) |
| 418 | 1254 ;; Since compilation-error-list is non-nil, it points to a specific |
| 1255 ;; error the user wanted. So don't move it around. | |
| 1256 nil | |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1257 ;; This was here for a long time (before my rewrite); why? --roland |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1258 ;;(switch-to-buffer compilation-last-buffer) |
| 71 | 1259 (set-buffer-modified-p nil) |
| 920 | 1260 (if (< compilation-parsing-end (point-max)) |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1261 ;; compilation-error-list might be non-nil if we have a non-nil |
|
6673
137122de77ef
(compile-reinitialize-errors): Fix typo in comment.
Karl Heuer <kwzh@gnu.org>
parents:
6639
diff
changeset
|
1262 ;; LIMIT-SEARCH or FIND-AT-LEAST arg. In that case its value |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1263 ;; records the current position in the error list, and we must |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1264 ;; preserve that after reparsing. |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1265 (let ((error-list-pos compilation-error-list)) |
| 920 | 1266 (funcall compilation-parse-errors-function |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1267 limit-search |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1268 (and find-at-least |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1269 ;; We only need enough new parsed errors to reach |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1270 ;; FIND-AT-LEAST errors past the current |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1271 ;; position. |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1272 (- find-at-least (length compilation-error-list)))) |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1273 ;; Remember the entire list for compilation-forget-errors. If |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1274 ;; this is an incremental parse, append to previous list. If |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1275 ;; we are parsing anew, compilation-forget-errors cleared |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1276 ;; compilation-old-error-list above. |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1277 (setq compilation-old-error-list |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1278 (nconc compilation-old-error-list compilation-error-list)) |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1279 (if error-list-pos |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1280 ;; We started in the middle of an existing list of parsed |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1281 ;; errors before parsing more; restore that position. |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1282 (setq compilation-error-list error-list-pos)) |
|
16519
b96e56680038
(compile-auto-highlight): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
16518
diff
changeset
|
1283 ;; Mouse-Highlight (the first line of) each error message when the |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1284 ;; mouse pointer moves over it: |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1285 (let ((inhibit-read-only t) |
|
24284
c8a762e57cf6
(compilation-setup): Set value of
Richard M. Stallman <rms@gnu.org>
parents:
24264
diff
changeset
|
1286 (buffer-undo-list t) |
|
c8a762e57cf6
(compilation-setup): Set value of
Richard M. Stallman <rms@gnu.org>
parents:
24264
diff
changeset
|
1287 deactivate-mark |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1288 (error-list compilation-error-list)) |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1289 (while error-list |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1290 (save-excursion |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1291 (put-text-property (goto-char (car (car error-list))) |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1292 (progn (end-of-line) (point)) |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1293 'mouse-face 'highlight)) |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1294 (setq error-list (cdr error-list)))) |
| 920 | 1295 ))))) |
| 71 | 1296 |
|
6595
7fbc171fd1b5
(compile-mouse-goto-error): New command.
Richard M. Stallman <rms@gnu.org>
parents:
6412
diff
changeset
|
1297 (defun compile-mouse-goto-error (event) |
|
24108
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1298 "Visit the source for the error message the mouse is pointing at. |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1299 This is like `compile-goto-error' called without prefix arg |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1300 at the end of the line." |
|
6595
7fbc171fd1b5
(compile-mouse-goto-error): New command.
Richard M. Stallman <rms@gnu.org>
parents:
6412
diff
changeset
|
1301 (interactive "e") |
|
6639
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1302 (save-excursion |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1303 (set-buffer (window-buffer (posn-window (event-end event)))) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1304 (goto-char (posn-point (event-end event))) |
|
6595
7fbc171fd1b5
(compile-mouse-goto-error): New command.
Richard M. Stallman <rms@gnu.org>
parents:
6412
diff
changeset
|
1305 |
|
6639
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1306 (or (compilation-buffer-p (current-buffer)) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1307 (error "Not in a compilation buffer.")) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1308 (setq compilation-last-buffer (current-buffer)) |
|
16997
c9f46b04dad0
(compile-mouse-goto-error): Move to end of line
Eli Zaretskii <eliz@gnu.org>
parents:
16985
diff
changeset
|
1309 ;; `compile-reinitialize-errors' needs to see the complete filename |
|
c9f46b04dad0
(compile-mouse-goto-error): Move to end of line
Eli Zaretskii <eliz@gnu.org>
parents:
16985
diff
changeset
|
1310 ;; on the line where they clicked the mouse. Since it only looks |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1311 ;; up to point, moving point to eol makes sure the filename is |
|
16997
c9f46b04dad0
(compile-mouse-goto-error): Move to end of line
Eli Zaretskii <eliz@gnu.org>
parents:
16985
diff
changeset
|
1312 ;; visible to `compile-reinitialize-errors'. |
|
c9f46b04dad0
(compile-mouse-goto-error): Move to end of line
Eli Zaretskii <eliz@gnu.org>
parents:
16985
diff
changeset
|
1313 (end-of-line) |
|
6639
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1314 (compile-reinitialize-errors nil (point)) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1315 |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1316 ;; Move to bol; the marker for the error on this line will point there. |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1317 (beginning-of-line) |
|
6595
7fbc171fd1b5
(compile-mouse-goto-error): New command.
Richard M. Stallman <rms@gnu.org>
parents:
6412
diff
changeset
|
1318 |
|
6639
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1319 ;; Move compilation-error-list to the elt of compilation-old-error-list |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1320 ;; we want. |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1321 (setq compilation-error-list compilation-old-error-list) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1322 (while (and compilation-error-list |
|
24264
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1323 ;; The marker can point nowhere if we previously |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1324 ;; failed to find the relevant file. See |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1325 ;; compilation-next-error-locus. |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1326 (or (null (marker-buffer (caar compilation-error-list))) |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1327 (> (point) (caar compilation-error-list)))) |
|
6639
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1328 (setq compilation-error-list (cdr compilation-error-list))) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1329 (or compilation-error-list |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1330 (error "No error to go to"))) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1331 (select-window (posn-window (event-end event))) |
|
6595
7fbc171fd1b5
(compile-mouse-goto-error): New command.
Richard M. Stallman <rms@gnu.org>
parents:
6412
diff
changeset
|
1332 |
|
6639
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1333 (push-mark) |
|
b7196b4a3679
(compile-mouse-goto-error): Simplify.
Karl Heuer <kwzh@gnu.org>
parents:
6595
diff
changeset
|
1334 (next-error 1)) |
|
6595
7fbc171fd1b5
(compile-mouse-goto-error): New command.
Richard M. Stallman <rms@gnu.org>
parents:
6412
diff
changeset
|
1335 |
| 71 | 1336 (defun compile-goto-error (&optional argp) |
| 1337 "Visit the source for the error message point is on. | |
|
6197
8ddddba0de43
(compile-goto-error): Push the mark before calling next-error.
Roland McGrath <roland@gnu.org>
parents:
5961
diff
changeset
|
1338 Use this command in a compilation log buffer. Sets the mark at point there. |
| 885 | 1339 \\[universal-argument] as a prefix arg means to reparse the buffer's error messages first; |
| 71 | 1340 other kinds of prefix arguments are ignored." |
| 1341 (interactive "P") | |
| 418 | 1342 (or (compilation-buffer-p (current-buffer)) |
| 1343 (error "Not in a compilation buffer.")) | |
| 1344 (setq compilation-last-buffer (current-buffer)) | |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1345 (compile-reinitialize-errors (consp argp) (point)) |
| 894 | 1346 |
| 1072 | 1347 ;; Move to bol; the marker for the error on this line will point there. |
| 1348 (beginning-of-line) | |
| 1349 | |
| 894 | 1350 ;; Move compilation-error-list to the elt of compilation-old-error-list |
| 901 | 1351 ;; we want. |
| 894 | 1352 (setq compilation-error-list compilation-old-error-list) |
| 901 | 1353 (while (and compilation-error-list |
|
24264
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1354 ;; The marker can point nowhere if we previously |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1355 ;; failed to find the relevant file. See |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1356 ;; compilation-next-error-locus. |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1357 (or (null (marker-buffer (caar compilation-error-list))) |
|
ffc2b7069315
(compile-mouse-goto-error): Don't lose with
Dave Love <fx@gnu.org>
parents:
24239
diff
changeset
|
1358 (> (point) (caar compilation-error-list)))) |
| 894 | 1359 (setq compilation-error-list (cdr compilation-error-list))) |
| 1360 | |
|
6197
8ddddba0de43
(compile-goto-error): Push the mark before calling next-error.
Roland McGrath <roland@gnu.org>
parents:
5961
diff
changeset
|
1361 (push-mark) |
| 901 | 1362 (next-error 1)) |
| 71 | 1363 |
| 418 | 1364 ;; Return a compilation buffer. |
| 1365 ;; If the current buffer is a compilation buffer, return it. | |
| 1366 ;; If compilation-last-buffer is set to a live buffer, use that. | |
| 1367 ;; Otherwise, look for a compilation buffer and signal an error | |
| 1368 ;; if there are none. | |
| 621 | 1369 (defun compilation-find-buffer (&optional other-buffer) |
| 1370 (if (and (not other-buffer) | |
| 1371 (compilation-buffer-p (current-buffer))) | |
| 418 | 1372 ;; The current buffer is a compilation buffer. |
| 1373 (current-buffer) | |
| 621 | 1374 (if (and compilation-last-buffer (buffer-name compilation-last-buffer) |
|
14807
db1942b2425e
(compilation-find-buffer): Only choose compilation-last-buffer if it is
Roland McGrath <roland@gnu.org>
parents:
14730
diff
changeset
|
1375 (compilation-buffer-p compilation-last-buffer) |
| 621 | 1376 (or (not other-buffer) (not (eq compilation-last-buffer |
| 1377 (current-buffer))))) | |
| 418 | 1378 compilation-last-buffer |
| 1379 (let ((buffers (buffer-list))) | |
| 621 | 1380 (while (and buffers (or (not (compilation-buffer-p (car buffers))) |
| 1381 (and other-buffer | |
| 1382 (eq (car buffers) (current-buffer))))) | |
| 418 | 1383 (setq buffers (cdr buffers))) |
| 1384 (if buffers | |
| 1385 (car buffers) | |
| 621 | 1386 (or (and other-buffer |
| 1387 (compilation-buffer-p (current-buffer)) | |
| 1388 ;; The current buffer is a compilation buffer. | |
| 1389 (progn | |
| 1390 (if other-buffer | |
| 1391 (message "This is the only compilation buffer.")) | |
| 1392 (current-buffer))) | |
| 1393 (error "No compilation started!"))))))) | |
| 418 | 1394 |
| 1395 ;;;###autoload | |
| 71 | 1396 (defun next-error (&optional argp) |
| 1397 "Visit next compilation error message and corresponding source code. | |
| 22966 | 1398 |
| 1399 If all the error messages parsed so far have been processed already, | |
| 1400 the message buffer is checked for new ones. | |
| 71 | 1401 |
| 1402 A prefix arg specifies how many error messages to move; | |
| 1403 negative means move back to previous error messages. | |
| 1404 Just C-u as a prefix means reparse the error message buffer | |
| 1405 and start at the first error. | |
| 1406 | |
| 22966 | 1407 \\[next-error] normally uses the most recently started compilation or |
| 1408 grep buffer. However, it can operate on any buffer with output from | |
| 1409 the \\[compile] and \\[grep] commands, or, more generally, on any | |
| 1410 buffer in Compilation mode or with Compilation Minor mode enabled. To | |
| 1411 specify use of a particular buffer for error messages, type | |
| 1412 \\[next-error] in that buffer. | |
| 71 | 1413 |
| 22966 | 1414 Once \\[next-error] has chosen the buffer for error messages, |
| 1415 it stays with that buffer until you use it in some other buffer which | |
| 1416 uses Compilation mode or Compilation Minor mode. | |
| 71 | 1417 |
| 418 | 1418 See variables `compilation-parse-errors-function' and |
| 1419 \`compilation-error-regexp-alist' for customization ideas." | |
| 71 | 1420 (interactive "P") |
| 418 | 1421 (setq compilation-last-buffer (compilation-find-buffer)) |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1422 (compilation-goto-locus (compilation-next-error-locus |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1423 ;; We want to pass a number here only if |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1424 ;; we got a numeric prefix arg, not just C-u. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1425 (and (not (consp argp)) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1426 (prefix-numeric-value argp)) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1427 (consp argp)))) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1428 ;;;###autoload (define-key ctl-x-map "`" 'next-error) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1429 |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1430 (defun previous-error () |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1431 "Visit previous compilation error message and corresponding source code. |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1432 This operates on the output from the \\[compile] command." |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1433 (interactive) |
|
11804
7a7da7fca594
(compilation-next-error-locus): Ignore zero column number.
Roland McGrath <roland@gnu.org>
parents:
11791
diff
changeset
|
1434 (next-error -1)) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1435 |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1436 (defun first-error () |
|
16866
3244576af168
compile.el (first-error): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents:
16519
diff
changeset
|
1437 "Reparse the error message buffer and start at the first error. |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1438 Visit corresponding source code. |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1439 This operates on the output from the \\[compile] command." |
|
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1440 (interactive) |
|
11804
7a7da7fca594
(compilation-next-error-locus): Ignore zero column number.
Roland McGrath <roland@gnu.org>
parents:
11791
diff
changeset
|
1441 (next-error '(4))) |
|
8425
8b8835f1630a
Set up a "Compile" menubar item.
Richard M. Stallman <rms@gnu.org>
parents:
8406
diff
changeset
|
1442 |
|
16448
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1443 (defvar compilation-skip-to-next-location nil |
|
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1444 "*If non-nil, skip multiple error messages for the same source location.") |
|
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1445 |
|
8342
95c011057e51
(compilation-next-error-locus): New arg SILENT.
Richard M. Stallman <rms@gnu.org>
parents:
8288
diff
changeset
|
1446 (defun compilation-next-error-locus (&optional move reparse silent) |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1447 "Visit next compilation error and return locus in corresponding source code. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1448 This operates on the output from the \\[compile] command. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1449 If all preparsed error messages have been processed, |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1450 the error message buffer is checked for new ones. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1451 |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1452 Returns a cons (ERROR . SOURCE) of two markers: ERROR is a marker at the |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1453 location of the error message in the compilation buffer, and SOURCE is a |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1454 marker at the location in the source code indicated by the error message. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1455 |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1456 Optional first arg MOVE says how many error messages to move forwards (or |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1457 backwards, if negative); default is 1. Optional second arg REPARSE, if |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1458 non-nil, says to reparse the error message buffer and reset to the first |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
1459 error (plus MOVE - 1). If optional third argument SILENT is non-nil, return |
|
8342
95c011057e51
(compilation-next-error-locus): New arg SILENT.
Richard M. Stallman <rms@gnu.org>
parents:
8288
diff
changeset
|
1460 nil instead of raising an error if there are no more errors. |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1461 |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1462 The current buffer should be the desired compilation output buffer." |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1463 (or move (setq move 1)) |
|
24239
e6c0e87123a7
(compilation-next-error-locus): Don't decrease argument FIND-AT-LEAST
Richard M. Stallman <rms@gnu.org>
parents:
24108
diff
changeset
|
1464 (compile-reinitialize-errors reparse nil (and (not reparse) (max 0 move))) |
| 418 | 1465 (let (next-errors next-error) |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1466 (catch 'no-next-error |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1467 (save-excursion |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1468 (set-buffer compilation-last-buffer) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1469 ;; compilation-error-list points to the "current" error. |
|
13755
5f7ea59f14b6
(compilation-mode): Add autoload cookie.
Roland McGrath <roland@gnu.org>
parents:
13540
diff
changeset
|
1470 (setq next-errors |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1471 (if (> move 0) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1472 (nthcdr (1- move) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1473 compilation-error-list) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1474 ;; Zero or negative arg; we need to move back in the list. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1475 (let ((n (1- move)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1476 (i 0) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1477 (e compilation-old-error-list)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1478 ;; See how many cdrs away the current error is from the start. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1479 (while (not (eq e compilation-error-list)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1480 (setq i (1+ i) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1481 e (cdr e))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1482 (if (> (- n) i) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1483 (error "Moved back past first error") |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1484 (nthcdr (+ i n) compilation-old-error-list)))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1485 next-error (car next-errors)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1486 (while |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1487 (if (null next-error) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1488 (progn |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1489 (and move (/= move 1) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1490 (error (if (> move 0) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1491 "Moved past last error") |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1492 "Moved back past first error")) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1493 ;; Forget existing error messages if compilation has finished. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1494 (if (not (and (get-buffer-process (current-buffer)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1495 (eq (process-status |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1496 (get-buffer-process |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1497 (current-buffer))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1498 'run))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1499 (compilation-forget-errors)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1500 (if silent |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1501 (throw 'no-next-error nil) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1502 (error (concat compilation-error-message |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1503 (and (get-buffer-process (current-buffer)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1504 (eq (process-status |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1505 (get-buffer-process |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1506 (current-buffer))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1507 'run) |
|
8342
95c011057e51
(compilation-next-error-locus): New arg SILENT.
Richard M. Stallman <rms@gnu.org>
parents:
8288
diff
changeset
|
1508 " yet"))))) |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1509 (setq compilation-error-list (cdr next-errors)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1510 (if (null (cdr next-error)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1511 ;; This error is boring. Go to the next. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1512 t |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1513 (or (markerp (cdr next-error)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1514 ;; This error has a filename/lineno pair. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1515 ;; Find the file and turn it into a marker. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1516 (let* ((fileinfo (car (cdr next-error))) |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1517 (buffer (apply 'compilation-find-file |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1518 (car next-error) fileinfo))) |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1519 (if (null buffer) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1520 ;; We can't find this error's file. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1521 ;; Remove all errors in the same file. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1522 (progn |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1523 (setq next-errors compilation-old-error-list) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1524 (while next-errors |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1525 (and (consp (cdr (car next-errors))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1526 (equal (car (cdr (car next-errors))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1527 fileinfo) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1528 (progn |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1529 (set-marker (car (car next-errors)) nil) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1530 (setcdr (car next-errors) nil))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1531 (setq next-errors (cdr next-errors))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1532 ;; Look for the next error. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1533 t) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1534 ;; We found the file. Get a marker for this error. |
|
24894
dcb1db1b1105
Deal with compilation-error-screen-columns being buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
24824
diff
changeset
|
1535 ;; compilation-old-error-list and |
|
dcb1db1b1105
Deal with compilation-error-screen-columns being buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
24824
diff
changeset
|
1536 ;; compilation-error-screen-columns are buffer-local |
|
dcb1db1b1105
Deal with compilation-error-screen-columns being buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
24824
diff
changeset
|
1537 ;; so we must be careful to extract their value |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1538 ;; before switching to the source file buffer. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1539 (let ((errors compilation-old-error-list) |
|
24894
dcb1db1b1105
Deal with compilation-error-screen-columns being buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
24824
diff
changeset
|
1540 (columns compilation-error-screen-columns) |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1541 (last-line (nth 1 (cdr next-error))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1542 (column (nth 2 (cdr next-error)))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1543 (set-buffer buffer) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1544 (save-excursion |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1545 (save-restriction |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1546 (widen) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1547 (goto-line last-line) |
|
11791
34dbef732b27
(compilation-error-regexp-alist): Add regexps for IBM and Cray compilers.
Roland McGrath <roland@gnu.org>
parents:
11618
diff
changeset
|
1548 (if (and column (> column 0)) |
|
10092
b53266f04fd9
(compilation-next-error-locus): Parsed column numbers are 1-origin.
Roland McGrath <roland@gnu.org>
parents:
9888
diff
changeset
|
1549 ;; Columns in error msgs are 1-origin. |
|
24894
dcb1db1b1105
Deal with compilation-error-screen-columns being buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
24824
diff
changeset
|
1550 (if columns |
|
23263
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
1551 (move-to-column (1- column)) |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
1552 (forward-char (1- column))) |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1553 (beginning-of-line)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1554 (setcdr next-error (point-marker)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1555 ;; Make all the other error messages referring |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1556 ;; to the same file have markers into the buffer. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1557 (while errors |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1558 (and (consp (cdr (car errors))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1559 (equal (car (cdr (car errors))) fileinfo) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1560 (let* ((this (nth 1 (cdr (car errors)))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1561 (column (nth 2 (cdr (car errors)))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1562 (lines (- this last-line))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1563 (if (eq selective-display t) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1564 ;; When selective-display is t, |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1565 ;; each C-m is a line boundary, |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1566 ;; as well as each newline. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1567 (if (< lines 0) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1568 (re-search-backward "[\n\C-m]" |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1569 nil 'end |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1570 (- lines)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1571 (re-search-forward "[\n\C-m]" |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1572 nil 'end |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1573 lines)) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1574 (forward-line lines)) |
|
11804
7a7da7fca594
(compilation-next-error-locus): Ignore zero column number.
Roland McGrath <roland@gnu.org>
parents:
11791
diff
changeset
|
1575 (if (and column (> column 1)) |
|
24894
dcb1db1b1105
Deal with compilation-error-screen-columns being buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
24824
diff
changeset
|
1576 (if columns |
|
23263
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
1577 (move-to-column (1- column)) |
|
03626baa368a
(compilation-error-screen-columns): New
Andreas Schwab <schwab@suse.de>
parents:
23228
diff
changeset
|
1578 (forward-char (1- column))) |
|
11804
7a7da7fca594
(compilation-next-error-locus): Ignore zero column number.
Roland McGrath <roland@gnu.org>
parents:
11791
diff
changeset
|
1579 (beginning-of-line)) |
|
8351
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1580 (setq last-line this) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1581 (setcdr (car errors) (point-marker)))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1582 (setq errors (cdr errors))))))))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1583 ;; If we didn't get a marker for this error, or this |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1584 ;; marker's buffer was killed, go on to the next one. |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1585 (or (not (markerp (cdr next-error))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1586 (not (marker-buffer (cdr next-error)))))) |
|
bbd2d410ab94
Finish installing previous change.
Richard M. Stallman <rms@gnu.org>
parents:
8342
diff
changeset
|
1587 (setq next-errors compilation-error-list |
|
8342
95c011057e51
(compilation-next-error-locus): New arg SILENT.
Richard M. Stallman <rms@gnu.org>
parents:
8288
diff
changeset
|
1588 next-error (car next-errors))))) |
| 418 | 1589 |
|
16448
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1590 (if compilation-skip-to-next-location |
|
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1591 ;; Skip over multiple error messages for the same source location, |
|
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1592 ;; so the next C-x ` won't go to an error in the same place. |
|
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1593 (while (and compilation-error-list |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1594 (equal (cdr (car compilation-error-list)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1595 (cdr next-error))) |
|
16448
39556b6d7c6e
(compilation-skip-to-next-location): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
16042
diff
changeset
|
1596 (setq compilation-error-list (cdr compilation-error-list)))) |
| 418 | 1597 |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1598 ;; We now have a marker for the position of the error source code. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1599 ;; NEXT-ERROR is a cons (ERROR . SOURCE) of two markers. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1600 next-error)) |
| 418 | 1601 |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1602 (defun compilation-goto-locus (next-error) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1603 "Jump to an error locus returned by `compilation-next-error-locus'. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1604 Takes one argument, a cons (ERROR . SOURCE) of two markers. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1605 Selects a window with point at SOURCE, with another window displaying ERROR." |
|
24108
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1606 (if (eq (window-buffer (selected-window)) |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1607 (marker-buffer (car next-error))) |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1608 ;; If the compilation buffer window is selected, |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1609 ;; keep the compilation buffer in this window; |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1610 ;; display the source in another window. |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1611 (let ((pop-up-windows t)) |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1612 (pop-to-buffer (marker-buffer (cdr next-error)))) |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1613 (if (and (window-dedicated-p (selected-window)) |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1614 (eq (selected-window) (frame-root-window))) |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1615 (switch-to-buffer-other-frame (marker-buffer (cdr next-error))) |
|
5f499867bc7e
(compilation-goto-locus): If already in the
Richard M. Stallman <rms@gnu.org>
parents:
24053
diff
changeset
|
1616 (switch-to-buffer (marker-buffer (cdr next-error))))) |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1617 (goto-char (cdr next-error)) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1618 ;; If narrowing got in the way of |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1619 ;; going to the right place, widen. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1620 (or (= (point) (marker-position (cdr next-error))) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1621 (progn |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1622 (widen) |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1623 (goto-char (cdr next-error)))) |
| 418 | 1624 |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1625 ;; Show compilation buffer in other window, scrolled to this error. |
|
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1626 (let* ((pop-up-windows t) |
|
11804
7a7da7fca594
(compilation-next-error-locus): Ignore zero column number.
Roland McGrath <roland@gnu.org>
parents:
11791
diff
changeset
|
1627 ;; Use an existing window if it is in a visible frame. |
|
8483
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
1628 (w (or (get-buffer-window (marker-buffer (car next-error)) 'visible) |
|
11804
7a7da7fca594
(compilation-next-error-locus): Ignore zero column number.
Roland McGrath <roland@gnu.org>
parents:
11791
diff
changeset
|
1629 ;; Pop up a window. |
|
8483
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
1630 (display-buffer (marker-buffer (car next-error)))))) |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1631 (set-window-point w (car next-error)) |
|
8483
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
1632 (set-window-start w (car next-error)) |
|
19dbc8373bec
(compilation-set-window-height): New function,
Richard M. Stallman <rms@gnu.org>
parents:
8425
diff
changeset
|
1633 (compilation-set-window-height w))) |
|
6240
5ce2192f76e1
(compile-reinitialize-errors): Rename first arg from ARGP to REPARSE.
Roland McGrath <roland@gnu.org>
parents:
6197
diff
changeset
|
1634 |
| 418 | 1635 ;; Find a buffer for file FILENAME. |
| 1636 ;; Search the directories in compilation-search-path. | |
| 1637 ;; A nil in compilation-search-path means to try the | |
| 1638 ;; current directory, which is passed in DIR. | |
| 1639 ;; If FILENAME is not found at all, ask the user where to find it. | |
| 1640 ;; Pop up the buffer containing MARKER and scroll to MARKER if we ask the user. | |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1641 (defun compilation-find-file (marker filename dir &rest formats) |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1642 (or formats (setq formats '("%s"))) |
| 418 | 1643 (let ((dirs compilation-search-path) |
|
12219
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1644 buffer thisdir fmts name) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1645 (if (file-name-absolute-p filename) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1646 ;; The file name is absolute. Use its explicit directory as |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1647 ;; the first in the search path, and strip it from FILENAME. |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1648 (setq filename (abbreviate-file-name (expand-file-name filename)) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1649 dirs (cons (file-name-directory filename) dirs) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1650 filename (file-name-nondirectory filename))) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1651 ;; Now search the path. |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1652 (while (and dirs (null buffer)) |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1653 (setq thisdir (or (car dirs) dir) |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1654 fmts formats) |
|
12219
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1655 ;; For each directory, try each format string. |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1656 (while (and fmts (null buffer)) |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1657 (setq name (expand-file-name (format (car fmts) filename) thisdir) |
|
12219
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1658 buffer (and (file-exists-p name) |
|
10928
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1659 (find-file-noselect name)) |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1660 fmts (cdr fmts))) |
|
a008a9d8966a
(compilation-buffer-p): Fix braino in last change: switch to the buffer first.
Roland McGrath <roland@gnu.org>
parents:
10842
diff
changeset
|
1661 (setq dirs (cdr dirs))) |
|
12219
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1662 (or buffer |
| 418 | 1663 ;; The file doesn't exist. |
| 1664 ;; Ask the user where to find it. | |
| 1665 ;; If he hits C-g, then the next time he does | |
| 1666 ;; next-error, he'll skip past it. | |
|
12219
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1667 (let* ((pop-up-windows t) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1668 (w (display-buffer (marker-buffer marker)))) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1669 (set-window-point w marker) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1670 (set-window-start w marker) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1671 (let ((name (expand-file-name |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1672 (read-file-name |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1673 (format "Find this error in: (default %s) " |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1674 filename) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1675 dir filename t)))) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1676 (if (file-directory-p name) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1677 (setq name (expand-file-name filename name))) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1678 (and (file-exists-p name) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1679 (find-file-noselect name))))))) |
| 418 | 1680 |
| 1681 ;; Set compilation-error-list to nil, and unchain the markers that point to the | |
| 1682 ;; error messages and their text, so that they no longer slow down gap motion. | |
| 1683 ;; This would happen anyway at the next garbage collection, but it is better to | |
| 894 | 1684 ;; do it right away. |
| 71 | 1685 (defun compilation-forget-errors () |
| 1686 (while compilation-old-error-list | |
| 1687 (let ((next-error (car compilation-old-error-list))) | |
| 1688 (set-marker (car next-error) nil) | |
| 418 | 1689 (if (markerp (cdr next-error)) |
| 1690 (set-marker (cdr next-error) nil))) | |
| 71 | 1691 (setq compilation-old-error-list (cdr compilation-old-error-list))) |
|
1846
19c13118ba0c
(compilation-forget-errors): Just set
Roland McGrath <roland@gnu.org>
parents:
1731
diff
changeset
|
1692 (setq compilation-error-list nil |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1693 compilation-directory-stack (list default-directory)) |
|
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1694 (set-marker compilation-parsing-end 1) |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1695 ;; Remove the highlighting added by compile-reinitialize-errors: |
|
24284
c8a762e57cf6
(compilation-setup): Set value of
Richard M. Stallman <rms@gnu.org>
parents:
24264
diff
changeset
|
1696 (let ((inhibit-read-only t) |
|
c8a762e57cf6
(compilation-setup): Set value of
Richard M. Stallman <rms@gnu.org>
parents:
24264
diff
changeset
|
1697 (buffer-undo-list t) |
|
c8a762e57cf6
(compilation-setup): Set value of
Richard M. Stallman <rms@gnu.org>
parents:
24264
diff
changeset
|
1698 deactivate-mark) |
|
16518
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1699 (remove-text-properties (point-min) (point-max) '(mouse-face highlight))) |
|
851101d4ba84
(compile-highlight-display-limit): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16448
diff
changeset
|
1700 ) |
| 418 | 1701 |
| 1702 | |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1703 ;; This function is not needed any more by compilation mode. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1704 ;; Does anyone else need it or can it be deleted? |
| 418 | 1705 (defun count-regexp-groupings (regexp) |
| 1706 "Return the number of \\( ... \\) groupings in REGEXP (a string)." | |
| 1707 (let ((groupings 0) | |
| 1708 (len (length regexp)) | |
| 1709 (i 0) | |
| 1710 c) | |
| 1711 (while (< i len) | |
| 1712 (setq c (aref regexp i) | |
| 1713 i (1+ i)) | |
| 1714 (cond ((= c ?\[) | |
| 1715 ;; Find the end of this [...]. | |
| 1716 (while (and (< i len) | |
| 1717 (not (= (aref regexp i) ?\]))) | |
| 1718 (setq i (1+ i)))) | |
| 1719 ((= c ?\\) | |
| 1720 (if (< i len) | |
| 1721 (progn | |
| 1722 (setq c (aref regexp i) | |
| 1723 i (1+ i)) | |
| 1724 (if (= c ?\)) | |
| 1725 ;; We found the end of a grouping, | |
| 1726 ;; so bump our counter. | |
| 1727 (setq groupings (1+ groupings)))))))) | |
| 1728 groupings)) | |
| 71 | 1729 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1730 (defvar compilation-current-file nil |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1731 "Used by compilation-parse-errors to store filename for file being compiled") |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1732 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1733 ;; This variable is not used as a global variable. It's defined here just to |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1734 ;; shut up the byte compiler. It's bound and used by compilation-parse-errors |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1735 ;; and set by compile-collect-regexps. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1736 (defvar compilation-regexps nil) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1737 |
| 907 | 1738 (defun compilation-parse-errors (limit-search find-at-least) |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1739 "Parse the current buffer as grep, cc, lint or other error messages. |
| 418 | 1740 See variable `compilation-parse-errors-function' for the interface it uses." |
| 71 | 1741 (setq compilation-error-list nil) |
| 1742 (message "Parsing error messages...") | |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1743 (if (null compilation-error-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1744 (error "compilation-error-regexp-alist is empty!")) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1745 (let* ((compilation-regexps nil) ; Variable set by compile-collect-regexps. |
|
21930
b84bfe98263d
* progmodes/compile.el (compilation-directory-stack): Doc fix.
Andreas Schwab <schwab@suse.de>
parents:
21224
diff
changeset
|
1746 (default-directory (car compilation-directory-stack)) |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1747 (found-desired nil) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1748 (compilation-num-errors-found 0) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1749 ;; Set up now the expanded, abbreviated directory variables |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1750 ;; that compile-abbreviate-directory will need, so we can |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1751 ;; compute them just once here. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1752 (orig (abbreviate-file-name default-directory)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1753 (orig-expanded (abbreviate-file-name |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1754 (file-truename default-directory))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1755 (parent-expanded (abbreviate-file-name |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1756 (expand-file-name "../" orig-expanded)))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1757 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1758 ;; Make a list of all the regexps. Each element has the form |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1759 ;; (REGEXP TYPE IDX1 IDX2 ...) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1760 ;; where TYPE is one of leave, enter, file, error or nomessage. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1761 (compile-collect-regexps 'leave compilation-leave-directory-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1762 (compile-collect-regexps 'enter compilation-enter-directory-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1763 (compile-collect-regexps 'file compilation-file-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1764 (compile-collect-regexps 'nomessage compilation-nomessage-regexp-alist) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1765 (compile-collect-regexps 'error compilation-error-regexp-alist) |
| 418 | 1766 |
| 71 | 1767 ;; Don't reparse messages already seen at last parse. |
| 1768 (goto-char compilation-parsing-end) | |
|
18565
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
1769 (when (and (bobp) |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
1770 (eq major-mode 'compilation-mode)) |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
1771 (setq compilation-current-file nil) ; No current file at start. |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
1772 ;; Don't parse the first two lines as error messages. |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
1773 ;; This matters for grep. |
|
1df558397136
(compilation-parse-errors): Skip 2 lines only for Compilation major mode.
Richard M. Stallman <rms@gnu.org>
parents:
18477
diff
changeset
|
1774 (forward-line 2)) |
| 418 | 1775 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1776 ;; Parse messages. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1777 (while (not (or found-desired (eobp))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1778 (let ((this compilation-regexps) (prev nil) (alist nil) type) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1779 ;; Go through the regular expressions. If a match is found, |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1780 ;; variable alist is set to the corresponding alist and the |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1781 ;; matching regexp is moved to the front of compilation-regexps |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1782 ;; to make it match faster next time. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1783 (while (and this (null alist)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1784 (if (not (looking-at (car (car this)))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1785 (progn (setq prev this) ; No match, go to next. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1786 (setq this (cdr this))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1787 (setq alist (cdr (car this))) ; Got a match. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1788 ;;; (if prev ; If not the first regexp, |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1789 ;;; (progn ; move it to the front. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1790 ;;; (setcdr prev (cdr this)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1791 ;;; (setcdr this compilation-regexps) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1792 ;;; (setq compilation-regexps this))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1793 )) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1794 (if (and alist ; Seen a match and not to |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1795 (not (eq (setq type (car alist)) 'nomessage))) ; be ignored. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1796 (let* ((end-of-match (match-end 0)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1797 (filename |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1798 (compile-buffer-substring (car (setq alist (cdr alist))))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1799 stack) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1800 (if (eq type 'error) ; error message |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1801 (let* ((linenum (if (numberp (car (setq alist (cdr alist)))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1802 (string-to-int |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1803 (compile-buffer-substring (car alist))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1804 ;; (car alist) is not a number, must be a |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1805 ;; function that is called below to return |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1806 ;; an error position descriptor. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1807 (car alist))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1808 ;; Convert to integer later if linenum not a function. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1809 (column (compile-buffer-substring |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1810 (car (setq alist (cdr alist))))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1811 this-error) |
| 935 | 1812 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1813 ;; Check that we have a file name. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1814 (or filename |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1815 ;; No file name in message, we must have seen it before |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1816 (setq filename compilation-current-file) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1817 (error "\ |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1818 An error message with no file name and no file name has been seen earlier.")) |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1819 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1820 ;; Check for a comint-file-name-prefix and prepend it if |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1821 ;; appropriate. (This is very useful for |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1822 ;; compilation-minor-mode in an rlogin-mode buffer.) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1823 (and (boundp 'comint-file-name-prefix) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1824 ;; If file name is relative, default-directory will |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1825 ;; already contain the comint-file-name-prefix (done |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1826 ;; by compile-abbreviate-directory). |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1827 (file-name-absolute-p filename) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1828 (setq filename |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1829 (concat comint-file-name-prefix filename))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1830 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1831 ;; Some compilers (e.g. Sun's java compiler, reportedly) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1832 ;; produce bogus file names like "./bar//foo.c" for file |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1833 ;; "bar/foo.c"; expand-file-name will collapse these into |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1834 ;; "/foo.c" and fail to find the appropriate file. So we |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1835 ;; look for doubled slashes in the file name and fix them |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1836 ;; up in the buffer. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1837 (setq filename (command-line-normalize-file-name filename)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1838 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1839 (setq filename |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1840 (cons filename (cons default-directory (cdr alist)))) |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1841 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1842 ;; Locate the erring file and line. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1843 ;; Make this-error a new elt for compilation-error-list, |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1844 ;; giving a marker for the current compilation buffer |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1845 ;; location, and the file and line number of the error. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1846 ;; Save, as the start of the error, the beginning of the |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1847 ;; line containing the match. |
|
19887
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1848 (setq this-error |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1849 (if (numberp linenum) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1850 (list (point-marker) filename linenum |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1851 (and column (string-to-int column))) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1852 ;; If linenum is not a number then it must be |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1853 ;; a function returning an error position |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1854 ;; descriptor or nil (meaning no position). |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1855 (save-excursion |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1856 (funcall linenum filename column)))) |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1857 |
|
19887
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1858 ;; We have an error position descriptor. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1859 ;; If we have found as many new errors as the user |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1860 ;; wants, or if we are past the buffer position he |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1861 ;; indicated, then we continue to parse until we have |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1862 ;; seen all consecutive errors in the same file. This |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1863 ;; means that all the errors of a source file will be |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1864 ;; seen in one parsing run, so that the error positions |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1865 ;; will be recorded as markers in the source file |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1866 ;; buffer that will move when the buffer is changed. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1867 (if (and this-error |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1868 compilation-error-list ; At least one previous. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1869 (or (and find-at-least |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1870 (>= compilation-num-errors-found |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1871 find-at-least)) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1872 (and limit-search |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1873 (>= end-of-match limit-search))) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1874 (not (equal ; Same filename? |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1875 (car (cdr (car compilation-error-list))) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1876 (car (cdr this-error))))) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1877 ;; We are past the limits and the last error |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1878 ;; parsed, didn't belong to the same source file |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1879 ;; as the earlier ones i.e. we have seen all the |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1880 ;; errors belonging to the earlier file. We don't |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1881 ;; add the error just parsed so that the next |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1882 ;; parsing run can get it and the following errors |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1883 ;; in the same file all at once. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1884 (setq found-desired t) |
|
5605
fcf3556282dc
(compilation-error-regexp-alist): Add regexp for Lucid lcc.
Roland McGrath <roland@gnu.org>
parents:
5475
diff
changeset
|
1885 |
|
19887
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1886 (goto-char end-of-match) ; Prepare for next message. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1887 ;; Don't add the same source line more than once. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1888 (and this-error |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1889 (not (and |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1890 compilation-error-list |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1891 (equal (cdr (car compilation-error-list)) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1892 (cdr this-error)))) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1893 (setq compilation-error-list |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1894 (cons this-error compilation-error-list) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1895 compilation-num-errors-found |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1896 (1+ compilation-num-errors-found))))) |
|
5475
e723f6be6239
(compilation-parse-errors): Prepend comint-file-name-prefix (if boundp) to
Roland McGrath <roland@gnu.org>
parents:
5472
diff
changeset
|
1897 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1898 ;; Not an error message. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1899 (if (eq type `file) ; Change current file. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1900 (and filename (setq compilation-current-file filename)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1901 ;; Enter or leave directory. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1902 (setq stack compilation-directory-stack) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1903 (and filename |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1904 (file-directory-p |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1905 (setq filename |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1906 ;; The directory name in the message |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1907 ;; is a truename. Try to convert it to a form |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1908 ;; like what the user typed in. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1909 (compile-abbreviate-directory |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1910 (file-name-as-directory |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1911 (expand-file-name filename)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1912 orig orig-expanded parent-expanded))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1913 (if (eq type 'leave) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1914 (while (and stack |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1915 (not (string-equal (car stack) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1916 filename))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1917 (setq stack (cdr stack))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1918 (setq compilation-directory-stack |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1919 (cons filename compilation-directory-stack) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1920 default-directory filename))) |
|
17866
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
1921 (and (eq type 'leave) |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
1922 stack |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
1923 (setq compilation-directory-stack (cdr stack)) |
|
7d458582345c
(compilation-parse-errors): Fix paren error.
Richard M. Stallman <rms@gnu.org>
parents:
17653
diff
changeset
|
1924 (setq stack (car compilation-directory-stack)) |
|
19887
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1925 (setq default-directory stack))) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1926 (goto-char end-of-match) ; Prepare to look at next message. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1927 (and limit-search (>= end-of-match limit-search) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1928 ;; The user wanted a specific error, and we're past it. |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1929 ;; We do this check here rather than at the end of the |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1930 ;; loop because if the last thing seen is an error |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1931 ;; message, we must carefully discard the last error |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1932 ;; when it is the first in a new file (see above in |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1933 ;; the error-message case) |
|
ff933683a5c5
(compilation-parse-errors): Fixed two bugs that
Richard M. Stallman <rms@gnu.org>
parents:
19766
diff
changeset
|
1934 (setq found-desired t))) |
| 935 | 1935 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1936 ;; Go to before the last character in the message so that we will |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1937 ;; see the next line also when the message ended at end of line. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1938 ;; When we ignore the last error message above, this will |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1939 ;; cancel the effect of forward-line below so that point |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1940 ;; doesn't move. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1941 (forward-char -1) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1942 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1943 ;; Is this message necessary any more? Parsing is now so fast |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1944 ;; that you might not need to know how it proceeds. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1945 (message |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1946 "Parsing error messages...%d found. %.0f%% of buffer seen." |
| 1133 | 1947 compilation-num-errors-found |
|
5472
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1948 ;; Use floating-point because (* 100 (point)) frequently |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1949 ;; exceeds the range of Emacs Lisp integers. |
|
ed690a728e13
(compilation-buffer-p): Move defsubst before all callers.
Roland McGrath <roland@gnu.org>
parents:
5456
diff
changeset
|
1950 (/ (* 100.0 (point)) (point-max))) |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1951 )) |
| 935 | 1952 |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1953 (forward-line 1))) ; End of while loop. Look at next line. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1954 |
|
25426
a08bfd064439
(compilation-parsing-end,compilation-setup)
Richard M. Stallman <rms@gnu.org>
parents:
24894
diff
changeset
|
1955 (set-marker compilation-parsing-end (point)) |
|
17623
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1956 (setq compilation-error-list (nreverse compilation-error-list)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1957 ;;; (message "Parsing error messages...done. %d found. %.0f%% of buffer seen." |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1958 ;;; compilation-num-errors-found |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1959 ;;; (/ (* 100.0 (point)) (point-max))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1960 (message "Parsing error messages...done."))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1961 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1962 (defun compile-collect-regexps (type this) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1963 ;; Add elements to variable compilation-regexps that is bound in |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1964 ;; compilation-parse-errors. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1965 (and (not (eq this t)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1966 (while this |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1967 (setq compilation-regexps |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1968 (cons (cons (car (car this)) (cons type (cdr (car this)))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1969 compilation-regexps)) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1970 (setq this (cdr this))))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1971 |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1972 (defun compile-buffer-substring (index) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1973 ;; Get substring matched by INDEXth subexpression. |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1974 (if index |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1975 (let ((beg (match-beginning index))) |
|
a09fd9348b0d
Support compilers that give a message each time the file being
Richard M. Stallman <rms@gnu.org>
parents:
17582
diff
changeset
|
1976 (if beg (buffer-substring beg (match-end index)))))) |
| 71 | 1977 |
|
3940
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1978 ;; If directory DIR is a subdir of ORIG or of ORIG's parent, |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1979 ;; return a relative name for it starting from ORIG or its parent. |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1980 ;; ORIG-EXPANDED is an expanded version of ORIG. |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1981 ;; PARENT-EXPANDED is an expanded version of ORIG's parent. |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1982 ;; Those two args could be computed here, but we run faster by |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1983 ;; having the caller compute them just once. |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1984 (defun compile-abbreviate-directory (dir orig orig-expanded parent-expanded) |
|
12219
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1985 ;; Apply canonical abbreviations to DIR first thing. |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1986 ;; Those abbreviations are already done in the other arguments passed. |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1987 (setq dir (abbreviate-file-name dir)) |
|
7c0b93d3df6b
(compilation-find-file): If FILENAME is absolute, apply
Roland McGrath <roland@gnu.org>
parents:
12029
diff
changeset
|
1988 |
|
5475
e723f6be6239
(compilation-parse-errors): Prepend comint-file-name-prefix (if boundp) to
Roland McGrath <roland@gnu.org>
parents:
5472
diff
changeset
|
1989 ;; Check for a comint-file-name-prefix and prepend it if appropriate. |
|
e723f6be6239
(compilation-parse-errors): Prepend comint-file-name-prefix (if boundp) to
Roland McGrath <roland@gnu.org>
parents:
5472
diff
changeset
|
1990 ;; (This is very useful for compilation-minor-mode in an rlogin-mode |
|
e723f6be6239
(compilation-parse-errors): Prepend comint-file-name-prefix (if boundp) to
Roland McGrath <roland@gnu.org>
parents:
5472
diff
changeset
|
1991 ;; buffer.) |
|
e723f6be6239
(compilation-parse-errors): Prepend comint-file-name-prefix (if boundp) to
Roland McGrath <roland@gnu.org>
parents:
5472
diff
changeset
|
1992 (if (boundp 'comint-file-name-prefix) |
|
e723f6be6239
(compilation-parse-errors): Prepend comint-file-name-prefix (if boundp) to
Roland McGrath <roland@gnu.org>
parents:
5472
diff
changeset
|
1993 (setq dir (concat comint-file-name-prefix dir))) |
|
e723f6be6239
(compilation-parse-errors): Prepend comint-file-name-prefix (if boundp) to
Roland McGrath <roland@gnu.org>
parents:
5472
diff
changeset
|
1994 |
|
3940
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1995 (if (and (> (length dir) (length orig-expanded)) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1996 (string= orig-expanded |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1997 (substring dir 0 (length orig-expanded)))) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1998 (setq dir |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
1999 (concat orig |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2000 (substring dir (length orig-expanded))))) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2001 (if (and (> (length dir) (length parent-expanded)) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2002 (string= parent-expanded |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2003 (substring dir 0 (length parent-expanded)))) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2004 (setq dir |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2005 (concat (file-name-directory |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2006 (directory-file-name orig)) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2007 (substring dir (length parent-expanded))))) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2008 dir) |
|
aa9f37730d77
(compile-abbreviate-directory): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3875
diff
changeset
|
2009 |
| 621 | 2010 (provide 'compile) |
|
712
16823e891d56
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
621
diff
changeset
|
2011 |
|
16823e891d56
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
621
diff
changeset
|
2012 ;;; compile.el ends here |
