annotate lisp/progmodes/fortran.el @ 63308:51d38cfbe542

Warn about using "cvs up -kb" if one intends to commit changes. Add a pointer to another site with detailed configure and build instructions. Suggest to look at config.log when configure fails. Add MinGW Make 3.80 to the list of successful combinations.
author Eli Zaretskii <eliz@gnu.org>
date Sat, 11 Jun 2005 11:31:29 +0000
parents f2892faa87d4
children 18a818a2ee7c 01137c1fdbe9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
1 ;;; fortran.el --- Fortran mode for GNU Emacs
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
2
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
3 ;; Copyright (C) 1986, 1993, 1994, 1995, 1997, 1998, 1999, 2000, 2001,
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
4 ;; 2003, 2004, 2005 Free Software Foundation, Inc.
845
213978acbc1e entered into RCS
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 811
diff changeset
5
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
6 ;; Author: Michael D. Prange <prange@erl.mit.edu>
45345
1f3817058799 Update maintainer.
Glenn Morris <rgm@gnu.org>
parents: 45301
diff changeset
7 ;; Maintainer: Glenn Morris <gmorris@ast.cam.ac.uk>
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
8 ;; Keywords: fortran, languages
660
08eb386dd0f3 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
9
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
10 ;; This file is part of GNU Emacs.
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
11
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
12 ;; GNU Emacs is free software; you can redistribute it and/or modify
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
13 ;; it under the terms of the GNU General Public License as published by
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
14 ;; the Free Software Foundation; either version 2, or (at your option)
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
15 ;; any later version.
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
16
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
17 ;; GNU Emacs is distributed in the hope that it will be useful,
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
20 ;; GNU General Public License for more details.
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
21
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
22 ;; You should have received a copy of the GNU General Public License
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13300
diff changeset
23 ;; along with GNU Emacs; see the file COPYING. If not, write to the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13300
diff changeset
24 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13300
diff changeset
25 ;; Boston, MA 02111-1307, USA.
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
26
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
27 ;;; Commentary:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
28
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
29 ;; This mode is documented in the Emacs manual.
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
30 ;;
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
31 ;; Note that it is for editing Fortran77 or Fortran90 fixed source
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
32 ;; form. For editing Fortran 90 free format source, use `f90-mode'
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
33 ;; (f90.el). It is meant to support the GNU Fortran language
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
34 ;; implemented by g77 (its extensions to Fortran77 and
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
35 ;; interpretations, e.g. of blackslash in strings).
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
36
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
37 ;;; History:
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
38
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
39 ;; Fortran mode was upgraded by Stephen A. Wood (saw@cebaf.gov).
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
40
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
41 ;; We acknowledge many contributions and valuable suggestions by
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
42 ;; Lawrence R. Dodd, Ralf Fassel, Ralph Finch, Stephen Gildea,
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
43 ;; Dr. Anil Gokhale, Ulrich Mueller, Mark Neale, Eric Prestemon,
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
44 ;; Gary Sabot and Richard Stallman.
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
45
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13300
diff changeset
46 ;;; Code:
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
47
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
48 ;; Todo:
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
49
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
50 ;; * Tidy it all up (more)!
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
51 ;; * Implement insertion and removal of statement continuations in
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
52 ;; mixed f77/f90 style, with the first `&' past column 72 and the
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
53 ;; second in column 6.
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
54 ;; * Support any other extensions to f77 grokked by GNU Fortran I've missed.
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
55
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
56 (eval-when-compile ; silence compiler
50648
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
57 (defvar dabbrev-case-fold-search)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
58 (defvar imenu-case-fold-search)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
59 (defvar imenu-syntax-alist))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
60
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
61
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
62 (defgroup fortran nil
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
63 "Major mode for editing fixed format Fortran code."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
64 :link '(custom-manual "(emacs)Fortran")
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
65 :group 'languages)
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
66
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
67 (defgroup fortran-indent nil
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
68 "Indentation variables in Fortran mode."
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
69 :prefix "fortran-"
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
70 :group 'fortran)
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
71
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
72 (defgroup fortran-comment nil
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
73 "Comment-handling variables in Fortran mode."
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
74 :prefix "fortran-"
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
75 :group 'fortran)
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
76
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
77
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
78 ;;;###autoload
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
79 (defcustom fortran-tab-mode-default nil
1485
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
80 "*Default tabbing/carriage control style for empty files in Fortran mode.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
81 A non-nil value specifies tab-digit style of continuation control.
1485
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
82 A value of nil specifies that continuation lines are marked
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
83 with a character in column 6."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
84 :type 'boolean
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
85 :group 'fortran-indent)
1485
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
86
50600
418cea060d92 (fortran-tab-mode-minor-mode-string): Delete this variable,
Glenn Morris <rgm@gnu.org>
parents: 50598
diff changeset
87 (defcustom fortran-tab-mode-string "/t"
418cea060d92 (fortran-tab-mode-minor-mode-string): Delete this variable,
Glenn Morris <rgm@gnu.org>
parents: 50598
diff changeset
88 "*String to appear in mode line in TAB format buffers."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
89 :type 'string
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
90 :group 'fortran-indent)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
91
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
92 (defcustom fortran-do-indent 3
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
93 "*Extra indentation applied to DO blocks."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
94 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
95 :group 'fortran-indent)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
96
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
97 (defcustom fortran-if-indent 3
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
98 "*Extra indentation applied to IF, SELECT CASE and WHERE blocks."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
99 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
100 :group 'fortran-indent)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
101
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
102 (defcustom fortran-structure-indent 3
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
103 "*Extra indentation applied to STRUCTURE, UNION, MAP and INTERFACE blocks."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
104 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
105 :group 'fortran-indent)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
106
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
107 (defcustom fortran-continuation-indent 5
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
108 "*Extra indentation applied to continuation lines."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
109 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
110 :group 'fortran-indent)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
111
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
112 (defcustom fortran-comment-indent-style 'fixed
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
113 "*How to indent comments.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
114 nil forces comment lines not to be touched;
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
115 `fixed' indents to `fortran-comment-line-extra-indent' columns beyond
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
116 `fortran-minimum-statement-indent-fixed' (if `indent-tabs-mode' nil), or
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
117 `fortran-minimum-statement-indent-tab' (if `indent-tabs-mode' non-nil);
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
118 `relative' indents to current Fortran indentation plus
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
119 `fortran-comment-line-extra-indent'."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
120 :type '(radio (const :tag "Untouched" nil) (const fixed) (const relative))
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
121 :group 'fortran-indent)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
122
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
123 (defcustom fortran-comment-line-extra-indent 0
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
124 "*Amount of extra indentation for text within full-line comments."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
125 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
126 :group 'fortran-indent
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
127 :group 'fortran-comment)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
128
28079
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
129 (defcustom fortran-comment-line-start "C"
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
130 "*Delimiter inserted to start new full-line comment.
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
131 You might want to change this to \"*\", for instance."
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
132 :version "21.1"
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
133 :type 'string
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
134 :group 'fortran-comment)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
135
28079
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
136 ;; This used to match preprocessor lines too, but that messes up
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
137 ;; filling and doesn't seem to be necessary.
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
138 (defcustom fortran-comment-line-start-skip
33947
7ade0d187b77 (fortran-mode): Don't set
Dave Love <fx@gnu.org>
parents: 31847
diff changeset
139 "^[CcDd*!]\\(\\([^ \t\n]\\)\\2+\\)?[ \t]*"
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
140 "*Regexp to match the start of a full-line comment."
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
141 :version "21.1"
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
142 :type 'regexp
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
143 :group 'fortran-comment)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
144
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
145 (defcustom fortran-directive-re
45242
52d991be0698 (fortran-preprocessor-re): New variable. Use it for font-locking.
Glenn Morris <rgm@gnu.org>
parents: 45067
diff changeset
146 "^[ \t]*#.*"
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
147 "*Regexp to match a directive line.
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
148 The matching text will be fontified with `font-lock-keyword-face'.
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
149 The matching line will be given zero indentation."
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59244
diff changeset
150 :version "22.1"
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
151 :type 'regexp
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
152 :group 'fortran-indent)
45242
52d991be0698 (fortran-preprocessor-re): New variable. Use it for font-locking.
Glenn Morris <rgm@gnu.org>
parents: 45067
diff changeset
153
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
154 (defcustom fortran-minimum-statement-indent-fixed 6
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
155 "*Minimum statement indentation for fixed format continuation style."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
156 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
157 :group 'fortran-indent)
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
158
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
159 (defcustom fortran-minimum-statement-indent-tab (max tab-width 6)
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
160 "*Minimum statement indentation for TAB format continuation style."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
161 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
162 :group 'fortran-indent)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
163
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
164 ;; Note that this is documented in the v18 manuals as being a string
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
165 ;; of length one rather than a single character.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
166 ;; The code in this file accepts either format for compatibility.
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
167 (defcustom fortran-comment-indent-char " "
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
168 "*Single-character string inserted for Fortran comment indentation.
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
169 Normally a space."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
170 :type 'string
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
171 :group 'fortran-comment)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
172
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
173 (defcustom fortran-line-number-indent 1
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
174 "*Maximum indentation for Fortran line numbers.
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
175 5 means right-justify them within their five-column field."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
176 :type 'integer
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
177 :group 'fortran-indent)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
178
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
179 (defcustom fortran-check-all-num-for-matching-do nil
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
180 "*Non-nil causes all numbered lines to be treated as possible DO loop ends."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
181 :type 'boolean
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
182 :group 'fortran)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
183
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
184 (defcustom fortran-blink-matching-if nil
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
185 "*Non-nil causes \\[fortran-indent-line] on ENDIF to blink on matching IF.
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
186 Also, from an ENDDO statement blink on matching DO [WHILE] statement."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
187 :type 'boolean
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
188 :group 'fortran)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
189
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
190 (defcustom fortran-continuation-string "$"
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
191 "*Single-character string used for Fortran continuation lines.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
192 In fixed format continuation style, this character is inserted in
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
193 column 6 by \\[fortran-split-line] to begin a continuation line.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
194 Also, if \\[fortran-indent-line] finds this at the beginning of a
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
195 line, it will convert the line into a continuation line of the
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
196 appropriate style. Normally $."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
197 :type 'string
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
198 :group 'fortran)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
199
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
200 (defcustom fortran-comment-region "c$$$"
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
201 "*String inserted by \\[fortran-comment-region] at start of each \
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
202 line in region."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
203 :type 'string
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
204 :group 'fortran-comment)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
205
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
206 (defcustom fortran-electric-line-number t
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
207 "*Non-nil causes line numbers to be moved to the correct column as typed."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
208 :type 'boolean
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
209 :group 'fortran)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
210
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
211 (defcustom fortran-column-ruler-fixed
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
212 "0 4 6 10 20 30 40 5\
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
213 0 60 70\n\
11516
e7c26522b881 Use new fortran-match-!-comment to do !-style fontification; do rest in regexps
Simon Marshall <simon@gnu.org>
parents: 10883
diff changeset
214 \[ ]|{ | | | | | | | | \
e7c26522b881 Use new fortran-match-!-comment to do !-style fontification; do rest in regexps
Simon Marshall <simon@gnu.org>
parents: 10883
diff changeset
215 \| | | | |}\n"
21079
65ac561ad75c (fortran-column-ruler-fixed,
Dave Love <fx@gnu.org>
parents: 20953
diff changeset
216 "String displayed above current line by \\[fortran-column-ruler].
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
217 This variable is used in fixed format mode.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
218 See the variable `fortran-column-ruler-tab' for TAB format mode."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
219 :type 'string
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
220 :group 'fortran)
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
221
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
222 (defcustom fortran-column-ruler-tab
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
223 "0 810 20 30 40 5\
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
224 0 60 70\n\
11516
e7c26522b881 Use new fortran-match-!-comment to do !-style fontification; do rest in regexps
Simon Marshall <simon@gnu.org>
parents: 10883
diff changeset
225 \[ ]| { | | | | | | | | \
e7c26522b881 Use new fortran-match-!-comment to do !-style fontification; do rest in regexps
Simon Marshall <simon@gnu.org>
parents: 10883
diff changeset
226 \| | | | |}\n"
21079
65ac561ad75c (fortran-column-ruler-fixed,
Dave Love <fx@gnu.org>
parents: 20953
diff changeset
227 "String displayed above current line by \\[fortran-column-ruler].
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
228 This variable is used in TAB format mode.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
229 See the variable `fortran-column-ruler-fixed' for fixed format mode."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
230 :type 'string
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
231 :group 'fortran)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
232
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
233 (defcustom fortran-analyze-depth 100
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
234 "Number of lines to scan to identify fixed or TAB format style."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
235 :type 'integer
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
236 :group 'fortran)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
237
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
238 (defcustom fortran-break-before-delimiters t
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
239 "*Non-nil causes filling to break lines before delimiters.
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
240 Delimiters are characters matching the regexp `fortran-break-delimiters-re'."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
241 :type 'boolean
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
242 :group 'fortran)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
243
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
244 (defconst fortran-break-delimiters-re "[-+*/><=, \t]"
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
245 "Regexp matching delimiter characters at which lines may be broken.
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
246 There are certain tokens comprised entirely of characters
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
247 matching this regexp that should not be split, and these are
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
248 specified by the constant `fortran-no-break-re'.")
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
249
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
250 ;; The ">=", etc F77 extensions are supported by g77.
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
251 (defconst fortran-no-break-re
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
252 (regexp-opt '("**" "//" "=>" ">=" "<=" "==" "/=") 'paren)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
253 "Regexp specifying where not to break lines when filling.
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
254 This regexp matches certain tokens comprised entirely of
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
255 characters matching the regexp `fortran-break-delimiters-re' that should
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
256 not be split by filling. Each element is assumed to be two
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
257 characters long.")
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
258
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
259 (defcustom fortran-mode-hook nil
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
260 "Hook run when entering Fortran mode."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
261 :type 'hook
17413
9fa0ed8da0b1 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16581
diff changeset
262 :group 'fortran)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
263
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
264
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
265 (defvar fortran-if-start-re "\\(\\(\\sw\\|\\s_\\)+:[ \t]*\\)?if[ \t]*("
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
266 "Regexp matching the start of an IF statement.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
267
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
268 (defvar fortran-end-prog-re1
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
269 "end\
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
270 \\([ \t]*\\(program\\|subroutine\\|function\\|block[ \t]*data\\)\\>\
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
271 \\([ \t]*\\(\\sw\\|\\s_\\)+\\)?\\)?"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
272 "Regexp possibly matching the end of a subprogram.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
273
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
274 (defvar fortran-end-prog-re
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
275 (concat "^[ \t0-9]*" fortran-end-prog-re1)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
276 "Regexp possibly matching the end of a subprogram, from the line start.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
277 See also `fortran-end-prog-re1'.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
278
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
279 (defconst fortran-type-types
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
280 (concat "\\<"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
281 (mapconcat 'identity ; " " -> "[ \t]*"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
282 (split-string
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
283 (regexp-opt
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
284 (let ((simple-types
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
285 '("character" "byte" "integer" "logical"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
286 "none" "real" "complex"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
287 "double precision" "double complex"))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
288 (structured-types '("structure" "union" "map"))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
289 (other-types '("record" "dimension"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
290 "parameter" "common" "save"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
291 "external" "intrinsic" "data"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
292 "equivalence")))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
293 (append
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
294 (mapcar (lambda (x) (concat "implicit " x))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
295 simple-types)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
296 simple-types
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
297 (mapcar (lambda (x) (concat "end " x))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
298 structured-types)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
299 structured-types
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
300 other-types)) 'paren))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
301 "[ \t]*") "\\>")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
302 "Regexp matching Fortran types.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
303
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
304 (defvar fortran-font-lock-keywords-1
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
305 ;; Program, subroutine and function declarations, plus calls.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
306 '(("\\<\\(block[ \t]*data\\|call\\|entry\\|function\\|\
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
307 program\\|subroutine\\)\\>[ \t]*\\(\\sw+\\)?"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
308 (1 font-lock-keyword-face)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
309 (2 font-lock-function-name-face nil t)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
310 "Subdued level highlighting for Fortran mode.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
311
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
312 (defvar fortran-font-lock-keywords-2
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
313 (append fortran-font-lock-keywords-1
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
314 (list
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
315 ;; Fontify all type specifiers (must be first - see below).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
316 (cons fortran-type-types 'font-lock-type-face)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
317 ;; Builtin keywords (except logical, do and goto - see below).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
318 (concat "\\<" (regexp-opt
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
319 '("continue" "format" "end" "enddo"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
320 "if" "then" "else" "endif" "elseif"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
321 "while" "inquire" "stop" "return"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
322 "include" "open" "close" "read"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
323 "write" "format" "print" "select" "case"
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
324 "cycle" "exit" "rewind" "backspace"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
325 "where" "elsewhere")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
326 'paren) "\\>")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
327 ;; Builtin operators.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
328 (concat "\\." (regexp-opt
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
329 '("and" "or" "not" "lt" "le" "eq" "ge"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
330 "gt" "ne" "true" "false")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
331 'paren) "\\.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
332 ;; do/goto keywords and targets, and goto tags.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
333 '("\\<\\(do\\|go *to\\)\\>[ \t]*\\([0-9]+\\)?"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
334 (1 font-lock-keyword-face)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
335 (2 font-lock-constant-face nil t))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
336 '("^ *\\([0-9]+\\)" . font-lock-constant-face)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
337 "Medium level highlighting for Fortran mode.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
338
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
339 (defvar fortran-font-lock-keywords-3
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
340 (append
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
341 fortran-font-lock-keywords-1
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
342 ;; All type specifiers plus their declared items.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
343 (list
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
344 (list (concat fortran-type-types "[ \t(/]*\\(*\\)?")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
345 ;; Type specifier.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
346 '(1 font-lock-type-face)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
347 ;; Declaration item (or just /.../ block name).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
348 `(font-lock-match-c-style-declaration-item-and-skip-to-next
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
349 ;; Start after any *(...) expression.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
350 (condition-case nil
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
351 (and (match-beginning ,(1+ (regexp-opt-depth
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
352 fortran-type-types)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
353 (forward-sexp)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
354 (forward-sexp))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
355 (error nil))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
356 ;; No need to clean up.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
357 nil
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
358 ;; Fontify as a variable name, functions fontified elsewhere.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
359 (1 font-lock-variable-name-face nil t))))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
360 ;; Things extra to `fortran-font-lock-keywords-3' (must be done first).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
361 (list
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
362 ;; Goto-like `err=label'/`end=label' in read/write statements.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
363 '(", *\\(e\\(nd\\|rr\\)\\)\\> *\\(= *\\([0-9]+\\)\\)?"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
364 (1 font-lock-keyword-face) (4 font-lock-constant-face nil t))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
365 ;; Standard continuation character and in a TAB-formatted line.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
366 '("^ \\{5\\}\\([^ 0\n]\\)" 1 font-lock-string-face)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
367 '("^\t\\([1-9]\\)" 1 font-lock-string-face))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
368 `((,fortran-directive-re (0 font-lock-keyword-face t)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
369 ;; `fortran-font-lock-keywords-2' without types (see above).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
370 (cdr (nthcdr (length fortran-font-lock-keywords-1)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
371 fortran-font-lock-keywords-2)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
372 "Gaudy level highlighting for Fortran mode.")
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
373
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
374 (defvar fortran-font-lock-keywords-4
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
375 (append fortran-font-lock-keywords-3
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
376 (list (list
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
377 (concat "\\<"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
378 (regexp-opt
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
379 '("int" "ifix" "idint" "real" "float" "sngl"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
380 "dble" "cmplx" "ichar" "char" "aint" "dint"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
381 "anint" "dnint" "nint" "idnint" "iabs" "abs"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
382 "dabs" "cabs" "mod" "amod" "dmod" "isign"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
383 "sign" "dsign" "idim" "dim" "ddim" "dprod"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
384 "max" "max0" "amax1" "dmax1" "amax0" "max1"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
385 "min0" "amin1" "dmin1" "amin0" "min1" "len"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
386 "index" "lge" "lgt" "lle" "llt" "aimag"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
387 "conjg" "sqrt" "dsqrt" "csqrt" "exp" "dexp"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
388 "cexp" "log" "alog" "dlog" "clog" "log10"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
389 "alog10" "dlog10" "sin" "dsin" "csin" "cos"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
390 "dcos" "ccos" "tan" "dtan" "asin" "dasin"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
391 "acos" "dacos" "atan" "datan" "atan2" "datan2"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
392 "sinh" "dsinh" "cosh" "dcosh" "tanh" "dtanh")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
393 'paren) "[ \t]*(") '(1 font-lock-builtin-face))))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
394 "Maximum highlighting for Fortran mode.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
395 Consists of level 3 plus all other intrinsics not already highlighted.")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
396
25054
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
397 ;; Comments are real pain in Fortran because there is no way to
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
398 ;; represent the standard comment syntax in an Emacs syntax table.
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
399 ;; (We can do so for F90-style). Therefore an unmatched quote in a
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
400 ;; standard comment will throw fontification off on the wrong track.
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
401 ;; So we do syntactic fontification with regexps.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
402 (defvar fortran-font-lock-syntactic-keywords
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
403 '(("^[cd\\*]" 0 (11))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
404 ("^[^cd\\*\t\n].\\{71\\}\\([^\n]+\\)" 1 (11)))
25054
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
405 "`font-lock-syntactic-keywords' for Fortran.
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
406 These get fixed-format comments fontified.")
23616
17ebfb12712f Fix for fontification of strings lost
Dave Love <fx@gnu.org>
parents: 23607
diff changeset
407
12386
ceccff3df349 Specify all Font Lock keywords in font-lock-defaults.
Simon Marshall <simon@gnu.org>
parents: 11801
diff changeset
408 (defvar fortran-font-lock-keywords fortran-font-lock-keywords-1
ceccff3df349 Specify all Font Lock keywords in font-lock-defaults.
Simon Marshall <simon@gnu.org>
parents: 11801
diff changeset
409 "Default expressions to highlight in Fortran mode.")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
410
20205
cdaddfc03fe8 (fortran-imenu-generic-expression): New variable.
Dave Love <fx@gnu.org>
parents: 17413
diff changeset
411 (defvar fortran-imenu-generic-expression
20277
b7f5af6127d5 (fortran-imenu-generic-expression): Match
Dave Love <fx@gnu.org>
parents: 20207
diff changeset
412 ;; These patterns could be confused by sequence nos. in cols 72+ and
b7f5af6127d5 (fortran-imenu-generic-expression): Match
Dave Love <fx@gnu.org>
parents: 20207
diff changeset
413 ;; don't allow continuations everywhere.
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
414 (list
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
415 (list
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
416 nil
30186
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
417 ;; [This will be fooled by `end function' allowed by G77. Also,
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
418 ;; it assumes sensible whitespace is employed.]
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
419 (concat
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
420 ;; leading whitespace:
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
421 "^\\s-+\\("
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
422 ;; function declaration with optional type, e.g. `real',
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
423 ;; `real*4', character(*), `double precision':
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
424 "\\(\\sw\\|\\s-\\|[*()+]\\)*"
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
425 "\\<function\\|subroutine\\|entry\\|block\\s-*data\\|program\\)"
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
426 ;; Possible statement continuation:
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
427 "[ \t" fortran-continuation-string "]+"
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
428 ;; Variable to index:
835820e0df08 (fortran-imenu-generic-expression): Change definition layout.
Dave Love <fx@gnu.org>
parents: 30149
diff changeset
429 "\\(\\sw+\\)")
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
430 3)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
431 ;; Un-named block data.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
432 '(nil "^\\s-+\\(block\\s-*data\\)\\s-*$" 1))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
433 "Value for `imenu-generic-expression' in Fortran mode.")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
434
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
435
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
436 ;; Hideshow support.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
437 (defconst fortran-blocks-re
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
438 (concat "block[ \t]*data\\|select[ \t]*case\\|"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
439 (regexp-opt '("do" "if" "interface" "function" "map" "program"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
440 "structure" "subroutine" "union" "where")))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
441 "Regexp potentially indicating the start or end of a Fortran \"block\".
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
442 Omits naked END statements, and DO-loops closed by anything other
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
443 than ENDDO.")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
444
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
445 (defconst fortran-end-block-re
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
446 ;; Do-loops terminated by things other than ENDDO cannot be handled
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
447 ;; with a regexp. This omission does not seem to matter to hideshow...
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
448 (concat "^[ \t0-9]*\\<end[ \t]*\\("
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
449 fortran-blocks-re
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
450 ;; Naked END statement.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
451 "\\|!\\|$\\)")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
452 "Regexp matching the end of a Fortran \"block\", from the line start.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
453 Note that only ENDDO is handled for the end of a DO-loop. Used
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
454 in the Fortran entry in `hs-special-modes-alist'.")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
455
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
456 (defconst fortran-start-block-re
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
457 (concat
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
458 "^[ \t0-9]*\\(" ; statement number
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
459 ;; Structure label for DO, IF, SELECT, WHERE.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
460 "\\(\\(\\sw+[ \t]*:[ \t]*\\)?"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
461 ;; IF blocks are a nuisance:
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
462 ;; IF ( ... ) foo is not a block, but a single statement.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
463 ;; IF ( ... ) THEN can be split over multiple lines.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
464 ;; [So can, eg, a DO WHILE (... ), but that is less common, I hope.]
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
465 ;; The regexp below allows for it to be split over at most 2 lines.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
466 ;; That leads to the problem of not matching two consecutive IF
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
467 ;; statements as one, eg:
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
468 ;; IF ( ... ) foo
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
469 ;; IF ( ... ) THEN
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
470 ;; It simply is not possible to do this in a 100% correct fashion
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
471 ;; using a regexp - see the functions fortran-end-if,
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
472 ;; fortran-beginning-if for the hoops we have to go through.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
473 ;; An alternative is to match on THEN at a line end, eg:
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
474 ;; ".*)[ \t]*then[ \t]*\\($\\|!\\)"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
475 ;; This would also match ELSE branches, though. This does not seem
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
476 ;; right to me, because then one has neighbouring blocks that are
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
477 ;; not nested in each other.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
478 "\\(if[ \t]*(\\(.*\\|"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
479 ".*\n\\([^if]*\\([^i].\\|.[^f]\\|.\\>\\)\\)\\)\\<then\\|"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
480 "do\\|select[ \t]*case\\|where\\)\\)\\|"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
481 (regexp-opt '("interface" "function" "map" "program"
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
482 "structure" "subroutine" "union"))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
483 "\\|block[ \t]*data\\)[ \t]*")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
484 "Regexp matching the start of a Fortran \"block\", from the line start.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
485 A simple regexp cannot do this in fully correct fashion, so this
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
486 tries to strike a compromise between complexity and flexibility.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
487 Used in the Fortran entry in `hs-special-modes-alist'.")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
488
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
489 (add-to-list 'hs-special-modes-alist
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
490 `(fortran-mode ,fortran-start-block-re ,fortran-end-block-re
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
491 "^[cC*!]" fortran-end-of-block nil))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
492
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
493
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
494 (defvar fortran-mode-syntax-table
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
495 (let ((table (make-syntax-table)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
496 ;; We might like `;' to be punctuation (g77 multi-statement
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
497 ;; lines), but that screws abbrevs.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
498 (modify-syntax-entry ?\; "w" table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
499 (modify-syntax-entry ?\r " " table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
500 (modify-syntax-entry ?+ "." table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
501 (modify-syntax-entry ?- "." table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
502 (modify-syntax-entry ?= "." table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
503 (modify-syntax-entry ?* "." table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
504 (modify-syntax-entry ?/ "." table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
505 (modify-syntax-entry ?\' "\"" table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
506 (modify-syntax-entry ?\" "\"" table)
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
507 ;; Consistent with GNU Fortran's default -- see the manual.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
508 ;; The F77 standard imposes no rule on this issue.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
509 (modify-syntax-entry ?\\ "\\" table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
510 ;; This might be better as punctuation, as for C, but this way you
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
511 ;; can treat floating-point numbers as symbols.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
512 (modify-syntax-entry ?. "_" table) ; e.g. `a.ne.b'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
513 (modify-syntax-entry ?_ "_" table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
514 (modify-syntax-entry ?$ "_" table) ; esp. VMSisms
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
515 (modify-syntax-entry ?\! "<" table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
516 (modify-syntax-entry ?\n ">" table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
517 table)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
518 "Syntax table used in Fortran mode.")
13300
73b7a6396cbe Fix to fortran-font-lock-keywords-* for new font-lock-keywords structure.
Simon Marshall <simon@gnu.org>
parents: 12814
diff changeset
519
51615
64bebb34e646 (fortran-gud-syntax-table): Syntax table
Nick Roberts <nickrob@snap.net.nz>
parents: 50648
diff changeset
520 (defvar fortran-gud-syntax-table
64bebb34e646 (fortran-gud-syntax-table): Syntax table
Nick Roberts <nickrob@snap.net.nz>
parents: 50648
diff changeset
521 (let ((st (make-syntax-table fortran-mode-syntax-table)))
64bebb34e646 (fortran-gud-syntax-table): Syntax table
Nick Roberts <nickrob@snap.net.nz>
parents: 50648
diff changeset
522 (modify-syntax-entry ?\n "." st)
64bebb34e646 (fortran-gud-syntax-table): Syntax table
Nick Roberts <nickrob@snap.net.nz>
parents: 50648
diff changeset
523 st)
64bebb34e646 (fortran-gud-syntax-table): Syntax table
Nick Roberts <nickrob@snap.net.nz>
parents: 50648
diff changeset
524 "Syntax table used to parse Fortran expressions for printing in GUD.")
64bebb34e646 (fortran-gud-syntax-table): Syntax table
Nick Roberts <nickrob@snap.net.nz>
parents: 50648
diff changeset
525
27199
4a15e79c5fb0 (fortran-mode-map): Don't bind M-C-a,
Dave Love <fx@gnu.org>
parents: 26665
diff changeset
526 (defvar fortran-mode-map
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
527 (let ((map (make-sparse-keymap)))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
528 (define-key map ";" 'fortran-abbrev-start)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
529 (define-key map "\C-c;" 'fortran-comment-region)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
530 (define-key map "\M-;" 'fortran-indent-comment)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
531 (define-key map "\M-\n" 'fortran-split-line)
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
532 (define-key map "\M-\C-n" 'fortran-end-of-block)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
533 (define-key map "\M-\C-p" 'fortran-beginning-of-block)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
534 (define-key map "\M-\C-q" 'fortran-indent-subprogram)
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
535 (define-key map "\C-c\C-w" 'fortran-window-create-momentarily)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
536 (define-key map "\C-c\C-r" 'fortran-column-ruler)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
537 (define-key map "\C-c\C-p" 'fortran-previous-statement)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
538 (define-key map "\C-c\C-n" 'fortran-next-statement)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
539 (define-key map "\C-c\C-d" 'fortran-join-line) ; like f90
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
540 (define-key map "\M-^" 'fortran-join-line) ; subvert delete-indentation
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
541 (define-key map "0" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
542 (define-key map "1" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
543 (define-key map "2" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
544 (define-key map "3" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
545 (define-key map "4" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
546 (define-key map "5" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
547 (define-key map "6" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
548 (define-key map "7" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
549 (define-key map "8" 'fortran-electric-line-number)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
550 (define-key map "9" 'fortran-electric-line-number)
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
551
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
552 (easy-menu-define fortran-menu map "Menu for Fortran mode."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
553 `("Fortran"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
554 ["Manual" (info "(emacs)Fortran")]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
555 ("Customization"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
556 ,(custom-menu-create 'fortran)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
557 ["Set" Custom-set t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
558 ["Save" Custom-save t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
559 ["Reset to Current" Custom-reset-current t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
560 ["Reset to Saved" Custom-reset-saved t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
561 ["Reset to Standard Settings" Custom-reset-standard t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
562 )
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
563 "--"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
564 ["Comment Region" fortran-comment-region mark-active]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
565 ["Uncomment Region"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
566 (fortran-comment-region (region-beginning) (region-end) 1)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
567 mark-active]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
568 ["Indent Region" indent-region mark-active]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
569 ["Indent Subprogram" fortran-indent-subprogram t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
570 "--"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
571 ["Beginning of Subprogram" fortran-beginning-of-subprogram t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
572 ["End of Subprogram" fortran-end-of-subprogram t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
573 ("Mark"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
574 ["Subprogram" mark-defun t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
575 ["IF Block" fortran-mark-if t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
576 ["DO Block" fortran-mark-do t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
577 )
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
578 ["Narrow to Subprogram" narrow-to-defun t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
579 ["Widen" widen t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
580 "--"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
581 ["Temporary column ruler" fortran-column-ruler t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
582 ["72-column window" fortran-window-create t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
583 ["Full Width Window"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
584 (enlarge-window-horizontally (- (frame-width) (window-width)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
585 (< (window-width) (frame-width))]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
586 ["Momentary 72-column window" fortran-window-create-momentarily t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
587 "--"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
588 ["Break Line at Point" fortran-split-line t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
589 ["Join Line" fortran-join-line t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
590 ["Fill Statement/Comment" fill-paragraph t]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
591 "--"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
592 ["Toggle auto-fill" auto-fill-mode :selected auto-fill-function
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
593 :style toggle]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
594 ["Toggle abbrev-mode" abbrev-mode :selected abbrev-mode
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
595 :style toggle]
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
596 ["Add imenu Menu" imenu-add-menubar-index
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
597 :active (not (lookup-key (current-local-map) [menu-bar index]))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
598 :included (fboundp 'imenu-add-to-menubar)]))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
599 map)
27199
4a15e79c5fb0 (fortran-mode-map): Don't bind M-C-a,
Dave Love <fx@gnu.org>
parents: 26665
diff changeset
600 "Keymap used in Fortran mode.")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
601
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
602
27199
4a15e79c5fb0 (fortran-mode-map): Don't bind M-C-a,
Dave Love <fx@gnu.org>
parents: 26665
diff changeset
603 (defvar fortran-mode-abbrev-table
48815
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
604 (let (abbrevs-changed)
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
605 (define-abbrev-table 'fortran-mode-abbrev-table nil)
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
606 ;; Use the 6th arg (SYSTEM-FLAG) of define-abbrev if possible.
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
607 ;; Only use `apply' to quieten the byte-compiler.
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
608 (mapcar
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
609 (function (lambda (element)
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
610 (condition-case nil
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
611 (apply 'define-abbrev fortran-mode-abbrev-table
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
612 (append element '(nil 0 t)))
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
613 (wrong-number-of-arguments
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
614 (apply 'define-abbrev fortran-mode-abbrev-table
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
615 (append element '(nil 0)))))))
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
616 '((";au" "automatic" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
617 (";b" "byte" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
618 (";bd" "block data" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
619 (";ch" "character" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
620 (";cl" "close" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
621 (";c" "continue" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
622 (";cm" "common" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
623 (";cx" "complex" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
624 (";df" "define" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
625 (";di" "dimension" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
626 (";do" "double" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
627 (";dc" "double complex" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
628 (";dp" "double precision" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
629 (";dw" "do while" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
630 (";e" "else" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
631 (";ed" "enddo" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
632 (";el" "elseif" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
633 (";en" "endif" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
634 (";eq" "equivalence" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
635 (";ew" "endwhere" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
636 (";ex" "external" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
637 (";ey" "entry" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
638 (";f" "format" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
639 (";fa" ".false." )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
640 (";fu" "function" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
641 (";g" "goto" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
642 (";im" "implicit" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
643 (";ib" "implicit byte" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
644 (";ic" "implicit complex" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
645 (";ich" "implicit character")
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
646 (";ii" "implicit integer" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
647 (";il" "implicit logical" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
648 (";ir" "implicit real" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
649 (";inc" "include" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
650 (";in" "integer" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
651 (";intr" "intrinsic" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
652 (";l" "logical" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
653 (";n" "namelist" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
654 (";o" "open" ) ; was ;op
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
655 (";pa" "parameter" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
656 (";pr" "program" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
657 (";ps" "pause" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
658 (";p" "print" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
659 (";rc" "record" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
660 (";re" "real" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
661 (";r" "read" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
662 (";rt" "return" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
663 (";rw" "rewind" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
664 (";s" "stop" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
665 (";sa" "save" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
666 (";st" "structure" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
667 (";sc" "static" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
668 (";su" "subroutine" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
669 (";tr" ".true." )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
670 (";ty" "type" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
671 (";vo" "volatile" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
672 (";w" "write" )
4d051ad4475f (fortran-mode-abbrev-table): Handle `define-abbrev' with either 5
Glenn Morris <rgm@gnu.org>
parents: 47767
diff changeset
673 (";wh" "where" )))
27199
4a15e79c5fb0 (fortran-mode-map): Don't bind M-C-a,
Dave Love <fx@gnu.org>
parents: 26665
diff changeset
674 fortran-mode-abbrev-table))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
675
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
676
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
677
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
678 ;;;###autoload
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
679 (defun fortran-mode ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
680 "Major mode for editing Fortran code in fixed format.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
681 For free format code, use `f90-mode'.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
682
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
683 \\[fortran-indent-line] indents the current Fortran line correctly.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
684 Note that DO statements must not share a common CONTINUE.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
685
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
686 Type ;? or ;\\[help-command] to display a list of built-in abbrevs for\
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
687 Fortran keywords.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
688
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
689 Key definitions:
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
690 \\{fortran-mode-map}
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
691
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
692 Variables controlling indentation style and extra features:
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
693
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
694 `fortran-comment-line-start'
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
695 To use comments starting with `!', set this to the string \"!\".
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
696 `fortran-do-indent'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
697 Extra indentation within DO blocks (default 3).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
698 `fortran-if-indent'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
699 Extra indentation within IF blocks (default 3).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
700 `fortran-structure-indent'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
701 Extra indentation within STRUCTURE, UNION, MAP and INTERFACE blocks.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
702 (default 3)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
703 `fortran-continuation-indent'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
704 Extra indentation applied to continuation statements (default 5).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
705 `fortran-comment-line-extra-indent'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
706 Amount of extra indentation for text in full-line comments (default 0).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
707 `fortran-comment-indent-style'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
708 How to indent the text in full-line comments. Allowed values are:
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
709 nil don't change the indentation
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
710 fixed indent to `fortran-comment-line-extra-indent' beyond the
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
711 value of either
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
712 `fortran-minimum-statement-indent-fixed' (fixed format) or
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
713 `fortran-minimum-statement-indent-tab' (TAB format),
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
714 depending on the continuation format in use.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
715 relative indent to `fortran-comment-line-extra-indent' beyond the
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
716 indentation for a line of code.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
717 (default 'fixed)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
718 `fortran-comment-indent-char'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
719 Single-character string to be inserted instead of space for
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
720 full-line comment indentation (default \" \").
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
721 `fortran-minimum-statement-indent-fixed'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
722 Minimum indentation for statements in fixed format mode (default 6).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
723 `fortran-minimum-statement-indent-tab'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
724 Minimum indentation for statements in TAB format mode (default 9).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
725 `fortran-line-number-indent'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
726 Maximum indentation for line numbers (default 1). A line number will
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
727 get less than this much indentation if necessary to avoid reaching
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
728 column 5.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
729 `fortran-check-all-num-for-matching-do'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
730 Non-nil causes all numbered lines to be treated as possible \"continue\"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
731 statements (default nil).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
732 `fortran-blink-matching-if'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
733 Non-nil causes \\[fortran-indent-line] on an ENDIF (or ENDDO) statement
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
734 to blink on the matching IF (or DO [WHILE]). (default nil)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
735 `fortran-continuation-string'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
736 Single-character string to be inserted in column 5 of a continuation
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
737 line (default \"$\").
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
738 `fortran-comment-region'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
739 String inserted by \\[fortran-comment-region] at start of each line in
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
740 the region (default \"c$$$\").
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
741 `fortran-electric-line-number'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
742 Non-nil causes line number digits to be moved to the correct column
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
743 as typed (default t).
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
744 `fortran-break-before-delimiters'
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
745 Non-nil causes lines to be broken before delimiters (default t).
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
746
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
747 Turning on Fortran mode calls the value of the variable `fortran-mode-hook'
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
748 with no args, if that value is non-nil."
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
749 (interactive)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
750 (kill-all-local-variables)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
751 (setq major-mode 'fortran-mode
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
752 mode-name "Fortran"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
753 local-abbrev-table fortran-mode-abbrev-table)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
754 (set-syntax-table fortran-mode-syntax-table)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
755 (use-local-map fortran-mode-map)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
756 (set (make-local-variable 'indent-line-function) 'fortran-indent-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
757 (set (make-local-variable 'indent-region-function)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
758 (lambda (start end)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
759 (let (fortran-blink-matching-if ; avoid blinking delay
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
760 indent-region-function)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
761 (indent-region start end nil))))
59244
9d627ac86f8b (fortran-mode): Use mode-require-final-newline.
Richard M. Stallman <rms@gnu.org>
parents: 55251
diff changeset
762 (set (make-local-variable 'require-final-newline) mode-require-final-newline)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
763 ;; The syntax tables don't understand the column-0 comment-markers.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
764 (set (make-local-variable 'comment-use-syntax) nil)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
765 (set (make-local-variable 'comment-padding) "$$$")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
766 (set (make-local-variable 'comment-start) fortran-comment-line-start)
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
767 (set (make-local-variable 'comment-start-skip)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
768 ;; We can't reuse `fortran-comment-line-start-skip' directly because
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
769 ;; it contains backrefs whereas we need submatch-1 to end at the
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
770 ;; beginning of the comment delimiter.
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
771 ;; (concat "\\(\\)\\(![ \t]*\\|" fortran-comment-line-start-skip "\\)")
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
772 "\\(\\)\\(?:^[CcDd*]\\|!\\)\\(?:\\([^ \t\n]\\)\\2+\\)?[ \t]*")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
773 (set (make-local-variable 'comment-indent-function) 'fortran-comment-indent)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
774 (set (make-local-variable 'abbrev-all-caps) t)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
775 (set (make-local-variable 'normal-auto-fill-function) 'fortran-auto-fill)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
776 (set (make-local-variable 'indent-tabs-mode) (fortran-analyze-file-format))
50600
418cea060d92 (fortran-tab-mode-minor-mode-string): Delete this variable,
Glenn Morris <rgm@gnu.org>
parents: 50598
diff changeset
777 (setq mode-line-process '(indent-tabs-mode fortran-tab-mode-string))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
778 (set (make-local-variable 'fill-column) 72)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
779 (set (make-local-variable 'fill-paragraph-function) 'fortran-fill-paragraph)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
780 (set (make-local-variable 'font-lock-defaults)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
781 '((fortran-font-lock-keywords
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
782 fortran-font-lock-keywords-1
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
783 fortran-font-lock-keywords-2
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
784 fortran-font-lock-keywords-3
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
785 fortran-font-lock-keywords-4)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
786 nil t ((?/ . "$/") ("_$" . "w"))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
787 fortran-beginning-of-subprogram))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
788 (set (make-local-variable 'font-lock-syntactic-keywords)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
789 fortran-font-lock-syntactic-keywords)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
790 (set (make-local-variable 'imenu-case-fold-search) t)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
791 (set (make-local-variable 'imenu-generic-expression)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
792 fortran-imenu-generic-expression)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
793 (set (make-local-variable 'imenu-syntax-alist) '(("_$" . "w")))
27417
0d4776018e39 (fortran-mode): Use beginning-of-defun-function, end-of-defun-function.
Dave Love <fx@gnu.org>
parents: 27199
diff changeset
794 (set (make-local-variable 'beginning-of-defun-function)
0d4776018e39 (fortran-mode): Use beginning-of-defun-function, end-of-defun-function.
Dave Love <fx@gnu.org>
parents: 27199
diff changeset
795 #'fortran-beginning-of-subprogram)
0d4776018e39 (fortran-mode): Use beginning-of-defun-function, end-of-defun-function.
Dave Love <fx@gnu.org>
parents: 27199
diff changeset
796 (set (make-local-variable 'end-of-defun-function)
0d4776018e39 (fortran-mode): Use beginning-of-defun-function, end-of-defun-function.
Dave Love <fx@gnu.org>
parents: 27199
diff changeset
797 #'fortran-end-of-subprogram)
28079
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
798 (set (make-local-variable 'add-log-current-defun-function)
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
799 #'fortran-current-defun)
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
800 (set (make-local-variable 'dabbrev-case-fold-search) 'case-fold-search)
51618
6a5cb63d165c (fortran-gud-find-expr): Move from gud.el (was gud-find-fortran-expr).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51615
diff changeset
801 (set (make-local-variable 'gud-find-expr-function) 'fortran-gud-find-expr)
62772
f2892faa87d4 * progmodes/ada-mode.el (ada-mode):
Lute Kamstra <lute@gnu.org>
parents: 61107
diff changeset
802 (run-mode-hooks 'fortran-mode-hook))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
803
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
804
51618
6a5cb63d165c (fortran-gud-find-expr): Move from gud.el (was gud-find-fortran-expr).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51615
diff changeset
805 (defun fortran-gud-find-expr ()
6a5cb63d165c (fortran-gud-find-expr): Move from gud.el (was gud-find-fortran-expr).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51615
diff changeset
806 ;; Consider \n as punctuation (end of expression).
6a5cb63d165c (fortran-gud-find-expr): Move from gud.el (was gud-find-fortran-expr).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51615
diff changeset
807 (with-syntax-table fortran-gud-syntax-table
6a5cb63d165c (fortran-gud-find-expr): Move from gud.el (was gud-find-fortran-expr).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51615
diff changeset
808 (gud-find-c-expr)))
6a5cb63d165c (fortran-gud-find-expr): Move from gud.el (was gud-find-fortran-expr).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51615
diff changeset
809
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
810 (defsubst fortran-comment-indent ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
811 "Return the indentation appropriate for the current comment line.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
812 This is 0 for a line matching `fortran-comment-line-start-skip', else
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
813 the value of `comment-column' (leaving at least one space after code)."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
814 (if (looking-at fortran-comment-line-start-skip) 0
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
815 (save-excursion
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
816 (skip-chars-backward " \t")
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
817 (max (1+ (current-column)) comment-column))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
818
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
819 (defun fortran-indent-comment ()
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
820 "Align or create comment on current line.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
821 Existing comments of all types are recognized and aligned.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
822 If the line has no comment, a side-by-side comment is inserted and aligned,
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
823 if the value of `comment-start' is not nil and allows such comments.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
824 Otherwise, a separate-line comment is inserted, on this line
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
825 or on a new line inserted before this line if this line is not blank."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
826 (interactive "*")
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
827 (beginning-of-line)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
828 ;; Recognize existing comments of either kind.
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
829 (cond ((fortran-find-comment-start-skip 'all)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
830 (goto-char (match-beginning 0))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
831 (if (bolp)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
832 (fortran-indent-line)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
833 (unless (= (current-column) (fortran-comment-indent))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
834 (delete-horizontal-space)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
835 (indent-to (fortran-comment-indent)))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
836 ;; No existing comment.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
837 ;; If side-by-side comments are defined, insert one,
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
838 ;; unless line is now blank.
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
839 ((and comment-start (not (looking-at "[ \t]*$"))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
840 (string-match comment-start-skip (concat " " comment-start)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
841 (end-of-line)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
842 (delete-horizontal-space)
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
843 (indent-to (fortran-comment-indent))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
844 (insert comment-start))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
845 ;; Else insert separate-line comment, making a new line if nec.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
846 (t
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
847 (if (looking-at "^[ \t]*$")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
848 (delete-horizontal-space)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
849 (beginning-of-line)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
850 (insert ?\n)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
851 (forward-char -1))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
852 (insert fortran-comment-line-start)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
853 (insert-char (if (stringp fortran-comment-indent-char)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
854 (aref fortran-comment-indent-char 0)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
855 fortran-comment-indent-char)
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
856 (- (fortran-calculate-indent) (current-column))))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
857
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
858 (defun fortran-comment-region (beg-region end-region arg)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
859 "Comment every line in the region.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
860 Inserts the string variable `fortran-comment-region' at the beginning of
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
861 every line in the region.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
862 BEG-REGION and END-REGION specify the region boundaries.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
863 With non-nil ARG, uncomments the region."
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
864 (interactive "*r\nP")
37080
00fb79924260 (fortran-comment-region): Fix typo.
Dave Love <fx@gnu.org>
parents: 36171
diff changeset
865 (let ((end-region-mark (copy-marker end-region))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
866 (save-point (point-marker)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
867 (goto-char beg-region)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
868 (beginning-of-line)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
869 (if arg
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
870 (let ((com (regexp-quote fortran-comment-region))) ; uncomment
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
871 (if (looking-at com)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
872 (delete-region (point) (match-end 0)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
873 (while (and (zerop (forward-line 1))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
874 (< (point) end-region-mark))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
875 (if (looking-at com)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
876 (delete-region (point) (match-end 0)))))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
877 (insert fortran-comment-region) ; comment
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
878 (while (and (zerop (forward-line 1))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
879 (< (point) end-region-mark))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
880 (insert fortran-comment-region)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
881 (goto-char save-point)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
882 (set-marker end-region-mark nil)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
883 (set-marker save-point nil)))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
884
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
885
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
886 (defun fortran-abbrev-start ()
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
887 "Typing ;\\[help-command] or ;? lists all the Fortran abbrevs.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
888 Any other key combination is executed normally."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
889 (interactive "*")
50648
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
890 (insert last-command-char)
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
891 (let (char event)
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
892 (if (fboundp 'next-command-event) ; XEmacs
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
893 (setq event (next-command-event)
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
894 char (event-to-character event))
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
895 (setq event (read-event)
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
896 char event))
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
897 ;; Insert char if not equal to `?', or if abbrev-mode is off.
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
898 (if (and abbrev-mode (or (eq char ??) (eq char help-char)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
899 (fortran-abbrev-help)
50648
5b37299dac0a (dabbrev-case-fold-search): Add defvar for compiler.
Glenn Morris <rgm@gnu.org>
parents: 50611
diff changeset
900 (setq unread-command-events (list event)))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
901
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
902 (defun fortran-abbrev-help ()
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
903 "List the currently defined abbrevs in Fortran mode."
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
904 (interactive)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
905 (message "Listing abbrev table...")
1485
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
906 (display-buffer (fortran-prepare-abbrev-list-buffer))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
907 (message "Listing abbrev table...done"))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
908
1485
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
909 (defun fortran-prepare-abbrev-list-buffer ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
910 "Create a buffer listing the Fortran mode abbreviations."
1485
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
911 (save-excursion
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
912 (set-buffer (get-buffer-create "*Abbrevs*"))
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
913 (erase-buffer)
1862
f6a38dd2250b * fortran.el (fortran-prepare-abbrev-list-buffer): Put quote in
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
914 (insert-abbrev-table-description 'fortran-mode-abbrev-table t)
1485
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
915 (goto-char (point-min))
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
916 (set-buffer-modified-p nil)
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
917 (edit-abbrevs-mode))
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
918 (get-buffer-create "*Abbrevs*"))
a6da00e1c5ad (fortran-tab-mode): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 1475
diff changeset
919
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
920 (defun fortran-column-ruler ()
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
921 "Insert a column ruler momentarily above current line, till next keystroke.
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
922 The ruler is defined by the value of `fortran-column-ruler-fixed' in fixed
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
923 format mode, and `fortran-column-ruler-tab' in TAB format mode.
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
924 The next key typed is executed unless it is SPC."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
925 (interactive)
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
926 (momentary-string-display
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
927 (if indent-tabs-mode
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
928 fortran-column-ruler-tab
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
929 fortran-column-ruler-fixed)
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
930 (save-excursion
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
931 (beginning-of-line)
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
932 (if (eq (window-start (selected-window))
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
933 (window-point (selected-window)))
27199
4a15e79c5fb0 (fortran-mode-map): Don't bind M-C-a,
Dave Love <fx@gnu.org>
parents: 26665
diff changeset
934 (line-beginning-position 2)
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
935 (point)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
936 nil "Type SPC or any command to erase ruler."))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
937
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
938 (defun fortran-window-create ()
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
939 "Make the window 72 columns wide.
1475
2596132752ff Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 845
diff changeset
940 See also `fortran-window-create-momentarily'."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
941 (interactive)
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
942 (let ((window-min-width 2))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
943 (if (< (window-width) (frame-width))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
944 (enlarge-window-horizontally (- (frame-width)
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
945 (window-width) 1)))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
946 (let* ((window-edges (window-edges))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
947 (scroll-bar-width (- (nth 2 window-edges)
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
948 (car window-edges)
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
949 (window-width))))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
950 (split-window-horizontally (+ 72 scroll-bar-width)))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
951 (other-window 1)
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
952 (switch-to-buffer " fortran-window-extra" t)
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
953 (select-window (previous-window))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
954
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
955 (defun fortran-window-create-momentarily (&optional arg)
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
956 "Momentarily make the window 72 columns wide.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
957 Optional ARG non-nil and non-unity disables the momentary feature.
1475
2596132752ff Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 845
diff changeset
958 See also `fortran-window-create'."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
959 (interactive "p")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
960 (if (or (not arg)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
961 (= arg 1))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
962 (save-window-excursion
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
963 (progn
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
964 (condition-case nil
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
965 (fortran-window-create)
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
966 (error (error "No room for Fortran window")))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
967 (message "Type SPC to continue editing.")
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
968 (let ((char (read-event)))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
969 (or (equal char (string-to-char " "))
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
970 (setq unread-command-events (list char))))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
971 (fortran-window-create)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
972
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
973 (defun fortran-split-line ()
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
974 "Break line at point and insert continuation marker and alignment."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
975 (interactive "*")
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
976 (delete-horizontal-space)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
977 (if (save-excursion
43883
b13e662ea2b3 (fortran-split-line): Make it work with any `!' comment as well.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43882
diff changeset
978 (let ((pos (point)))
b13e662ea2b3 (fortran-split-line): Make it work with any `!' comment as well.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43882
diff changeset
979 (beginning-of-line)
b13e662ea2b3 (fortran-split-line): Make it work with any `!' comment as well.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43882
diff changeset
980 (and (fortran-find-comment-start-skip 'all)
b13e662ea2b3 (fortran-split-line): Make it work with any `!' comment as well.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43882
diff changeset
981 (< (match-beginning 0) pos))))
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
982 (insert ?\n (match-string 0))
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
983 (if indent-tabs-mode
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
984 (insert ?\n ?\t (fortran-numerical-continuation-char))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
985 (insert "\n " fortran-continuation-string))) ; space after \n important
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
986 (fortran-indent-line)) ; when cont string is C, c or *
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
987
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
988 (defun fortran-remove-continuation ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
989 "Delete any Fortran continuation characters at point.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
990 Returns t if anything actually deleted."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
991 (when (looking-at "\\( \\{5\\}[^ 0\n]\\|\t[1-9]\\|&\\)")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
992 (replace-match "")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
993 (delete-indentation)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
994 t))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
995
23463
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
996 (defun fortran-join-line (arg)
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
997 "Join current line to the previous one and re-indent.
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
998 With a prefix argument, repeat this operation that many times.
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
999 If the prefix argument ARG is negative, join the next -ARG lines.
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1000 Continuation lines are correctly handled."
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1001 (interactive "*p")
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1002 (save-excursion
23463
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1003 (when (> 0 arg)
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1004 (setq arg (- arg))
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1005 (forward-line arg))
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1006 (while (not (zerop arg))
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1007 (beginning-of-line)
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1008 (or (fortran-remove-continuation)
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1009 (delete-indentation))
ac51d834b81e 1998-10-14 Dave Love <fx@gnu.org>
Dave Love <fx@gnu.org>
parents: 23335
diff changeset
1010 (setq arg (1- arg)))
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1011 (fortran-indent-line)))
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1012
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1013 (defun fortran-numerical-continuation-char ()
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1014 "Return a digit for tab-digit style of continuation lines.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1015 If previous line is a tab-digit continuation line, return that digit
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1016 plus one, otherwise return 1. Zero not allowed."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1017 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1018 (forward-line -1)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1019 (if (looking-at "\t[1-9]")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1020 (+ ?1 (% (- (char-after (1+ (point))) ?0) 9))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1021 ?1)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1022
22377
24999a02843d (fortran-electric-line-number): Add delete-selection property.
Richard M. Stallman <rms@gnu.org>
parents: 21804
diff changeset
1023 (put 'fortran-electric-line-number 'delete-selection t)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1024 (defun fortran-electric-line-number (arg)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1025 "Self insert, but if part of a Fortran line number indent it automatically.
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1026 Auto-indent does not happen if a numeric ARG is used."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1027 (interactive "*P")
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1028 (if (or arg (not fortran-electric-line-number))
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
1029 (if arg
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1030 (self-insert-command (prefix-numeric-value arg))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1031 (self-insert-command 1))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1032 (if (or (and (= 5 (current-column))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1033 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1034 (beginning-of-line)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1035 ;; In col 5 with only spaces to the left.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1036 (looking-at " \\{5\\}")))
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1037 (and (= (if indent-tabs-mode
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1038 fortran-minimum-statement-indent-tab
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1039 fortran-minimum-statement-indent-fixed) (current-column))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1040 ;; In col 8 with a single tab to the left.
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59244
diff changeset
1041 (eq ?\t (char-after (line-beginning-position)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1042 (not (or (eq last-command 'fortran-indent-line)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1043 (eq last-command
3567
2ca5f216e445 (fortran-indent-new-line): Renamed from
Richard M. Stallman <rms@gnu.org>
parents: 3400
diff changeset
1044 'fortran-indent-new-line))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1045 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1046 (re-search-backward "[^ \t0-9]"
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1047 (line-beginning-position)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1048 t)) ; not a line number
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1049 (looking-at "[0-9]")) ; within a line number
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1050 (self-insert-command (prefix-numeric-value arg))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1051 (skip-chars-backward " \t")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1052 (insert last-command-char)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1053 (fortran-indent-line))))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1054
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1055
23711
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1056 (defun fortran-check-end-prog-re ()
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1057 "Check a preliminary match against `fortran-end-prog-re'."
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1058 ;; Having got a possible match for the subprogram end, we need a
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1059 ;; match of whitespace, avoiding possible column 73+ stuff.
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1060 (save-match-data
23838
e494267843f7 (fortran-check-end-prog-re): Allow trailing
Dave Love <fx@gnu.org>
parents: 23754
diff changeset
1061 (string-match "^\\s-*\\(\\'\\|\\s<\\)"
23711
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1062 (buffer-substring (match-end 0)
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1063 (min (line-end-position)
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1064 (+ 72 (line-beginning-position)))))))
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1065
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1066 ;; Note that you can't just check backwards for `subroutine' &c in
7beb8675e914 Fix previous change:
Dave Love <fx@gnu.org>
parents: 23616
diff changeset
1067 ;; case of un-marked main programs not at the start of the file.
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1068 (defun fortran-beginning-of-subprogram ()
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
1069 "Move point to the beginning of the current Fortran subprogram."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1070 (interactive)
25054
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1071 (save-match-data
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1072 (let ((case-fold-search t))
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1073 (beginning-of-line -1)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1074 (if (catch 'ok
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1075 (while (re-search-backward fortran-end-prog-re nil 'move)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1076 (if (fortran-check-end-prog-re)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1077 (throw 'ok t))))
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1078 (forward-line)))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1079
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1080 (defun fortran-end-of-subprogram ()
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
1081 "Move point to the end of the current Fortran subprogram."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1082 (interactive)
25054
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1083 (save-match-data
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1084 (let ((case-fold-search t))
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1085 (if (save-excursion ; on END
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1086 (beginning-of-line)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1087 (and (looking-at fortran-end-prog-re)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1088 (fortran-check-end-prog-re)))
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1089 (forward-line)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1090 (beginning-of-line 2)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1091 (catch 'ok
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1092 (while (re-search-forward fortran-end-prog-re nil 'move)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1093 (if (fortran-check-end-prog-re)
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1094 (throw 'ok t))))
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1095 (goto-char (match-beginning 0))
888326cb8ffb (fortran-mode-syntax-table): Change `\' to `\'
Dave Love <fx@gnu.org>
parents: 24800
diff changeset
1096 (forward-line)))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1097
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1098 (defun fortran-previous-statement ()
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
1099 "Move point to beginning of the previous Fortran statement.
45242
52d991be0698 (fortran-preprocessor-re): New variable. Use it for font-locking.
Glenn Morris <rgm@gnu.org>
parents: 45067
diff changeset
1100 Returns 'first-statement if that statement is the first
52d991be0698 (fortran-preprocessor-re): New variable. Use it for font-locking.
Glenn Morris <rgm@gnu.org>
parents: 45067
diff changeset
1101 non-comment Fortran statement in the file, and nil otherwise.
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1102 Directive lines are treated as comments."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1103 (interactive)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1104 (let (not-first-statement continue-test)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1105 (beginning-of-line)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1106 (setq continue-test
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1107 (and
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1108 (not (looking-at fortran-comment-line-start-skip))
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1109 (not (looking-at fortran-directive-re))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1110 (or (looking-at
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1111 (concat "[ \t]*"
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1112 (regexp-quote fortran-continuation-string)))
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1113 (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]"))))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1114 (while (and (setq not-first-statement (zerop (forward-line -1)))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1115 (or (looking-at fortran-comment-line-start-skip)
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1116 (looking-at fortran-directive-re)
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1117 (looking-at
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1118 (concat "[ \t]*"
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1119 (regexp-quote fortran-continuation-string)))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1120 (looking-at "[ \t]*$\\| \\{5\\}[^ 0\n]\\|\t[1-9]")
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1121 (looking-at (concat "[ \t]*" comment-start-skip)))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1122 (cond ((and continue-test
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1123 (not not-first-statement))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1124 (message "Incomplete continuation statement."))
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
1125 (continue-test
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1126 (fortran-previous-statement))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1127 ((not not-first-statement)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1128 'first-statement))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1129
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1130 (defun fortran-next-statement ()
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
1131 "Move point to beginning of the next Fortran statement.
45242
52d991be0698 (fortran-preprocessor-re): New variable. Use it for font-locking.
Glenn Morris <rgm@gnu.org>
parents: 45067
diff changeset
1132 Returns 'last-statement if that statement is the last
52d991be0698 (fortran-preprocessor-re): New variable. Use it for font-locking.
Glenn Morris <rgm@gnu.org>
parents: 45067
diff changeset
1133 non-comment Fortran statement in the file, and nil otherwise.
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1134 Directive lines are treated as comments."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1135 (interactive)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1136 (let (not-last-statement)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1137 (beginning-of-line)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1138 (while (and (setq not-last-statement
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1139 (and (zerop (forward-line 1))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1140 (not (eobp))))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1141 (or (looking-at fortran-comment-line-start-skip)
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1142 (looking-at fortran-directive-re)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1143 (looking-at "[ \t]*$\\| [^ 0\n]\\|\t[1-9]")
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1144 (looking-at (concat "[ \t]*" comment-start-skip)))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1145 (if (not not-last-statement)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1146 'last-statement)))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1147
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1148 (defun fortran-looking-at-if-then ()
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1149 "Return non-nil if at the start of a line with an IF ... THEN statement."
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1150 ;; cf f90-looking-at-if-then.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1151 (let ((p (point))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1152 (i (fortran-beginning-if)))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1153 (if i
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1154 (save-excursion
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1155 (goto-char i)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1156 (beginning-of-line)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1157 (= (point) p)))))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1158
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1159 ;; Used in hs-special-modes-alist.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1160 (defun fortran-end-of-block (&optional num)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1161 "Move point forward to the end of the current code block.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1162 With optional argument NUM, go forward that many balanced blocks.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1163 If NUM is negative, go backward to the start of a block. Does
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1164 not check for consistency of block types. Interactively, pushes
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1165 mark before moving point."
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1166 (interactive "p")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1167 (if (interactive-p) (push-mark (point) t))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1168 (and num (< num 0) (fortran-beginning-of-block (- num)))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1169 (let ((case-fold-search t)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1170 (count (or num 1)))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1171 (end-of-line)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1172 (while (and (> count 0)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1173 (re-search-forward
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1174 (concat "\\(" fortran-blocks-re
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1175 (if fortran-check-all-num-for-matching-do
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1176 "\\|^[ \t]*[0-9]+" "")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1177 "\\|continue\\|end\\)\\>")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1178 nil 'move))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1179 (beginning-of-line)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1180 (if (if (looking-at (concat "^[0-9 \t]*" fortran-if-start-re))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1181 (fortran-looking-at-if-then)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1182 (looking-at fortran-start-block-re))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1183 (setq count (1+ count))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1184 (if (or (looking-at fortran-end-block-re)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1185 (and (or (looking-at "^[0-9 \t]*continue")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1186 (and fortran-check-all-num-for-matching-do
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1187 (looking-at "[ \t]*[0-9]+")))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1188 (fortran-check-for-matching-do)))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1189 (setq count (1- count))))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1190 (end-of-line))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1191 (if (> count 0) (error "Missing block end"))))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1192
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1193 (defun fortran-beginning-of-block (&optional num)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1194 "Move point backwards to the start of the current code block.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1195 With optional argument NUM, go backward that many balanced
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1196 blocks. If NUM is negative, go forward to the end of a block.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1197 Does not check for consistency of block types. Interactively,
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1198 pushes mark before moving point."
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1199 (interactive "p")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1200 (if (interactive-p) (push-mark (point) t))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1201 (and num (< num 0) (fortran-end-of-block (- num)))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1202 (let ((case-fold-search t)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1203 (count (or num 1)))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1204 (beginning-of-line)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1205 (while (and (> count 0)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1206 (re-search-backward
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1207 (concat "\\(" fortran-blocks-re
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1208 (if fortran-check-all-num-for-matching-do
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1209 "\\|^[ \t]*[0-9]+" "")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1210 "\\|continue\\|end\\)\\>")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1211 nil 'move))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1212 (beginning-of-line)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1213 (if (if (looking-at (concat "^[0-9 \t]*" fortran-if-start-re))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1214 (fortran-looking-at-if-then)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1215 (looking-at fortran-start-block-re))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1216 (setq count (1- count))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1217 (if (or (looking-at fortran-end-block-re)
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1218 (and (or (looking-at "^[0-9 \t]*continue")
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1219 (and fortran-check-all-num-for-matching-do
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1220 (looking-at "[ \t]*[0-9]+")))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1221 (fortran-check-for-matching-do)))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1222 (setq count (1+ count)))))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1223 ;; Includes an un-named main program block.
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1224 (if (> count 0) (error "Missing block start"))))
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1225
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1226
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1227 (defun fortran-blink-match (regex keyword find-begin)
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1228 "From a line matching REGEX, blink matching KEYWORD statement line.
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1229 Use function FIND-BEGIN to match it."
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1230 (let ((top-of-window (window-start))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1231 (end-point (point))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1232 (case-fold-search t)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1233 matching
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1234 message)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1235 (when (save-excursion
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1236 (beginning-of-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1237 (skip-chars-forward " \t0-9")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1238 (looking-at regex))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1239 (if (not (setq matching (funcall find-begin)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1240 (setq message (concat "No matching " keyword "."))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1241 (if (< matching top-of-window)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1242 (save-excursion
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1243 (goto-char matching)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1244 (beginning-of-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1245 (setq message
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1246 (concat "Matches "
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1247 (buffer-substring (point)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1248 (line-end-position)))))))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1249 (if message
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1250 (message "%s" message)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1251 (goto-char matching)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1252 (sit-for 1)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1253 (goto-char end-point)))))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1254
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1255 (defun fortran-blink-matching-if ()
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1256 "From an ENDIF or ELSE statement, blink the matching IF statement."
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1257 (fortran-blink-match "e\\(nd[ \t]*if\\|lse\\([ \t]*if\\)?\\)\\b"
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1258 "if" #'fortran-beginning-if))
6731
23d9c2bc097b (fortran-blink-matching-do): New function,
Richard M. Stallman <rms@gnu.org>
parents: 5720
diff changeset
1259
23d9c2bc097b (fortran-blink-matching-do): New function,
Richard M. Stallman <rms@gnu.org>
parents: 5720
diff changeset
1260 (defun fortran-blink-matching-do ()
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1261 "From an ENDDO statement, blink the matching DO or DO WHILE statement."
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1262 (fortran-blink-match "end[ \t]*do\\b" "do" #'fortran-beginning-do))
10189
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1263
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1264 (defun fortran-mark-do ()
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
1265 "Put mark at end of Fortran DO [WHILE]-ENDDO construct, point at beginning.
10189
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1266 The marks are pushed."
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1267 (interactive)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1268 (let (enddo-point do-point)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1269 (if (setq enddo-point (fortran-end-do))
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1270 (if (not (setq do-point (fortran-beginning-do)))
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1271 (message "No matching do.")
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1272 (goto-char enddo-point)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1273 (push-mark)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1274 (goto-char do-point)))))
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1275
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1276 (defun fortran-end-do ()
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1277 "Search forward for first unmatched ENDDO.
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1278 Return point or nil."
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1279 (let ((case-fold-search t))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1280 (if (save-excursion (beginning-of-line)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1281 (skip-chars-forward " \t0-9")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1282 (looking-at "end[ \t]*do\\b"))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1283 ;; Sitting on one.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1284 (match-beginning 0)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1285 ;; Search for one.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1286 (save-excursion
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1287 (let ((count 1))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1288 (while (and (not (zerop count))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1289 (not (eq (fortran-next-statement) 'last-statement))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1290 ;; Keep local to subprogram.
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1291 (not (and (looking-at fortran-end-prog-re)
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1292 (fortran-check-end-prog-re))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1293 (skip-chars-forward " \t0-9")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1294 (cond ((looking-at "end[ \t]*do\\b")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1295 (setq count (1- count)))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1296 ((looking-at
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1297 "\\(\\(\\sw\\|\\s_\\)+:[ \t]*\\)?do[ \t]+[^0-9]")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1298 (setq count (1+ count)))))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1299 (and (zerop count)
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1300 ;; All pairs accounted for.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1301 (point)))))))
10189
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1302
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1303 (defun fortran-beginning-do ()
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1304 "Search backwards for first unmatched DO [WHILE].
47767
1ad06cb931a9 (fortran-beginning-do): Ignore labelled DO loops altogether.
Glenn Morris <rgm@gnu.org>
parents: 46979
diff changeset
1305 Return point or nil. Ignores labelled DO loops (ie DO 10 ... 10 CONTINUE)."
1ad06cb931a9 (fortran-beginning-do): Ignore labelled DO loops altogether.
Glenn Morris <rgm@gnu.org>
parents: 46979
diff changeset
1306 (let ((case-fold-search t)
1ad06cb931a9 (fortran-beginning-do): Ignore labelled DO loops altogether.
Glenn Morris <rgm@gnu.org>
parents: 46979
diff changeset
1307 (dostart-re "\\(\\(\\sw\\|\\s_\\)+:[ \t]*\\)?do[ \t]+[^0-9]"))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1308 (if (save-excursion
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1309 (beginning-of-line)
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1310 (skip-chars-forward " \t0-9")
47767
1ad06cb931a9 (fortran-beginning-do): Ignore labelled DO loops altogether.
Glenn Morris <rgm@gnu.org>
parents: 46979
diff changeset
1311 (looking-at dostart-re))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1312 ;; Sitting on one.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1313 (match-beginning 0)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1314 ;; Search for one.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1315 (save-excursion
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1316 (let ((count 1))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1317 (while (and (not (zerop count))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1318 (not (eq (fortran-previous-statement) 'first-statement))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1319 ;; Keep local to subprogram.
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1320 (not (and (looking-at fortran-end-prog-re)
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1321 (fortran-check-end-prog-re))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1322 (skip-chars-forward " \t0-9")
47767
1ad06cb931a9 (fortran-beginning-do): Ignore labelled DO loops altogether.
Glenn Morris <rgm@gnu.org>
parents: 46979
diff changeset
1323 (cond ((looking-at dostart-re)
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1324 (setq count (1- count)))
47767
1ad06cb931a9 (fortran-beginning-do): Ignore labelled DO loops altogether.
Glenn Morris <rgm@gnu.org>
parents: 46979
diff changeset
1325 ;; Note labelled loop ends not considered.
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1326 ((looking-at "end[ \t]*do\\b")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1327 (setq count (1+ count)))))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1328 (and (zerop count)
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1329 ;; All pairs accounted for.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1330 (point)))))))
10189
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1331
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1332 (defun fortran-mark-if ()
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1333 "Put mark at end of Fortran IF-ENDIF construct, point at beginning.
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1334 The marks are pushed."
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1335 (interactive)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1336 (let (endif-point if-point)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1337 (if (setq endif-point (fortran-end-if))
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1338 (if (not (setq if-point (fortran-beginning-if)))
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1339 (message "No matching if.")
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1340 ;; Set mark, move point.
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1341 (goto-char endif-point)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1342 (push-mark)
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1343 (goto-char if-point)))))
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1344
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1345 (defun fortran-end-if ()
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1346 "Search forwards for first unmatched ENDIF.
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1347 Return point or nil."
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1348 (let ((case-fold-search t))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1349 (if (save-excursion (beginning-of-line)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1350 (skip-chars-forward " \t0-9")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1351 (looking-at "end[ \t]*if\\b"))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1352 ;; Sitting on one.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1353 (match-beginning 0)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1354 ;; Search for one. The point has been already been moved to first
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1355 ;; letter on line but this should not cause troubles.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1356 (save-excursion
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1357 (let ((count 1))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1358 (while (and (not (zerop count))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1359 (not (eq (fortran-next-statement) 'last-statement))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1360 ;; Keep local to subprogram.
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1361 (not (and (looking-at fortran-end-prog-re)
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1362 (fortran-check-end-prog-re))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1363 (skip-chars-forward " \t0-9")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1364 (cond ((looking-at "end[ \t]*if\\b")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1365 (setq count (1- count)))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1366 ((looking-at fortran-if-start-re)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1367 (save-excursion
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1368 (if (or
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1369 (looking-at ".*)[ \t]*then\\b[ \t]*[^ \t(=a-z0-9]")
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1370 (let (then-test) ; multi-line if-then
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1371 (while
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1372 (and
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1373 (zerop (forward-line 1))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1374 ;; Search forward for then.
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1375 (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]")
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1376 (not
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1377 (setq then-test
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1378 (looking-at
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1379 ".*then\\b[ \t]*[^ \t(=a-z0-9]")))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1380 then-test))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1381 (setq count (1+ count)))))))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1382 (and (zerop count)
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1383 ;; All pairs accounted for.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1384 (point)))))))
10189
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1385
b2d6d69b7707 (fortran-end-if, fortran-end-do,
Richard M. Stallman <rms@gnu.org>
parents: 9476
diff changeset
1386 (defun fortran-beginning-if ()
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1387 "Search backwards for first unmatched IF-THEN.
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1388 Return point or nil."
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1389 (let ((case-fold-search t))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1390 (if (save-excursion
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1391 ;; May be sitting on multi-line if-then statement, first
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1392 ;; move to beginning of current statement. Note:
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1393 ;; `fortran-previous-statement' moves to previous statement
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1394 ;; *unless* current statement is first one. Only move
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1395 ;; forward if not first-statement.
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1396 (if (not (eq (fortran-previous-statement) 'first-statement))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1397 (fortran-next-statement))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1398 (skip-chars-forward " \t0-9")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1399 (and
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1400 (looking-at fortran-if-start-re)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1401 (save-match-data
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1402 (or (looking-at ".*)[ \t]*then\\b[ \t]*[^ \t(=a-z0-9]")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1403 ;; Multi-line if-then.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1404 (let (then-test)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1405 (while
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1406 (and (zerop (forward-line 1))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1407 ;; Search forward for then.
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1408 (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]")
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1409 (not
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1410 (setq then-test
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1411 (looking-at
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1412 ".*then\\b[ \t]*[^ \t(=a-z0-9]")))))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1413 then-test)))))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1414 ;; Sitting on one.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1415 (match-beginning 0)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1416 ;; Search for one.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1417 (save-excursion
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1418 (let ((count 1))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1419 (while (and (not (zerop count))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1420 (not (eq (fortran-previous-statement) 'first-statement))
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1421 ;; Keep local to subprogram.
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1422 (not (and (looking-at fortran-end-prog-re)
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1423 (fortran-check-end-prog-re))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1424 (skip-chars-forward " \t0-9")
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1425 (cond ((looking-at fortran-if-start-re)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1426 (save-excursion
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1427 (if (or
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1428 (looking-at ".*)[ \t]*then\\b[ \t]*[^ \t(=a-z0-9]")
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1429 (let (then-test) ; multi-line if-then
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1430 (while
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1431 (and
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1432 (zerop (forward-line 1))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1433 ;; Search forward for then.
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1434 (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]")
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1435 (not
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1436 (setq then-test
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1437 (looking-at
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1438 (concat ".*then\\b[ \t]*"
41676
82c2143ec3eb Fontify rewind, backspace. Doc fixes.
Dave Love <fx@gnu.org>
parents: 41234
diff changeset
1439 "[^ \t(=a-z0-9]"))))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1440 then-test))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1441 (setq count (1- count)))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1442 ((looking-at "end[ \t]*if\\b")
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1443 (setq count (1+ count)))))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1444 (and (zerop count)
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1445 ;; All pairs accounted for.
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1446 (point)))))))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1447
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1448
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1449 (defun fortran-indent-line ()
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1450 "Indent current Fortran line based on its contents and on previous lines."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1451 (interactive "*")
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1452 (let ((cfi (fortran-calculate-indent)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1453 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1454 (beginning-of-line)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1455 (if (or (not (= cfi (fortran-current-line-indentation)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1456 (and (re-search-forward "^[ \t]*[0-9]+" (+ (point) 4) t)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1457 (not (fortran-line-number-indented-correctly-p))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1458 (fortran-indent-to-column cfi)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1459 (beginning-of-line)
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1460 (if (fortran-find-comment-start-skip)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1461 (fortran-indent-comment))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1462 ;; Never leave point in left margin.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1463 (if (< (current-column) cfi)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1464 (move-to-column cfi))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1465 (and auto-fill-function
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1466 (> (save-excursion (end-of-line) (current-column))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1467 fill-column)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1468 (save-excursion
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1469 (end-of-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1470 (fortran-fill)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1471 (when fortran-blink-matching-if
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1472 (fortran-blink-matching-if)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1473 (fortran-blink-matching-do))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1474
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1475 (defun fortran-auto-fill ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1476 "Function to use for `normal-auto-fill-function' in Fortran mode."
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1477 (if (> (current-column) (current-fill-column))
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1478 (let ((cfi (fortran-calculate-indent)))
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1479 (save-excursion
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1480 (beginning-of-line)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1481 (if (or (not (= cfi (fortran-current-line-indentation)))
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1482 (and (re-search-forward "^[ \t]*[0-9]+"
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1483 (+ (point) 4) t)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1484 (not (fortran-line-number-indented-correctly-p))))
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1485 (fortran-indent-to-column cfi)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1486 (beginning-of-line)
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1487 (if (fortran-find-comment-start-skip)
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1488 (fortran-indent-comment))))
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1489 (fortran-fill)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1490 ;; Never leave point in left margin.
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1491 (if (< (current-column) cfi)
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1492 (move-to-column cfi)))))
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1493
25162
ec613559ec18 (fortran-indent-new-line): Make it an alias
Dave Love <fx@gnu.org>
parents: 25054
diff changeset
1494 ;; Historically this was a separate function which advertised itself
ec613559ec18 (fortran-indent-new-line): Make it an alias
Dave Love <fx@gnu.org>
parents: 25054
diff changeset
1495 ;; as reindenting but only did so where `most likely to be necessary'.
ec613559ec18 (fortran-indent-new-line): Make it an alias
Dave Love <fx@gnu.org>
parents: 25054
diff changeset
1496 (defalias 'fortran-indent-new-line 'reindent-then-newline-and-indent)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1497
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1498 (defun fortran-indent-subprogram ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1499 "Properly indent the Fortran subprogram containing point."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1500 (interactive "*")
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1501 (save-excursion
27199
4a15e79c5fb0 (fortran-mode-map): Don't bind M-C-a,
Dave Love <fx@gnu.org>
parents: 26665
diff changeset
1502 (mark-defun)
24254
93993abff564 (mark-fortran-subprogram): Activate mark
Dave Love <fx@gnu.org>
parents: 24125
diff changeset
1503 (message "Indenting subprogram...")
93993abff564 (mark-fortran-subprogram): Activate mark
Dave Love <fx@gnu.org>
parents: 24125
diff changeset
1504 (indent-region (point) (mark) nil))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1505 (message "Indenting subprogram...done."))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1506
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1507 (defun fortran-calculate-indent ()
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1508 "Calculates the Fortran indent column based on previous lines."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1509 (let (icol first-statement (case-fold-search t)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1510 (fortran-minimum-statement-indent
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1511 (if indent-tabs-mode
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1512 fortran-minimum-statement-indent-tab
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1513 fortran-minimum-statement-indent-fixed)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1514 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1515 (setq first-statement (fortran-previous-statement))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1516 (if first-statement
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1517 (setq icol fortran-minimum-statement-indent)
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1518 (if (= (point) (point-min))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1519 (setq icol fortran-minimum-statement-indent)
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1520 (setq icol (fortran-current-line-indentation)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1521 (skip-chars-forward " \t0-9")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1522 (cond ((looking-at "\\(\\(\\sw\\|\\s_\\)+:[ \t]*\\)?if[ \t]*(")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1523 (if (or (looking-at ".*)[ \t]*then\\b[ \t]*[^ \t_$(=a-z0-9]")
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1524 (let (then-test) ; multi-line if-then
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1525 (while (and (zerop (forward-line 1))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1526 ;; Search forward for then.
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1527 (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1528 (not (setq then-test
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1529 (looking-at
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1530 ".*then\\b[ \t]\
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1531 *[^ \t_$(=a-z0-9]")))))
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1532 then-test))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1533 (setq icol (+ icol fortran-if-indent))))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1534 ((looking-at "else\\(if\\)?\\b")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1535 (setq icol (+ icol fortran-if-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1536 ((looking-at "select[ \t]*case[ \t](.*)")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1537 (setq icol (+ icol fortran-if-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1538 ((looking-at "case[ \t]*(.*)")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1539 (setq icol (+ icol fortran-if-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1540 ((looking-at "case[ \t]*default\\b")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1541 (setq icol (+ icol fortran-if-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1542 ((looking-at "\\(otherwise\\|else[ \t]*where\\)\\b")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1543 (setq icol (+ icol fortran-if-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1544 ((looking-at "where[ \t]*(.*)[ \t]*\n")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1545 (setq icol (+ icol fortran-if-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1546 ((looking-at "do\\b")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1547 (setq icol (+ icol fortran-do-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1548 ((looking-at
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1549 "\\(structure\\|union\\|map\\|interface\\)\
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1550 \\b[ \t]*[^ \t=(a-z]")
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1551 (setq icol (+ icol fortran-structure-indent)))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1552 ((and (looking-at fortran-end-prog-re1)
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1553 (fortran-check-end-prog-re))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1554 ;; Previous END resets indent to minimum.
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1555 (setq icol fortran-minimum-statement-indent)))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1556 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1557 (beginning-of-line)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1558 (cond ((looking-at "[ \t]*$"))
45301
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1559 ;; Check for directive before comment, so as not to indent.
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1560 ((looking-at fortran-directive-re)
793bb00af917 (fortran-directive-re): New name for fortran-preprocessor-re. All usage
Glenn Morris <rgm@gnu.org>
parents: 45255
diff changeset
1561 (setq fortran-minimum-statement-indent 0 icol 0))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1562 ((looking-at fortran-comment-line-start-skip)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1563 (cond ((eq fortran-comment-indent-style 'relative)
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1564 (setq icol (+ icol fortran-comment-line-extra-indent)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1565 ((eq fortran-comment-indent-style 'fixed)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1566 (setq icol (+ fortran-minimum-statement-indent
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1567 fortran-comment-line-extra-indent))))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1568 (setq fortran-minimum-statement-indent 0))
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1569 ((or (looking-at (concat "[ \t]*"
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1570 (regexp-quote
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1571 fortran-continuation-string)))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1572 (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]"))
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1573 (skip-chars-forward " \t")
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1574 ;; Do not introduce extra whitespace into a broken string.
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1575 (setq icol
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1576 (if (fortran-is-in-string-p (point))
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1577 6
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1578 (+ icol fortran-continuation-indent))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1579 (first-statement)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1580 ((and fortran-check-all-num-for-matching-do
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1581 (looking-at "[ \t]*[0-9]+")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1582 (fortran-check-for-matching-do))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1583 (setq icol (- icol fortran-do-indent)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1584 (t
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1585 (skip-chars-forward " \t0-9")
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1586 (cond ((looking-at "end[ \t]*\\(if\\|select\\|where\\)\\b")
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1587 (setq icol (- icol fortran-if-indent)))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1588 ((looking-at "else\\(if\\)?\\b")
5720
fe1a71db966f (calculate-fortran-indent): Handle
Richard M. Stallman <rms@gnu.org>
parents: 5065
diff changeset
1589 (setq icol (- icol fortran-if-indent)))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1590 ((looking-at "case[ \t]*\\((.*)\\|default\\>\\)")
5720
fe1a71db966f (calculate-fortran-indent): Handle
Richard M. Stallman <rms@gnu.org>
parents: 5065
diff changeset
1591 (setq icol (- icol fortran-if-indent)))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1592 ((looking-at "\\(otherwise\\|else[ \t]*where\\)\\b")
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1593 (setq icol (- icol fortran-if-indent)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1594 ((and (looking-at "continue\\b")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1595 (fortran-check-for-matching-do))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1596 (setq icol (- icol fortran-do-indent)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1597 ((looking-at "end[ \t]*do\\b")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1598 (setq icol (- icol fortran-do-indent)))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1599 ((looking-at "end[ \t]*\
5720
fe1a71db966f (calculate-fortran-indent): Handle
Richard M. Stallman <rms@gnu.org>
parents: 5065
diff changeset
1600 \\(structure\\|union\\|map\\|interface\\)\\b[ \t]*[^ \t=(a-z]")
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1601 (setq icol (- icol fortran-structure-indent)))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1602 ((and (looking-at fortran-end-prog-re1)
23754
53a4f2e0fccc Various minor doc fixes.
Dave Love <fx@gnu.org>
parents: 23732
diff changeset
1603 (fortran-check-end-prog-re)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1604 (not (= icol fortran-minimum-statement-indent)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1605 (message "Warning: `end' not in column %d. Probably\
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1606 an unclosed block." fortran-minimum-statement-indent))))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1607 (max fortran-minimum-statement-indent icol)))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1608
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1609
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1610 (defun fortran-current-line-indentation ()
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1611 "Indentation of current line, ignoring Fortran line number or continuation.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1612 This is the column position of the first non-whitespace character
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1613 aside from the line number and/or column 5/8 line-continuation character.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1614 For comment lines, returns indentation of the first
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1615 non-indentation text within the comment."
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1616 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1617 (beginning-of-line)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1618 (cond ((looking-at fortran-comment-line-start-skip)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1619 (goto-char (match-end 0))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1620 (skip-chars-forward
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1621 (if (stringp fortran-comment-indent-char)
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1622 fortran-comment-indent-char
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1623 (char-to-string fortran-comment-indent-char))))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1624 ((or (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]"))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1625 (goto-char (match-end 0)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1626 (t
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1627 ;; Move past line number.
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1628 (skip-chars-forward "[ \t0-9]")))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1629 ;; Move past whitespace.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1630 (skip-chars-forward " \t")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1631 (current-column)))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1632
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1633 (defun fortran-indent-to-column (col)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1634 "Indent current line to column COL.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1635 notes: 1) A non-zero/non-blank character in column 5 indicates a continuation
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1636 line, and this continuation character is retained on indentation;
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1637 2) If `fortran-continuation-string' is the first non-whitespace
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1638 character, this is a continuation line;
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1639 3) A non-continuation line which has a number as the first
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1640 non-whitespace character is a numbered line.
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1641 4) A TAB followed by a digit indicates a continuation line."
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1642 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1643 (beginning-of-line)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1644 (if (looking-at fortran-comment-line-start-skip)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1645 (if fortran-comment-indent-style
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1646 (let* ((char (if (stringp fortran-comment-indent-char)
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1647 (aref fortran-comment-indent-char 0)
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1648 fortran-comment-indent-char))
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1649 (chars (string ? ?\t char)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1650 (goto-char (match-end 0))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1651 (skip-chars-backward chars)
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1652 (delete-region (point) (progn (skip-chars-forward chars)
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1653 (point)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1654 (insert-char char (- col (current-column)))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1655 (if (looking-at "\t[1-9]")
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1656 (if indent-tabs-mode
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1657 (goto-char (match-end 0))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1658 (delete-char 2)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1659 (insert-char ? 5)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1660 (insert fortran-continuation-string))
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1661 (if (looking-at " \\{5\\}[^ 0\n]")
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1662 (if indent-tabs-mode
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1663 (progn (delete-char 6)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1664 (insert ?\t (fortran-numerical-continuation-char) 1))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1665 (forward-char 6))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1666 (delete-horizontal-space)
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1667 ;; Put line number in columns 0-4, or
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1668 ;; continuation character in column 5.
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1669 (cond ((eobp))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1670 ((looking-at (regexp-quote fortran-continuation-string))
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1671 (if indent-tabs-mode
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1672 (progn
20207
38616c4cf58c (fortran-imenu-generic-expression): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 20205
diff changeset
1673 (indent-to
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1674 (if indent-tabs-mode
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1675 fortran-minimum-statement-indent-tab
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1676 fortran-minimum-statement-indent-fixed))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1677 (delete-char 1)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1678 (insert-char (fortran-numerical-continuation-char) 1))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1679 (indent-to 5)
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1680 (forward-char 1)))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1681 ((looking-at "[0-9]+")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1682 (let ((extra-space (- 5 (- (match-end 0) (point)))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1683 (if (< extra-space 0)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1684 (message "Warning: line number exceeds 5-digit limit.")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1685 (indent-to (min fortran-line-number-indent extra-space))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1686 (skip-chars-forward "0-9")))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1687 ;; Point is now after any continuation character or line number.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1688 ;; Put body of statement where specified.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1689 (delete-horizontal-space)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1690 (indent-to col)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1691 ;; Indent any comment following code on the same line.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1692 (when (fortran-find-comment-start-skip)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1693 (goto-char (match-beginning 0))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1694 (unless (= (current-column) (fortran-comment-indent))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1695 (delete-horizontal-space)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1696 (indent-to (fortran-comment-indent)))))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1697
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1698 (defun fortran-line-number-indented-correctly-p ()
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1699 "Return t if current line's line number is correctly indented.
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1700 Do not call if there is no line number."
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1701 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1702 (beginning-of-line)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1703 (skip-chars-forward " \t")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1704 (and (<= (current-column) fortran-line-number-indent)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1705 (or (= (current-column) fortran-line-number-indent)
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1706 (progn (skip-chars-forward "0-9")
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1707 (= (current-column) 5))))))
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1708
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1709 (defun fortran-check-for-matching-do ()
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1710 "When called from a numbered statement, return t if matching DO is found.
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1711 Otherwise return nil."
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1712 (let ((case-fold-search t)
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1713 charnum)
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1714 (save-excursion
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1715 (beginning-of-line)
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1716 (when (looking-at "[ \t]*[0-9]+")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1717 (skip-chars-forward " \t")
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1718 (skip-chars-forward "0") ; skip past leading zeros
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1719 (setq charnum
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1720 (buffer-substring (point) (progn
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1721 (skip-chars-forward "0-9")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1722 (point))))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1723 (beginning-of-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1724 (save-restriction
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1725 (save-excursion
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1726 (narrow-to-defun)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1727 (and (re-search-backward
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1728 (concat
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1729 "\\(^[ \t0-9]*do[ \t]*0*"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1730 charnum "\\b\\)\\|" "\\(^[ \t]*0*"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1731 charnum "\\b\\)")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1732 nil t)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1733 (looking-at
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1734 (concat "^[ \t0-9]*do[ \t]*0*"
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1735 charnum)))))))))
332
3cb8418b827a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1736
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1737 (defun fortran-find-comment-start-skip (&optional all)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1738 "Move to past `comment-start-skip' found on current line.
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1739 Return non-nil if `comment-start-skip' found, nil if not.
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1740 If ALL is nil, only match comments that start in column > 0."
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1741 ;; Hopefully at some point we can just use the line below! -stef
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1742 ;; (comment-search-forward (line-end-position) t))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1743 (when (or all comment-start-skip)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1744 (let ((pos (point))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1745 (css (if comment-start-skip
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1746 (concat fortran-comment-line-start-skip
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1747 "\\|" comment-start-skip)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1748 fortran-comment-line-start-skip)))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1749 (when (re-search-forward css (line-end-position) t)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1750 (if (and (or all (> (match-beginning 0) (line-beginning-position)))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1751 (or (save-match-data
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1752 (not (fortran-is-in-string-p (match-beginning 0))))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1753 ;; Recurse for rest of line.
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1754 (fortran-find-comment-start-skip all)))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1755 (point)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1756 (goto-char pos)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1757 nil)))))
11516
e7c26522b881 Use new fortran-match-!-comment to do !-style fontification; do rest in regexps
Simon Marshall <simon@gnu.org>
parents: 10883
diff changeset
1758
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1759 ;; From: ralf@up3aud1.gwdg.de (Ralf Fassel)
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1760 ;; Test if TAB format continuation lines work.
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1761 (defun fortran-is-in-string-p (where)
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1762 "Return non-nil iff WHERE (a buffer position) is inside a Fortran string."
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1763 (save-excursion
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1764 (goto-char where)
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1765 (cond
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1766 ((bolp) nil) ; bol is never inside a string
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1767 ((save-excursion ; comment lines too
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1768 (beginning-of-line)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1769 (looking-at fortran-comment-line-start-skip)) nil)
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1770 (t (let ((parse-state '(0 nil nil nil nil nil 0))
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1771 (quoted-comment-start (if comment-start
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1772 (regexp-quote comment-start)))
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1773 (not-done t)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1774 parse-limit end-of-line)
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1775 ;; Move to start of current statement.
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1776 (fortran-next-statement)
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1777 (fortran-previous-statement)
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1778 ;; Now parse up to WHERE.
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1779 (while not-done
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1780 (if (or ;; Skip to next line if:
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1781 ;; - comment line?
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1782 (looking-at fortran-comment-line-start-skip)
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1783 ;; - at end of line?
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1784 (eolp)
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1785 ;; - not in a string and after comment-start?
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1786 (and (not (nth 3 parse-state))
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1787 comment-start
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1788 (equal comment-start
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1789 (char-to-string (preceding-char)))))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1790 (if (> (forward-line) 0)
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1791 (setq not-done nil))
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1792 ;; else:
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1793 ;; If we are at beginning of code line, skip any
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1794 ;; whitespace, labels and tab continuation markers.
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1795 (if (bolp) (skip-chars-forward " \t0-9"))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1796 ;; If we are in column <= 5 now, check for continuation char.
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1797 (cond ((= 5 (current-column)) (forward-char 1))
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1798 ((and (< (current-column) 5)
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1799 (equal fortran-continuation-string
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1800 (char-to-string (following-char)))
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1801 (forward-char 1))))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1802 ;; Find out parse-limit from here.
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1803 (setq end-of-line (line-end-position))
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1804 (setq parse-limit (min where end-of-line))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1805 ;; Parse max up to comment-start, if non-nil and in current line.
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1806 (if comment-start
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1807 (save-excursion
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1808 (if (re-search-forward quoted-comment-start end-of-line t)
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1809 (setq parse-limit (min (point) parse-limit)))))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1810 ;; Now parse if still in limits.
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1811 (if (< (point) where)
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1812 (setq parse-state (parse-partial-sexp
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1813 (point) parse-limit nil nil parse-state))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1814 (setq not-done nil))))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1815 ;; Result.
3400
927c3d8374ef (fortran-mode): Replace comment-indent-hook with
Richard M. Stallman <rms@gnu.org>
parents: 2307
diff changeset
1816 (nth 3 parse-state))))))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1817
31847
c2d49e897f90 (fortran-mode): Locally set
Dave Love <fx@gnu.org>
parents: 30186
diff changeset
1818 ;; From old version.
c2d49e897f90 (fortran-mode): Locally set
Dave Love <fx@gnu.org>
parents: 30186
diff changeset
1819 (defalias 'fortran-auto-fill-mode 'auto-fill-mode)
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1820
12772
f4b2913b7f58 (fortran-auto-fill-mode, fortran-do-auto-fill, fortran-fill):
Richard M. Stallman <rms@gnu.org>
parents: 12715
diff changeset
1821 (defun fortran-fill ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1822 "Fill the current line at an appropriate point(s)."
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1823 (let* ((auto-fill-function #'fortran-auto-fill)
24800
b4bf2212c418 Add :link to defgroup.
Dave Love <fx@gnu.org>
parents: 24254
diff changeset
1824 (opoint (point))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1825 (bol (line-beginning-position))
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1826 (eol (line-end-position))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1827 (bos (min eol (+ bol (fortran-current-line-indentation))))
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1828 ;; If in a string at fill-column, break it either before the
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1829 ;; initial quote, or at fill-col (if string is too long).
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1830 (quote
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1831 (save-excursion
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1832 (goto-char bol)
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1833 ;; OK to break quotes on comment lines.
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1834 (unless (looking-at fortran-comment-line-start-skip)
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1835 (let (fcpoint start)
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1836 (move-to-column fill-column)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1837 (when (fortran-is-in-string-p (setq fcpoint (point)))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1838 (save-excursion
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1839 (re-search-backward "\\S\"\\s\"\\S\"?" bol t)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1840 (setq start
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1841 (if fortran-break-before-delimiters
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1842 (point)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1843 (1+ (point)))))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1844 (if (re-search-forward "\\S\"\\s\"\\S\"" eol t)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1845 (backward-char 2))
61107
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1846 ;; If the current string is longer than (fill-column
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1847 ;; - 6) chars, break it at the fill column (else
9554f19ae068 Reformat and update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 59996
diff changeset
1848 ;; infinite loop).
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1849 (if (> (- (point) start)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1850 (- fill-column 6 fortran-continuation-indent))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1851 fcpoint
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1852 start))))))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1853 ;; Decide where to split the line. If a position for a quoted
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1854 ;; string was found above then use that, else break the line
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1855 ;; before/after the last delimiter.
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1856 (fill-point
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1857 (or quote
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1858 (save-excursion
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1859 ;; If f-b-b-d is t, have an extra column to play with,
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1860 ;; since delimiter gets shifted to new line.
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1861 (move-to-column (if fortran-break-before-delimiters
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1862 (1+ fill-column)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1863 fill-column))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1864 (let ((repeat t))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1865 (while repeat
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1866 (setq repeat nil)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1867 ;; Adapted from f90-find-breakpoint.
55251
f5da8d364dba (fortran-fill): Use local var `bol' rather than duplicate call to
Glenn Morris <rgm@gnu.org>
parents: 53700
diff changeset
1868 (re-search-backward fortran-break-delimiters-re bol)
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1869 (if (not fortran-break-before-delimiters)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1870 (if (looking-at fortran-no-break-re)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1871 ;; Deal with cases such as "**" split over
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1872 ;; fill-col. Simpler alternative would be
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1873 ;; to start from (1- fill-column) above.
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1874 (if (> (+ 2 (current-column)) fill-column)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1875 (setq repeat t)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1876 (forward-char 2))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1877 (forward-char 1))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1878 (backward-char)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1879 (or (looking-at fortran-no-break-re)
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1880 (forward-char)))))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1881 ;; Line indented beyond fill-column?
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1882 (when (<= (point) bos)
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1883 (move-to-column (1+ fill-column))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1884 ;; What is this doing???
50579
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1885 (or (re-search-forward "[\t\n,'+-/*)=]" eol t)
603b312a33d1 (fortran-previous-statement): Check for fortran-continuation-string.
Glenn Morris <rgm@gnu.org>
parents: 50561
diff changeset
1886 (goto-char bol)))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1887 (if (bolp)
53700
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1888 (re-search-forward "[ \t]" opoint t))
444062830592 (fortran-break-before-delimiters): Doc fix.
Glenn Morris <rgm@gnu.org>
parents: 52401
diff changeset
1889 (point)))))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1890 ;; If we are in an in-line comment, don't break unless the
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1891 ;; line of code is longer than it should be. Otherwise
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1892 ;; break the line at the column computed above.
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1893 ;;
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1894 ;; Need to use fortran-find-comment-start-skip to make sure that
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1895 ;; quoted !'s don't prevent a break.
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1896 (when (and (save-excursion
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1897 (beginning-of-line)
49755
fb628fd7f726 (fortran-fill): Fill lines that do not have comments.
Glenn Morris <rgm@gnu.org>
parents: 49751
diff changeset
1898 (if (not (fortran-find-comment-start-skip))
fb628fd7f726 (fortran-fill): Fill lines that do not have comments.
Glenn Morris <rgm@gnu.org>
parents: 49751
diff changeset
1899 t
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1900 (goto-char (match-beginning 0))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1901 (>= (point) fill-point)))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1902 (save-excursion
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1903 (goto-char fill-point)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1904 (not (bolp)))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1905 (> (save-excursion
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1906 (goto-char opoint)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1907 (current-column))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1908 (min (1+ fill-column)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1909 (+ (fortran-calculate-indent)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1910 fortran-continuation-indent))))
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1911 (goto-char fill-point)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1912 (fortran-break-line)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1913 (end-of-line))))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1914
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1915 (defun fortran-break-line ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1916 "Call `fortran-split-line'. Joins continuation lines first, then refills."
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1917 (let ((opoint (point))
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1918 (bol (line-beginning-position))
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1919 (comment-string
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1920 (save-excursion
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1921 (if (fortran-find-comment-start-skip)
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1922 (delete-and-extract-region
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1923 (match-beginning 0) (line-end-position))))))
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
1924 ;; Forward line 1 really needs to go to next non white line.
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1925 (if (save-excursion (forward-line)
43882
e601e469e7a4 (fortran-mode): Set comment-padding to "$$$".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42443
diff changeset
1926 (looking-at " \\{5\\}[^ 0\n]\\|\t[1-9]"))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1927 (progn
12715
ad18c3ad23b3 (fortran-break-line): Fixed a bug that sometimes
Richard M. Stallman <rms@gnu.org>
parents: 12386
diff changeset
1928 (end-of-line)
ad18c3ad23b3 (fortran-break-line): Fixed a bug that sometimes
Richard M. Stallman <rms@gnu.org>
parents: 12386
diff changeset
1929 (delete-region (point) (match-end 0))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1930 (delete-horizontal-space)
12772
f4b2913b7f58 (fortran-auto-fill-mode, fortran-do-auto-fill, fortran-fill):
Richard M. Stallman <rms@gnu.org>
parents: 12715
diff changeset
1931 (fortran-fill))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1932 (fortran-split-line))
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1933 (if comment-string
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1934 (save-excursion
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1935 (goto-char bol)
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1936 (end-of-line)
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1937 (delete-horizontal-space)
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1938 (indent-to (fortran-comment-indent))
1548
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1939 (insert comment-string)))))
cbed5e520f81 version 1.28.8
Richard M. Stallman <rms@gnu.org>
parents: 1488
diff changeset
1940
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1941 (defun fortran-analyze-file-format ()
20805
918448e5d294 Various docstring and commentary fixes, including
Dave Love <fx@gnu.org>
parents: 20277
diff changeset
1942 "Return nil if fixed format is used, t if TAB formatting is used.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1943 Use `fortran-tab-mode-default' if no non-comment statements are found
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1944 before the end or in the first `fortran-analyze-depth' lines."
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1945 (let ((i 0))
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1946 (save-excursion
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1947 (goto-char (point-min))
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1948 (while (not (or
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1949 (eobp)
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1950 (eq (char-after) ?\t)
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1951 (looking-at " \\{6\\}")
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1952 (> i fortran-analyze-depth)))
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1953 (forward-line)
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1954 (setq i (1+ i)))
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1955 (cond
26560
edf06ac56d1f (fortran-comment-line-start): Renamed from comment-line-start.
Dave Love <fx@gnu.org>
parents: 25162
diff changeset
1956 ((eq (char-after) ?\t) t)
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1957 ((looking-at " \\{6\\}") nil)
50600
418cea060d92 (fortran-tab-mode-minor-mode-string): Delete this variable,
Glenn Morris <rgm@gnu.org>
parents: 50598
diff changeset
1958 (t fortran-tab-mode-default)))))
1633
65af7bcd5e31 * fortran.el: New version of version 1.30 (!) from Stephen A. Wood
Jim Blandy <jimb@redhat.com>
parents: 1611
diff changeset
1959
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1960 (defun fortran-fill-paragraph (&optional justify)
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1961 "Fill surrounding comment block as paragraphs, else fill statement.
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1962 Intended as the value of `fill-paragraph-function'.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1963 A comment block is filled by calling `fill-comment-paragraph' with
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1964 argument JUSTIFY, otherwise `fortran-fill-statement' is called.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1965 Always returns non-nil (to prevent `fill-paragraph' being called)."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1966 (interactive "*P")
49751
cc3cda196420 (fortran-mode): Set comment-use-syntax.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48815
diff changeset
1967 (or (fill-comment-paragraph justify)
cc3cda196420 (fortran-mode): Set comment-use-syntax.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48815
diff changeset
1968 (fortran-fill-statement)
cc3cda196420 (fortran-mode): Set comment-use-syntax.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48815
diff changeset
1969 t))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1970
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1971 (defun fortran-fill-statement ()
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1972 "Fill a Fortran statement up to `fill-column'."
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1973 (interactive "*")
30149
1c8c6dbfcfb9 Don't require easymenu. Use repeat counts in various regexps.
Dave Love <fx@gnu.org>
parents: 28079
diff changeset
1974 (let ((auto-fill-function #'fortran-auto-fill))
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1975 (unless (save-excursion
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1976 (beginning-of-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1977 (or (looking-at "[ \t]*$")
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1978 (looking-at fortran-comment-line-start-skip)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1979 (and comment-start-skip
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1980 (looking-at (concat "[ \t]*" comment-start-skip)))))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1981 (save-excursion
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1982 ;; Find beginning of statement.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1983 (fortran-next-statement)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1984 (fortran-previous-statement)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1985 ;; Re-indent initially.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1986 (fortran-indent-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1987 ;; Replace newline plus continuation field plus indentation with
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1988 ;; single space.
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1989 (while (progn
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1990 (forward-line)
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1991 (fortran-remove-continuation)))
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1992 (fortran-previous-statement)))
24800
b4bf2212c418 Add :link to defgroup.
Dave Love <fx@gnu.org>
parents: 24254
diff changeset
1993 (fortran-indent-line)))
21410
d68f866455c6 Use regexp-opt and eval-and-compile to
Dave Love <fx@gnu.org>
parents: 21167
diff changeset
1994
45067
b7f97570f3f7 (fortran-strip-sequence-nos): Rename from typo `fortran-strip-sqeuence-nos'.
Glenn Morris <rgm@gnu.org>
parents: 44726
diff changeset
1995 (defun fortran-strip-sequence-nos (&optional do-space)
36171
5d300b531da9 (fortran-strip-sqeuence-nos): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 35244
diff changeset
1996 "Delete all text in column 72 and up (assumed to be sequence numbers).
5d300b531da9 (fortran-strip-sqeuence-nos): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 35244
diff changeset
1997 Normally also deletes trailing whitespace after stripping such text.
5d300b531da9 (fortran-strip-sqeuence-nos): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 35244
diff changeset
1998 Supplying prefix arg DO-SPACE prevents stripping the whitespace."
50598
5f26cbba48ba Whitespace changes, some re-ordering of code, trivial commentary change.
Glenn Morris <rgm@gnu.org>
parents: 50579
diff changeset
1999 (interactive "*p")
26665
4aede027bedb (fortran-strip-sqeuence-nos): New command.
Dave Love <fx@gnu.org>
parents: 26560
diff changeset
2000 (save-excursion
4aede027bedb (fortran-strip-sqeuence-nos): New command.
Dave Love <fx@gnu.org>
parents: 26560
diff changeset
2001 (goto-char (point-min))
35244
682d1ffa0b5e (fortran-mode-map): Modify Customization
Dave Love <fx@gnu.org>
parents: 33947
diff changeset
2002 (while (re-search-forward "^.\\{72\\}\\(.*\\)" nil t)
26665
4aede027bedb (fortran-strip-sqeuence-nos): New command.
Dave Love <fx@gnu.org>
parents: 26560
diff changeset
2003 (replace-match "" nil nil nil 1)
4aede027bedb (fortran-strip-sqeuence-nos): New command.
Dave Love <fx@gnu.org>
parents: 26560
diff changeset
2004 (unless do-space (delete-horizontal-space)))))
4aede027bedb (fortran-strip-sqeuence-nos): New command.
Dave Love <fx@gnu.org>
parents: 26560
diff changeset
2005
28079
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
2006 ;; This code used to live in add-log.el, but this is a better place
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
2007 ;; for it.
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
2008 (defun fortran-current-defun ()
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
2009 "Function to use for `add-log-current-defun-function' in Fortran mode."
46979
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2010 (save-excursion
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2011 ;; We must be inside function body for this to work.
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2012 (fortran-beginning-of-subprogram)
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2013 (let ((case-fold-search t)) ; case-insensitive
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
2014 ;; Search for fortran subprogram start.
46979
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2015 (if (re-search-forward
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2016 (concat "^[ \t]*\\(program\\|subroutine\\|function"
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2017 "\\|[ \ta-z0-9*()]*[ \t]+function\\|"
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2018 "\\(block[ \t]*data\\)\\)")
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2019 (save-excursion (fortran-end-of-subprogram)
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2020 (point))
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2021 t)
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2022 (or (match-string-no-properties 2)
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2023 (progn
50611
5ac877b692fe Comment changes.
Glenn Morris <rgm@gnu.org>
parents: 50600
diff changeset
2024 ;; Move to EOL or before first left paren.
46979
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2025 (if (re-search-forward "[(\n]" nil t)
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2026 (progn (backward-char)
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2027 (skip-chars-backward " \t"))
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2028 (end-of-line))
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2029 ;; Use the name preceding that.
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2030 (buffer-substring-no-properties (point) (progn (backward-sexp)
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2031 (point)))))
0ea82abe061c (fortran-current-defun): Use save-excursion.
Glenn Morris <rgm@gnu.org>
parents: 45345
diff changeset
2032 "main"))))
28079
07cbc9269fbc (fortran-comment-line-start): Define as
Dave Love <fx@gnu.org>
parents: 27417
diff changeset
2033
584
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 332
diff changeset
2034 (provide 'fortran)
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 332
diff changeset
2035
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51618
diff changeset
2036 ;;; arch-tag: 74935096-21c4-4cab-8ee5-6ef16090dc04
660
08eb386dd0f3 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
2037 ;;; fortran.el ends here