annotate lisp/progmodes/perl-mode.el @ 110756:9070b77b4a28

shr.el (shr-insert): Tweak line breaking. shr.el (shr-insert): Handle <pre> better.
author Katsumi Yamaoka <yamaoka@jpl.org>
date Mon, 04 Oct 2010 10:43:14 +0000
parents b10051866f51
children 9aff83bb4de1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
789
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
1 ;;; perl-mode.el --- Perl code editing commands for GNU Emacs
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
2
101002
3b3c7e10cd97 Replace last-command-char with last-command-event.
Glenn Morris <rgm@gnu.org>
parents: 100908
diff changeset
3 ;; Copyright (C) 1990, 1994, 2001, 2002, 2003, 2004, 2005, 2006, 2007,
106815
1d1d5d9bd884 Add 2010 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 106334
diff changeset
4 ;; 2008, 2009, 2010 Free Software Foundation, Inc.
846
20674ae6bf52 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 814
diff changeset
5
789
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
6 ;; Author: William F. Mann
11370
d1dc644021a4 (perl-comment-indent): Make extra space only when
Richard M. Stallman <rms@gnu.org>
parents: 10938
diff changeset
7 ;; Maintainer: FSF
789
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
8 ;; Adapted-By: ESR
814
38b2499cb3e9 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 792
diff changeset
9 ;; Keywords: languages
789
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
10
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
11 ;; Adapted from C code editing commands 'c-mode.el', Copyright 1987 by the
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
12 ;; Free Software Foundation, under terms of its General Public License.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
13
882
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
14 ;; This file is part of GNU Emacs.
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
15
94673
52b7a8c22af5 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93621
diff changeset
16 ;; GNU Emacs is free software: you can redistribute it and/or modify
882
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
17 ;; it under the terms of the GNU General Public License as published by
94673
52b7a8c22af5 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93621
diff changeset
18 ;; the Free Software Foundation, either version 3 of the License, or
52b7a8c22af5 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93621
diff changeset
19 ;; (at your option) any later version.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
20
882
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
21 ;; GNU Emacs is distributed in the hope that it will be useful,
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
22 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
23 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
24 ;; GNU General Public License for more details.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
25
882
bff32d8ecc5e entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 846
diff changeset
26 ;; You should have received a copy of the GNU General Public License
94673
52b7a8c22af5 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93621
diff changeset
27 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
28
789
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
29 ;;; Commentary:
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
30
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
31 ;; To enter perl-mode automatically, add (autoload 'perl-mode "perl-mode")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
32 ;; to your .emacs file and change the first line of your perl script to:
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
33 ;; #!/usr/bin/perl -- # -*-Perl-*-
14040
187735b53d52 Comment fixes.
Karl Heuer <kwzh@gnu.org>
parents: 12677
diff changeset
34 ;; With arguments to perl:
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
35 ;; #!/usr/bin/perl -P- # -*-Perl-*-
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
36 ;; To handle files included with do 'filename.pl';, add something like
9060
7364babe18d2 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 8551
diff changeset
37 ;; (setq auto-mode-alist (append (list (cons "\\.pl\\'" 'perl-mode))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
38 ;; auto-mode-alist))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
39 ;; to your .emacs file; otherwise the .pl suffix defaults to prolog-mode.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
40
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
41 ;; This code is based on the 18.53 version c-mode.el, with extensive
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
42 ;; rewriting. Most of the features of c-mode survived intact.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
43
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
44 ;; I added a new feature which adds functionality to TAB; it is controlled
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
45 ;; by the variable perl-tab-to-comment. With it enabled, TAB does the
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
46 ;; first thing it can from the following list: change the indentation;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
47 ;; move past leading white space; delete an empty comment; reindent a
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
48 ;; comment; move to end of line; create an empty comment; tell you that
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
49 ;; the line ends in a quoted string, or has a # which should be a \#.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
50
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
51 ;; If your machine is slow, you may want to remove some of the bindings
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
52 ;; to perl-electric-terminator. I changed the indenting defaults to be
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
53 ;; what Larry Wall uses in perl/lib, but left in all the options.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
54
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
55 ;; I also tuned a few things: comments and labels starting in column
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
56 ;; zero are left there by perl-indent-exp; perl-beginning-of-function
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
57 ;; goes back to the first open brace/paren in column zero, the open brace
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
58 ;; in 'sub ... {', or the equal sign in 'format ... ='; perl-indent-exp
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
59 ;; (meta-^q) indents from the current line through the close of the next
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
60 ;; brace/paren, so you don't need to start exactly at a brace or paren.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
61
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
62 ;; It may be good style to put a set of redundant braces around your
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
63 ;; main program. This will let you reindent it with meta-^q.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
64
792
45d748a65f24 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 789
diff changeset
65 ;; Known problems (these are all caused by limitations in the Emacs Lisp
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
66 ;; parsing routine (parse-partial-sexp), which was not designed for such
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
67 ;; a rich language; writing a more suitable parser would be a big job):
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
68 ;; 2) The globbing syntax <pattern> is not recognized, so special
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
69 ;; characters in the pattern string must be backslashed.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
70 ;; 3) The << quoting operators are not recognized; see below.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
71 ;; 5) To make '$' work correctly, $' is not recognized as a variable.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
72 ;; Use "$'" or $POSTMATCH instead.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
73 ;;
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
74 ;; If you don't use font-lock, additional problems will appear:
3591
507f64624555 Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents: 2307
diff changeset
75 ;; 1) Regular expression delimiters do not act as quotes, so special
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
76 ;; characters such as `'"#:;[](){} may need to be backslashed
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
77 ;; in regular expressions and in both parts of s/// and tr///.
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
78 ;; 4) The q and qq quoting operators are not recognized; see below.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
79 ;; 5) To make variables such a $' and $#array work, perl-mode treats
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
80 ;; $ just like backslash, so '$' is not treated correctly.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
81 ;; 6) Unfortunately, treating $ like \ makes ${var} be treated as an
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
82 ;; unmatched }. See below.
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
83 ;; 7) When ' (quote) is used as a package name separator, perl-mode
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
84 ;; doesn't understand, and thinks it is seeing a quoted string.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
85
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
86 ;; Here are some ugly tricks to bypass some of these problems: the perl
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
87 ;; expression /`/ (that's a back-tick) usually evaluates harmlessly,
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
88 ;; but will trick perl-mode into starting a quoted string, which
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
89 ;; can be ended with another /`/. Assuming you have no embedded
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
90 ;; back-ticks, this can used to help solve problem 3:
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
91 ;;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
92 ;; /`/; $ugly = q?"'$?; /`/;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
93 ;;
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
94 ;; The same trick can be used for problem 6 as in:
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
95 ;; /{/; while (<${glob_me}>)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
96 ;; but a simpler solution is to add a space between the $ and the {:
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
97 ;; while (<$ {glob_me}>)
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
98 ;;
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
99 ;; Problem 7 is even worse, but this 'fix' does work :-(
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
100 ;; $DB'stop#'
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
101 ;; [$DB'line#'
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
102 ;; ] =~ s/;9$//;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
103
789
71d052f72ac1 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 475
diff changeset
104 ;;; Code:
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
105
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
106 (eval-when-compile (require 'cl))
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
107
65237
33613253f37e (font-lock-comment-face, font-lock-doc-face, font-lock-string-face):
Juanma Barranquero <lekktu@gmail.com>
parents: 64699
diff changeset
108 (defvar font-lock-comment-face)
33613253f37e (font-lock-comment-face, font-lock-doc-face, font-lock-string-face):
Juanma Barranquero <lekktu@gmail.com>
parents: 64699
diff changeset
109 (defvar font-lock-doc-face)
33613253f37e (font-lock-comment-face, font-lock-doc-face, font-lock-string-face):
Juanma Barranquero <lekktu@gmail.com>
parents: 64699
diff changeset
110 (defvar font-lock-string-face)
33613253f37e (font-lock-comment-face, font-lock-doc-face, font-lock-string-face):
Juanma Barranquero <lekktu@gmail.com>
parents: 64699
diff changeset
111
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
112 (defgroup perl nil
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
113 "Major mode for editing Perl code."
66963
a11fdee52c05 Add :link (custom-group-link font-lock-faces) to defgroup.
Juri Linkov <juri@jurta.org>
parents: 66638
diff changeset
114 :link '(custom-group-link :tag "Font Lock Faces group" font-lock-faces)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
115 :prefix "perl-"
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
116 :group 'languages)
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
117
42896
b97054e2d931 (perl-mode-abbrev-table): Restore definition.
Richard M. Stallman <rms@gnu.org>
parents: 41346
diff changeset
118 (defvar perl-mode-abbrev-table nil
b97054e2d931 (perl-mode-abbrev-table): Restore definition.
Richard M. Stallman <rms@gnu.org>
parents: 41346
diff changeset
119 "Abbrev table in use in perl-mode buffers.")
b97054e2d931 (perl-mode-abbrev-table): Restore definition.
Richard M. Stallman <rms@gnu.org>
parents: 41346
diff changeset
120 (define-abbrev-table 'perl-mode-abbrev-table ())
b97054e2d931 (perl-mode-abbrev-table): Restore definition.
Richard M. Stallman <rms@gnu.org>
parents: 41346
diff changeset
121
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
122 (defvar perl-mode-map
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
123 (let ((map (make-sparse-keymap)))
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
124 (define-key map "{" 'perl-electric-terminator)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
125 (define-key map "}" 'perl-electric-terminator)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
126 (define-key map ";" 'perl-electric-terminator)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
127 (define-key map ":" 'perl-electric-terminator)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
128 (define-key map "\e\C-a" 'perl-beginning-of-function)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
129 (define-key map "\e\C-e" 'perl-end-of-function)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
130 (define-key map "\e\C-h" 'perl-mark-function)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
131 (define-key map "\e\C-q" 'perl-indent-exp)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
132 (define-key map "\177" 'backward-delete-char-untabify)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
133 (define-key map "\t" 'perl-indent-command)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
134 map)
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
135 "Keymap used in Perl mode.")
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
136
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
137 (autoload 'c-macro-expand "cmacexp"
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
138 "Display the result of expanding all C macros occurring in the region.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
139 The expansion is entirely correct because it uses the C preprocessor."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
140 t)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
141
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
142 (defvar perl-mode-syntax-table
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
143 (let ((st (make-syntax-table (standard-syntax-table))))
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
144 (modify-syntax-entry ?\n ">" st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
145 (modify-syntax-entry ?# "<" st)
47955
db56d4bb5e01 (perl-mode-syntax-table): Change $ back to just "/" instead of "/ p".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47469
diff changeset
146 ;; `$' is also a prefix char so I was tempted to say "/ p",
db56d4bb5e01 (perl-mode-syntax-table): Change $ back to just "/" instead of "/ p".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47469
diff changeset
147 ;; but the `p' thingy basically overrides the `/' :-( --stef
db56d4bb5e01 (perl-mode-syntax-table): Change $ back to just "/" instead of "/ p".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47469
diff changeset
148 (modify-syntax-entry ?$ "/" st)
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
149 (modify-syntax-entry ?% ". p" st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
150 (modify-syntax-entry ?@ ". p" st)
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
151 (modify-syntax-entry ?& "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
152 (modify-syntax-entry ?\' "\"" st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
153 (modify-syntax-entry ?* "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
154 (modify-syntax-entry ?+ "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
155 (modify-syntax-entry ?- "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
156 (modify-syntax-entry ?/ "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
157 (modify-syntax-entry ?< "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
158 (modify-syntax-entry ?= "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
159 (modify-syntax-entry ?> "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
160 (modify-syntax-entry ?\\ "\\" st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
161 (modify-syntax-entry ?` "\"" st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
162 (modify-syntax-entry ?| "." st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
163 st)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
164 "Syntax table in use in `perl-mode' buffers.")
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
165
12677
1504d644c6bc (perl-imenu-generic-expression) New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11370
diff changeset
166 (defvar perl-imenu-generic-expression
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
167 '(;; Functions
60300
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
168 (nil "^sub\\s-+\\([-A-Za-z0-9+_:]+\\)" 1)
12677
1504d644c6bc (perl-imenu-generic-expression) New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11370
diff changeset
169 ;;Variables
60300
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
170 ("Variables" "^\\([$@%][-A-Za-z0-9+_:]+\\)\\s-*=" 1)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
171 ("Packages" "^package\\s-+\\([-A-Za-z0-9+_:]+\\);" 1)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
172 ("Doc sections" "^=head[0-9][ \t]+\\(.*\\)" 1))
12677
1504d644c6bc (perl-imenu-generic-expression) New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11370
diff changeset
173 "Imenu generic expression for Perl mode. See `imenu-generic-expression'.")
1504d644c6bc (perl-imenu-generic-expression) New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11370
diff changeset
174
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
175 ;; Regexps updated with help from Tom Tromey <tromey@cambric.colorado.edu> and
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
176 ;; Jim Campbell <jec@murzim.ca.boeing.com>.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
177
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
178 (defconst perl-font-lock-keywords-1
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
179 '(;; What is this for?
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
180 ;;("\\(--- .* ---\\|=== .* ===\\)" . font-lock-string-face)
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
181 ;;
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
182 ;; Fontify preprocessor statements as we do in `c-font-lock-keywords'.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
183 ;; Ilya Zakharevich <ilya@math.ohio-state.edu> thinks this is a bad idea.
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
184 ;; ("^#[ \t]*include[ \t]+\\(<[^>\"\n]+>\\)" 1 font-lock-string-face)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
185 ;; ("^#[ \t]*define[ \t]+\\(\\sw+\\)(" 1 font-lock-function-name-face)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
186 ;; ("^#[ \t]*if\\>"
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
187 ;; ("\\<\\(defined\\)\\>[ \t]*(?\\(\\sw+\\)?" nil nil
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
188 ;; (1 font-lock-constant-face) (2 font-lock-variable-name-face nil t)))
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
189 ;; ("^#[ \t]*\\(\\sw+\\)\\>[ \t]*\\(\\sw+\\)?"
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
190 ;; (1 font-lock-constant-face) (2 font-lock-variable-name-face nil t))
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
191 ;;
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
192 ;; Fontify function and package names in declarations.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
193 ("\\<\\(package\\|sub\\)\\>[ \t]*\\(\\sw+\\)?"
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
194 (1 font-lock-keyword-face) (2 font-lock-function-name-face nil t))
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
195 ("\\<\\(import\\|no\\|require\\|use\\)\\>[ \t]*\\(\\sw+\\)?"
20953
f3f9df46d008 Changed font-lock-reference-face to font-lock-constant-face.
Simon Marshall <simon@gnu.org>
parents: 20459
diff changeset
196 (1 font-lock-keyword-face) (2 font-lock-constant-face nil t)))
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
197 "Subdued level highlighting for Perl mode.")
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
198
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
199 (defconst perl-font-lock-keywords-2
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
200 (append perl-font-lock-keywords-1
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
201 (list
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
202 ;;
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
203 ;; Fontify keywords, except those fontified otherwise.
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
204 (concat "\\<"
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
205 (regexp-opt '("if" "until" "while" "elsif" "else" "unless"
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
206 "do" "dump" "for" "foreach" "exit" "die"
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
207 "BEGIN" "END" "return" "exec" "eval") t)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
208 "\\>")
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
209 ;;
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
210 ;; Fontify local and my keywords as types.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
211 '("\\<\\(local\\|my\\)\\>" . font-lock-type-face)
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
212 ;;
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
213 ;; Fontify function, variable and file name references.
60825
cd1a709e8af3 (perl-font-lock-keywords-2):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60762
diff changeset
214 '("&\\(\\sw+\\(::\\sw+\\)*\\)" 1 font-lock-function-name-face)
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
215 ;; Additionally underline non-scalar variables. Maybe this is a bad idea.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
216 ;;'("[$@%*][#{]?\\(\\sw+\\)" 1 font-lock-variable-name-face)
60825
cd1a709e8af3 (perl-font-lock-keywords-2):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60762
diff changeset
217 '("[$*]{?\\(\\sw+\\(::\\sw+\\)*\\)" 1 font-lock-variable-name-face)
cd1a709e8af3 (perl-font-lock-keywords-2):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60762
diff changeset
218 '("\\([@%]\\|\\$#\\)\\(\\sw+\\(::\\sw+\\)*\\)"
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
219 (2 (cons font-lock-variable-name-face '(underline))))
20953
f3f9df46d008 Changed font-lock-reference-face to font-lock-constant-face.
Simon Marshall <simon@gnu.org>
parents: 20459
diff changeset
220 '("<\\(\\sw+\\)>" 1 font-lock-constant-face)
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
221 ;;
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
222 ;; Fontify keywords with/and labels as we do in `c++-font-lock-keywords'.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
223 '("\\<\\(continue\\|goto\\|last\\|next\\|redo\\)\\>[ \t]*\\(\\sw+\\)?"
20953
f3f9df46d008 Changed font-lock-reference-face to font-lock-constant-face.
Simon Marshall <simon@gnu.org>
parents: 20459
diff changeset
224 (1 font-lock-keyword-face) (2 font-lock-constant-face nil t))
f3f9df46d008 Changed font-lock-reference-face to font-lock-constant-face.
Simon Marshall <simon@gnu.org>
parents: 20459
diff changeset
225 '("^[ \t]*\\(\\sw+\\)[ \t]*:[^:]" 1 font-lock-constant-face)))
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
226 "Gaudy level highlighting for Perl mode.")
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
227
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
228 (defvar perl-font-lock-keywords perl-font-lock-keywords-1
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
229 "Default expressions to highlight in Perl mode.")
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
230
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
231 (defvar perl-quote-like-pairs
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
232 '((?\( . ?\)) (?\[ . ?\]) (?\{ . ?\}) (?\< . ?\>)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
233
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
234 ;; FIXME: handle here-docs and regexps.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
235 ;; <<EOF <<"EOF" <<'EOF' (no space)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
236 ;; see `man perlop'
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
237 ;; ?...?
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
238 ;; /.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
239 ;; m [...]
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
240 ;; m /.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
241 ;; q /.../ = '...'
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
242 ;; qq /.../ = "..."
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
243 ;; qx /.../ = `...`
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
244 ;; qr /.../ = precompiled regexp =~=~ m/.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
245 ;; qw /.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
246 ;; s /.../.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
247 ;; s <...> /.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
248 ;; s '...'...'
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
249 ;; tr /.../.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
250 ;; y /.../.../
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
251 ;;
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
252 ;; <file*glob>
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
253 (defun perl-syntax-propertize-function (start end)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
254 (let ((case-fold-search nil))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
255 (goto-char start)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
256 (perl-syntax-propertize-special-constructs end)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
257 ;; TODO: here-documents ("<<\\(\\sw\\|['\"]\\)")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
258 (funcall
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
259 (syntax-propertize-rules
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
260 ;; Turn POD into b-style comments. Place the cut rule first since it's
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
261 ;; more specific.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
262 ("^=cut\\>.*\\(\n\\)" (1 "> b"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
263 ("^\\(=\\)\\sw" (1 "< b"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
264 ;; Catch ${ so that ${var} doesn't screw up indentation.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
265 ;; This also catches $' to handle 'foo$', although it should really
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
266 ;; check that it occurs inside a '..' string.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
267 ("\\(\\$\\)[{']" (1 ". p"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
268 ;; Handle funny names like $DB'stop.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
269 ("\\$ ?{?^?[_a-zA-Z][_a-zA-Z0-9]*\\('\\)[_a-zA-Z]" (1 "_"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
270 ;; format statements
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
271 ("^[ \t]*format.*=[ \t]*\\(\n\\)"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
272 (1 (prog1 "\"" (perl-syntax-propertize-special-constructs end))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
273 ;; Funny things in `sub' arg-specs like `sub myfun ($)' or `sub ($)'.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
274 ;; Be careful not to match "sub { (...) ... }".
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
275 ("\\<sub\\(?:[[:space:]]+[^{}[:punct:][:space:]]+\\)?[[:space:]]*(\\([^)]+\\))"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
276 (1 "."))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
277 ;; Regexp and funny quotes. Distinguishing a / that starts a regexp
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
278 ;; match from the division operator is ...interesting.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
279 ;; Basically, / is a regexp match if it's preceded by an infix operator
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
280 ;; (or some similar separator), or by one of the special keywords
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
281 ;; corresponding to builtin functions that can take their first arg
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
282 ;; without parentheses. Of course, that presume we're looking at the
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
283 ;; *opening* slash. We can afford to mis-match the closing ones
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
284 ;; here, because they will be re-treated separately later in
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
285 ;; perl-font-lock-special-syntactic-constructs.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
286 ((concat "\\(?:\\(?:^\\|[^$@&%[:word:]]\\)"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
287 (regexp-opt '("split" "if" "unless" "until" "while" "split"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
288 "grep" "map" "not" "or" "and"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
289 "\\|[?:.,;=!~({[]\\|\\(^\\)\\)[ \t\n]*\\(/\\)")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
290 (2 (ignore
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
291 (if (and (match-end 1) ; / at BOL.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
292 (save-excursion
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
293 (goto-char (match-end 1))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
294 (forward-comment (- (point-max)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
295 (put-text-property (point) (match-end 2)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
296 'syntax-multiline t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
297 (not (memq (char-before)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
298 '(?? ?: ?. ?, ?\; ?= ?! ?~ ?\( ?\[)))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
299 nil ;; A division sign instead of a regexp-match.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
300 (put-text-property (match-beginning 2) (match-end 2)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
301 'syntax-table (string-to-syntax "\""))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
302 (perl-syntax-propertize-special-constructs end)))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
303 ("\\(^\\|[?:.,;=!~({[ \t]\\)\\([msy]\\|q[qxrw]?\\|tr\\)\\>\\s-*\\([^])}> \n\t]\\)"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
304 ;; Nasty cases:
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
305 ;; /foo/m $a->m $#m $m @m %m
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
306 ;; \s (appears often in regexps).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
307 ;; -s file
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
308 ;; sub tr {...}
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
309 (3 (ignore
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
310 (if (save-excursion (goto-char (match-beginning 0))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
311 (forward-word -1)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
312 (looking-at-p "sub[ \t\n]"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
313 ;; This is defining a function.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
314 nil
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
315 (put-text-property (match-beginning 3) (match-end 3)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
316 'syntax-table
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
317 (if (assoc (char-after (match-beginning 3))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
318 perl-quote-like-pairs)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
319 (string-to-syntax "|")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
320 (string-to-syntax "\"")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
321 (perl-syntax-propertize-special-constructs end))))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
322 (point) end)))
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
323
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
324 (defvar perl-empty-syntax-table
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
325 (let ((st (copy-syntax-table)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
326 ;; Make all chars be of punctuation syntax.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
327 (dotimes (i 256) (aset st i '(1)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
328 (modify-syntax-entry ?\\ "\\" st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
329 st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
330 "Syntax table used internally for processing quote-like operators.")
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
331
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
332 (defun perl-quote-syntax-table (char)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
333 (let ((close (cdr (assq char perl-quote-like-pairs)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
334 (st (copy-syntax-table perl-empty-syntax-table)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
335 (if (not close)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
336 (modify-syntax-entry char "\"" st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
337 (modify-syntax-entry char "(" st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
338 (modify-syntax-entry close ")" st))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
339 st))
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
340
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
341 (defun perl-syntax-propertize-special-constructs (limit)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
342 "Propertize special constructs like regexps and formats."
66638
4ac8c6441408 (perl-font-lock-special-syntactic-constructs):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65358
diff changeset
343 (let ((state (syntax-ppss))
4ac8c6441408 (perl-font-lock-special-syntactic-constructs):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65358
diff changeset
344 char)
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
345 (cond
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
346 ((or (null (setq char (nth 3 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
347 (and (characterp char) (eq (char-syntax (nth 3 state)) ?\")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
348 ;; Normal text, or comment, or docstring, or normal string.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
349 nil)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
350 ((eq (nth 3 state) ?\n)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
351 ;; A `format' command.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
352 (when (re-search-forward "^\\s *\\.\\s *\n" limit 'move)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
353 (put-text-property (1- (point)) (point)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
354 'syntax-table (string-to-syntax "\""))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
355 (t
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
356 ;; This is regexp like quote thingy.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
357 (setq char (char-after (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
358 (let ((twoargs (save-excursion
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
359 (goto-char (nth 8 state))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
360 (skip-syntax-backward " ")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
361 (skip-syntax-backward "w")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
362 (member (buffer-substring
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
363 (point) (progn (forward-word 1) (point)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
364 '("tr" "s" "y"))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
365 (close (cdr (assq char perl-quote-like-pairs)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
366 (st (perl-quote-syntax-table char)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
367 (when (with-syntax-table st
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
368 (if close
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
369 ;; For paired delimiters, Perl allows nesting them, but
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
370 ;; since we treat them as strings, Emacs does not count
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
371 ;; those delimiters in `state', so we don't know how deep
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
372 ;; we are: we have to go back to the beginning of this
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
373 ;; "string" and count from there.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
374 (condition-case nil
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
375 (progn
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
376 ;; Start after the first char since it doesn't have
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
377 ;; paren-syntax (an alternative would be to let-bind
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
378 ;; parse-sexp-lookup-properties).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
379 (goto-char (1+ (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
380 (up-list 1)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
381 t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
382 (scan-error nil))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
383 (not (or (nth 8 (parse-partial-sexp
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
384 (point) limit nil nil state 'syntax-table))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
385 ;; If we have a self-paired opener and a twoargs
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
386 ;; command, the form is s/../../ so we have to skip
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
387 ;; a second time.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
388 ;; In the case of s{...}{...}, we only handle the
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
389 ;; first part here and the next below.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
390 (when (and twoargs (not close))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
391 (nth 8 (parse-partial-sexp
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
392 (point) limit
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
393 nil nil state 'syntax-table)))))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
394 ;; Point is now right after the arg(s).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
395 (when (eq (char-before (1- (point))) ?$)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
396 (put-text-property (- (point) 2) (1- (point))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
397 'syntax-table '(1)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
398 (put-text-property (1- (point)) (point)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
399 'syntax-table
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
400 (if close
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
401 (string-to-syntax "|")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
402 (string-to-syntax "\"")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
403 ;; If we have two args with a non-self-paired starter (e.g.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
404 ;; s{...}{...}) we're right after the first arg, so we still have to
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
405 ;; handle the second part.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
406 (when (and twoargs close)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
407 ;; Skip whitespace and make sure that font-lock will
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
408 ;; refontify the second part in the proper context.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
409 (put-text-property
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
410 (point) (progn (forward-comment (point-max)) (point))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
411 'syntax-multiline t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
412 ;;
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
413 (when (< (point) limit)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
414 (put-text-property (point) (1+ (point))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
415 'syntax-table
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
416 (if (assoc (char-after)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
417 perl-quote-like-pairs)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
418 ;; Put an `e' in the cdr to mark this
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
419 ;; char as "second arg starter".
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
420 (string-to-syntax "|e")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
421 (string-to-syntax "\"e")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
422 (forward-char 1)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
423 ;; Re-use perl-syntax-propertize-special-constructs to handle the
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
424 ;; second part (the first delimiter of second part can't be
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
425 ;; preceded by "s" or "tr" or "y", so it will not be considered
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
426 ;; as twoarg).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
427 (perl-syntax-propertize-special-constructs limit)))))))))
66638
4ac8c6441408 (perl-font-lock-special-syntactic-constructs):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65358
diff changeset
428
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
429 (defun perl-font-lock-syntactic-face-function (state)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
430 (cond
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
431 ((and (nth 3 state)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
432 (eq ?e (cdr-safe (get-text-property (nth 8 state) 'syntax-table)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
433 ;; This is a second-arg of s{..}{...} form; let's check if this second
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
434 ;; arg is executable code rather than a string. For that, we need to
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
435 ;; look for an "e" after this second arg, so we have to hunt for the
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
436 ;; end of the arg. Depending on whether the whole arg has already
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
437 ;; been syntax-propertized or not, the end-char will have different
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
438 ;; syntaxes, so let's ignore syntax-properties temporarily so we can
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
439 ;; pretend it has not been syntax-propertized yet.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
440 (let* ((parse-sexp-lookup-properties nil)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
441 (char (char-after (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
442 (paired (assq char perl-quote-like-pairs)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
443 (with-syntax-table (perl-quote-syntax-table char)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
444 (save-excursion
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
445 (if (not paired)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
446 (parse-partial-sexp (point) (point-max)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
447 nil nil state 'syntax-table)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
448 (condition-case nil
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
449 (progn
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
450 (goto-char (1+ (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
451 (up-list 1))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
452 (scan-error (goto-char (point-max)))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
453 (put-text-property (nth 8 state) (point)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
454 'jit-lock-defer-multiline t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
455 (looking-at "[ \t]*\\sw*e")))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
456 nil)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
457 (t (funcall (default-value 'font-lock-syntactic-face-function) state))))
9386
17dfca2d42e2 (perl-font-lock-keywords): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 9060
diff changeset
458
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
459 (defcustom perl-indent-level 4
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
460 "*Indentation of Perl statements with respect to containing block."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
461 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
462 :group 'perl)
78660
ccfc1f1f4817 * progmodes/cperl-mode.el (cperl-indent-level): Autoload the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78571
diff changeset
463
79553
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
464 ;; Is is not unusual to put both things like perl-indent-level and
78660
ccfc1f1f4817 * progmodes/cperl-mode.el (cperl-indent-level): Autoload the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78571
diff changeset
465 ;; cperl-indent-level in the local variable section of a file. If only
ccfc1f1f4817 * progmodes/cperl-mode.el (cperl-indent-level): Autoload the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78571
diff changeset
466 ;; one of perl-mode and cperl-mode is in use, a warning will be issued
79553
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
467 ;; about the variable. Autoload these here, so that no warning is
78660
ccfc1f1f4817 * progmodes/cperl-mode.el (cperl-indent-level): Autoload the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78571
diff changeset
468 ;; issued when using either perl-mode or cperl-mode.
ccfc1f1f4817 * progmodes/cperl-mode.el (cperl-indent-level): Autoload the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78571
diff changeset
469 ;;;###autoload(put 'perl-indent-level 'safe-local-variable 'integerp)
79553
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
470 ;;;###autoload(put 'perl-continued-statement-offset 'safe-local-variable 'integerp)
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
471 ;;;###autoload(put 'perl-continued-brace-offset 'safe-local-variable 'integerp)
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
472 ;;;###autoload(put 'perl-brace-offset 'safe-local-variable 'integerp)
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
473 ;;;###autoload(put 'perl-brace-imaginary-offset 'safe-local-variable 'integerp)
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
474 ;;;###autoload(put 'perl-label-offset 'safe-local-variable 'integerp)
78660
ccfc1f1f4817 * progmodes/cperl-mode.el (cperl-indent-level): Autoload the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78571
diff changeset
475
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
476 (defcustom perl-continued-statement-offset 4
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
477 "*Extra indent for lines not starting new statements."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
478 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
479 :group 'perl)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
480 (defcustom perl-continued-brace-offset -4
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
481 "*Extra indent for substatements that start with open-braces.
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
482 This is in addition to `perl-continued-statement-offset'."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
483 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
484 :group 'perl)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
485 (defcustom perl-brace-offset 0
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
486 "*Extra indentation for braces, compared with other text in same context."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
487 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
488 :group 'perl)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
489 (defcustom perl-brace-imaginary-offset 0
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
490 "*Imagined indentation of an open brace that actually follows a statement."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
491 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
492 :group 'perl)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
493 (defcustom perl-label-offset -2
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
494 "*Offset of Perl label lines relative to usual indentation."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
495 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
496 :group 'perl)
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
497 (defcustom perl-indent-continued-arguments nil
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
498 "*If non-nil offset of argument lines relative to usual indentation.
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
499 If nil, continued arguments are aligned with the first argument."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
500 :type '(choice integer (const nil))
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
501 :group 'perl)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
502
51054
cd2cb7e0cc7e (perl-tab-always-indent): Default to tab-always-indent.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 49598
diff changeset
503 (defcustom perl-tab-always-indent tab-always-indent
cd2cb7e0cc7e (perl-tab-always-indent): Default to tab-always-indent.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 49598
diff changeset
504 "Non-nil means TAB in Perl mode always indents the current line.
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
505 Otherwise it inserts a tab character if you type it past the first
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
506 nonwhite character on the line."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
507 :type 'boolean
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
508 :group 'perl)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
509
10807
50f00b298a2d (perl-tab-to-comment): Default is nil.
Richard M. Stallman <rms@gnu.org>
parents: 9480
diff changeset
510 ;; I changed the default to nil for consistency with general Emacs
50f00b298a2d (perl-tab-to-comment): Default is nil.
Richard M. Stallman <rms@gnu.org>
parents: 9480
diff changeset
511 ;; conventions -- rms.
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
512 (defcustom perl-tab-to-comment nil
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
513 "*Non-nil means TAB moves to eol or makes a comment in some cases.
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
514 For lines which don't need indenting, TAB either indents an
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
515 existing comment, moves to end-of-line, or if at end-of-line already,
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
516 create a new comment."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
517 :type 'boolean
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
518 :group 'perl)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
519
59328
7f974399bee1 (perl-nochange, perl-calculate-indent):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59249
diff changeset
520 (defcustom perl-nochange ";?#\\|\f\\|\\s(\\|\\(\\w\\|\\s_\\)+:[^:]"
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
521 "*Lines starting with this regular expression are not auto-indented."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
522 :type 'regexp
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
523 :group 'perl)
60300
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
524
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
525 ;; Outline support
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
526
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
527 (defvar perl-outline-regexp
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
528 (concat (mapconcat 'cadr perl-imenu-generic-expression "\\|")
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
529 "\\|^=cut\\>"))
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
530
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
531 (defun perl-outline-level ()
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
532 (cond
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
533 ((looking-at "package\\s-") 0)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
534 ((looking-at "sub\\s-") 1)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
535 ((looking-at "=head[0-9]") (- (char-before (match-end 0)) ?0))
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
536 ((looking-at "=cut") 1)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
537 (t 3)))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
538
60693
0dab980fb0b7 (perl-mode-hook): Defvar it.
Richard M. Stallman <rms@gnu.org>
parents: 60300
diff changeset
539 (defvar perl-mode-hook nil
0dab980fb0b7 (perl-mode-hook): Defvar it.
Richard M. Stallman <rms@gnu.org>
parents: 60300
diff changeset
540 "Normal hook to run when entering Perl mode.")
0dab980fb0b7 (perl-mode-hook): Defvar it.
Richard M. Stallman <rms@gnu.org>
parents: 60300
diff changeset
541
21857
a22711be4750 (perl-mode): Add autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents: 20960
diff changeset
542 ;;;###autoload
41346
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
543 (defun perl-mode ()
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
544 "Major mode for editing Perl code.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
545 Expression and list commands understand all Perl brackets.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
546 Tab indents for Perl code.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
547 Comments are delimited with # ... \\n.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
548 Paragraphs are separated by blank lines only.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
549 Delete converts tabs to spaces as it moves back.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
550 \\{perl-mode-map}
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
551 Variables controlling indentation style:
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
552 `perl-tab-always-indent'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
553 Non-nil means TAB in Perl mode should always indent the current line,
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
554 regardless of where in the line point is when the TAB command is used.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
555 `perl-tab-to-comment'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
556 Non-nil means that for lines which don't need indenting, TAB will
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
557 either delete an empty comment, indent an existing comment, move
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
558 to end-of-line, or if at end-of-line already, create a new comment.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
559 `perl-nochange'
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
560 Lines starting with this regular expression are not auto-indented.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
561 `perl-indent-level'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
562 Indentation of Perl statements within surrounding block.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
563 The surrounding block's indentation is the indentation
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
564 of the line on which the open-brace appears.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
565 `perl-continued-statement-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
566 Extra indentation given to a substatement, such as the
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
567 then-clause of an if or body of a while.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
568 `perl-continued-brace-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
569 Extra indentation given to a brace that starts a substatement.
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
570 This is in addition to `perl-continued-statement-offset'.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
571 `perl-brace-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
572 Extra indentation for line if it starts with an open brace.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
573 `perl-brace-imaginary-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
574 An open brace following other text is treated as if it were
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
575 this far to the right of the start of its line.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
576 `perl-label-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
577 Extra indentation for line that is a label.
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
578 `perl-indent-continued-arguments'
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
579 Offset of argument lines relative to usual indentation.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
580
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
581 Various indentation styles: K&R BSD BLK GNU LW
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
582 perl-indent-level 5 8 0 2 4
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
583 perl-continued-statement-offset 5 8 4 2 4
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
584 perl-continued-brace-offset 0 0 0 0 -4
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
585 perl-brace-offset -5 -8 0 0 0
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
586 perl-brace-imaginary-offset 0 0 4 0 0
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
587 perl-label-offset -5 -8 -2 -2 -2
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
588
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
589 Turning on Perl mode runs the normal hook `perl-mode-hook'."
41346
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
590 (interactive)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
591 (kill-all-local-variables)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
592 (use-local-map perl-mode-map)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
593 (setq major-mode 'perl-mode)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
594 (setq mode-name "Perl")
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
595 (setq local-abbrev-table perl-mode-abbrev-table)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
596 (set-syntax-table perl-mode-syntax-table)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
597 (make-local-variable 'paragraph-start)
10889
de7673bb5d19 (perl-mode): Remove ^ from paragraph-start & paragraph-separate.
Boris Goldowsky <boris@gnu.org>
parents: 10807
diff changeset
598 (setq paragraph-start (concat "$\\|" page-delimiter))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
599 (make-local-variable 'paragraph-separate)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
600 (setq paragraph-separate paragraph-start)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
601 (make-local-variable 'paragraph-ignore-fill-prefix)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
602 (setq paragraph-ignore-fill-prefix t)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
603 (make-local-variable 'indent-line-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
604 (setq indent-line-function 'perl-indent-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
605 (make-local-variable 'require-final-newline)
59249
ccfc48223233 (perl-mode): Use mode-require-final-newline.
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
606 (setq require-final-newline mode-require-final-newline)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
607 (make-local-variable 'comment-start)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
608 (setq comment-start "# ")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
609 (make-local-variable 'comment-end)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
610 (setq comment-end "")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
611 (make-local-variable 'comment-start-skip)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
612 (setq comment-start-skip "\\(^\\|\\s-\\);?#+ *")
2307
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 882
diff changeset
613 (make-local-variable 'comment-indent-function)
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 882
diff changeset
614 (setq comment-indent-function 'perl-comment-indent)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
615 (make-local-variable 'parse-sexp-ignore-comments)
5922
79d326d2da22 (perl-mode): Set parse-sexp-ignore-comments.
Richard M. Stallman <rms@gnu.org>
parents: 5589
diff changeset
616 (setq parse-sexp-ignore-comments t)
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
617 ;; Tell font-lock.el how to handle Perl.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
618 (setq font-lock-defaults '((perl-font-lock-keywords
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
619 perl-font-lock-keywords-1
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
620 perl-font-lock-keywords-2)
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
621 nil nil ((?\_ . "w")) nil
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
622 (font-lock-syntactic-face-function
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
623 . perl-font-lock-syntactic-face-function)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
624 (set (make-local-variable 'syntax-propertize-function)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
625 #'perl-syntax-propertize-function)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
626 (add-hook 'syntax-propertize-extend-region-functions
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
627 #'syntax-propertize-multiline 'append 'local)
12677
1504d644c6bc (perl-imenu-generic-expression) New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11370
diff changeset
628 ;; Tell imenu how to handle Perl.
60300
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
629 (set (make-local-variable 'imenu-generic-expression)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
630 perl-imenu-generic-expression)
41346
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
631 (setq imenu-case-fold-search nil)
60300
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
632 ;; Setup outline-minor-mode.
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
633 (set (make-local-variable 'outline-regexp) perl-outline-regexp)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
634 (set (make-local-variable 'outline-level) 'perl-outline-level)
60693
0dab980fb0b7 (perl-mode-hook): Defvar it.
Richard M. Stallman <rms@gnu.org>
parents: 60300
diff changeset
635 (run-mode-hooks 'perl-mode-hook))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
636
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
637 ;; This is used by indent-for-comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
638 ;; to decide how much to indent a comment in Perl code
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
639 ;; based on its context.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
640 (defun perl-comment-indent ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
641 (if (and (bolp) (not (eolp)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
642 0 ;Existing comment at bol stays there.
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
643 comment-column))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
644
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
645 (defalias 'electric-perl-terminator 'perl-electric-terminator)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
646 (defun perl-electric-terminator (arg)
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
647 "Insert character and adjust indentation.
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
648 If at end-of-line, and not in a comment or a quote, correct the's indentation."
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
649 (interactive "P")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
650 (let ((insertpos (point)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
651 (and (not arg) ; decide whether to indent
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
652 (eolp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
653 (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
654 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
655 (and (not ; eliminate comments quickly
16472
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
656 (and comment-start-skip
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
657 (re-search-forward comment-start-skip insertpos t)) )
101002
3b3c7e10cd97 Replace last-command-char with last-command-event.
Glenn Morris <rgm@gnu.org>
parents: 100908
diff changeset
658 (or (/= last-command-event ?:)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
659 ;; Colon is special only after a label ....
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
660 (looking-at "\\s-*\\(\\w\\|\\s_\\)+$"))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
661 (let ((pps (parse-partial-sexp
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
662 (perl-beginning-of-function) insertpos)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
663 (not (or (nth 3 pps) (nth 4 pps) (nth 5 pps))))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
664 (progn ; must insert, indent, delete
101002
3b3c7e10cd97 Replace last-command-char with last-command-event.
Glenn Morris <rgm@gnu.org>
parents: 100908
diff changeset
665 (insert-char last-command-event 1)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
666 (perl-indent-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
667 (delete-char -1))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
668 (self-insert-command (prefix-numeric-value arg)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
669
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
670 ;; not used anymore, but may be useful someday:
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
671 ;;(defun perl-inside-parens-p ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
672 ;; (condition-case ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
673 ;; (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
674 ;; (save-restriction
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
675 ;; (narrow-to-region (point)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
676 ;; (perl-beginning-of-function))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
677 ;; (goto-char (point-max))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
678 ;; (= (char-after (or (scan-lists (point) -1 1) (point-min))) ?\()))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
679 ;; (error nil)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
680
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
681 (defun perl-indent-command (&optional arg)
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
682 "Indent Perl code in the active region or current line.
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
683 In Transient Mark mode, when the region is active, reindent the region.
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
684 Otherwise, with a prefix argument, reindent the current line
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
685 unconditionally.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
686
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
687 Otherwise, if `perl-tab-always-indent' is nil and point is not in
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
688 the indentation area at the beginning of the line, insert a tab.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
689
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
690 Otherwise, indent the current line. If point was within the
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
691 indentation area, it is moved to the end of the indentation area.
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
692 If the line was already indented properly and point was not
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
693 within the indentation area, and if `perl-tab-to-comment' is
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
694 non-nil (the default), then do the first possible action from the
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
695 following list:
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
696
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
697 1) delete an empty comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
698 2) move forward to start of comment, indenting if necessary
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
699 3) move forward to end of line
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
700 4) create an empty comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
701 5) move backward to start of comment, indenting if necessary."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
702 (interactive "P")
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
703 (cond ((use-region-p) ; indent the active region
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
704 (indent-region (region-beginning) (region-end)))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
705 (arg
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
706 (perl-indent-line "\f")) ; just indent this line
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
707 ((and (not perl-tab-always-indent)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
708 (> (current-column) (current-indentation)))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
709 (insert-tab))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
710 (t
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
711 (let* ((oldpnt (point))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
712 (lsexp (progn (beginning-of-line) (point)))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
713 (bof (perl-beginning-of-function))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
714 (delta (progn
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
715 (goto-char oldpnt)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
716 (perl-indent-line "\f\\|;?#" bof))))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
717 (and perl-tab-to-comment
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
718 (= oldpnt (point)) ; done if point moved
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
719 (if (listp delta) ; if line starts in a quoted string
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
720 (setq lsexp (or (nth 2 delta) bof))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
721 (= delta 0)) ; done if indenting occurred
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
722 (let ((eol (progn (end-of-line) (point)))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
723 state)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
724 (cond ((= (char-after bof) ?=)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
725 (if (= oldpnt eol)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
726 (message "In a format statement")))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
727 ((progn (setq state (parse-partial-sexp lsexp eol))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
728 (nth 3 state))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
729 (if (= oldpnt eol) ; already at eol in a string
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
730 (message "In a string which starts with a %c."
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
731 (nth 3 state))))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
732 ((not (nth 4 state))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
733 (if (= oldpnt eol) ; no comment, create one?
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
734 (indent-for-comment)))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
735 ((progn (beginning-of-line)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
736 (and comment-start-skip
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
737 (re-search-forward
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
738 comment-start-skip eol 'move)))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
739 (if (eolp)
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
740 (progn ; delete existing comment
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
741 (goto-char (match-beginning 0))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
742 (skip-chars-backward " \t")
77377
4d2d90c19454 (perl-indent-command): Use delete-region instead of kill-region.
Chong Yidong <cyd@stupidchicken.com>
parents: 77262
diff changeset
743 (delete-region (point) eol))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
744 (if (or (< oldpnt (point)) (= oldpnt eol))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
745 (indent-for-comment) ; indent existing comment
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
746 (end-of-line))))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
747 ((/= oldpnt eol)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
748 (end-of-line))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
749 (t
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
750 (message "Use backslash to quote # characters.")
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
751 (ding t)))))))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
752
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
753 (defun perl-indent-line (&optional nochange parse-start)
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
754 "Indent current line as Perl code.
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
755 Return the amount the indentation
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
756 changed by, or (parse-state) if line starts in a quoted string."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
757 (let ((case-fold-search nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
758 (pos (- (point-max) (point)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
759 (bof (or parse-start (save-excursion (perl-beginning-of-function))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
760 beg indent shift-amt)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
761 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
762 (setq beg (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
763 (setq shift-amt
40539
901d871219d0 (perl-indent-line): Use `eq' to compare output of `char-after'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39569
diff changeset
764 (cond ((eq (char-after bof) ?=) 0)
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
765 ((listp (setq indent (perl-calculate-indent bof))) indent)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
766 ((looking-at (or nochange perl-nochange)) 0)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
767 (t
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
768 (skip-chars-forward " \t\f")
60762
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
769 (setq indent (perl-indent-new-calculate nil indent bof))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
770 (- indent (current-column)))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
771 (skip-chars-forward " \t\f")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
772 (if (and (numberp shift-amt) (/= 0 shift-amt))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
773 (progn (delete-region beg (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
774 (indent-to indent)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
775 ;; If initial point was within line's indentation,
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
776 ;; position after the indentation. Else stay at same point in text.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
777 (if (> (- (point-max) pos) (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
778 (goto-char (- (point-max) pos)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
779 shift-amt))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
780
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
781 (defun perl-continuation-line-p (limit)
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
782 "Move to end of previous line and return non-nil if continued."
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
783 ;; Statement level. Is it a continuation or a new statement?
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
784 ;; Find previous non-comment character.
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
785 (perl-backward-to-noncomment)
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
786 ;; Back up over label lines, since they don't
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
787 ;; affect whether our line is a continuation.
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
788 (while (or (eq (preceding-char) ?\,)
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
789 (and (eq (preceding-char) ?:)
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
790 (memq (char-syntax (char-after (- (point) 2)))
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
791 '(?w ?_))))
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
792 (if (eq (preceding-char) ?\,)
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
793 (perl-backward-to-start-of-continued-exp limit)
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
794 (beginning-of-line))
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
795 (perl-backward-to-noncomment))
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
796 ;; Now we get the answer.
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
797 (not (memq (preceding-char) '(?\; ?\} ?\{))))
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
798
48268
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
799 (defun perl-hanging-paren-p ()
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
800 "Non-nil if we are right after a hanging parenthesis-like char."
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
801 (and (looking-at "[ \t]*$")
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
802 (save-excursion
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
803 (skip-syntax-backward " (") (not (bolp)))))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
804
60762
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
805 (defun perl-indent-new-calculate (&optional virtual default parse-start)
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
806 (or
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
807 (and virtual (save-excursion (skip-chars-backward " \t") (bolp))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
808 (current-column))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
809 (and (looking-at "\\(\\w\\|\\s_\\)+:[^:]")
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
810 (max 1 (+ (or default (perl-calculate-indent parse-start))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
811 perl-label-offset)))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
812 (and (= (char-syntax (following-char)) ?\))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
813 (save-excursion
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
814 (forward-char 1)
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
815 (forward-sexp -1)
69948
6b919f4beee5 (perl-indent-new-calculate): Recompute parse-start after jumping backward by
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 68773
diff changeset
816 (perl-indent-new-calculate
6b919f4beee5 (perl-indent-new-calculate): Recompute parse-start after jumping backward by
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 68773
diff changeset
817 ;; Recalculate the parsing-start, since we may have jumped
6b919f4beee5 (perl-indent-new-calculate): Recompute parse-start after jumping backward by
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 68773
diff changeset
818 ;; dangerously close (typically in the case of nested functions).
6b919f4beee5 (perl-indent-new-calculate): Recompute parse-start after jumping backward by
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 68773
diff changeset
819 'virtual nil (save-excursion (perl-beginning-of-function)))))
60762
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
820 (and (and (= (following-char) ?{)
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
821 (save-excursion (forward-char) (perl-hanging-paren-p)))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
822 (+ (or default (perl-calculate-indent parse-start))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
823 perl-brace-offset))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
824 (or default (perl-calculate-indent parse-start))))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
825
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
826 (defun perl-calculate-indent (&optional parse-start)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
827 "Return appropriate indentation for current line as Perl code.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
828 In usual case returns an integer: the column to indent to.
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
829 Returns (parse-state) if line starts inside a string.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
830 Optional argument PARSE-START should be the position of `beginning-of-defun'."
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
831 (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
832 (let ((indent-point (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
833 (case-fold-search nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
834 (colon-line-end 0)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
835 state containing-sexp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
836 (if parse-start ;used to avoid searching
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
837 (goto-char parse-start)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
838 (perl-beginning-of-function))
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
839 ;; We might be now looking at a local function that has nothing to
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
840 ;; do with us because `indent-point' is past it. In this case
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
841 ;; look further back up for another `perl-beginning-of-function'.
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
842 (while (and (looking-at "{")
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
843 (save-excursion
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
844 (beginning-of-line)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
845 (looking-at "\\s-+sub\\>"))
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
846 (> indent-point (save-excursion (forward-sexp 1) (point))))
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
847 (perl-beginning-of-function))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
848 (while (< (point) indent-point) ;repeat until right sexp
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
849 (setq state (parse-partial-sexp (point) indent-point 0))
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
850 ;; state = (depth_in_parens innermost_containing_list
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
851 ;; last_complete_sexp string_terminator_or_nil inside_commentp
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
852 ;; following_quotep minimum_paren-depth_this_scan)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
853 ;; Parsing stops if depth in parentheses becomes equal to third arg.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
854 (setq containing-sexp (nth 1 state)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
855 (cond ((nth 3 state) state) ; In a quoted string?
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
856 ((null containing-sexp) ; Line is at top level.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
857 (skip-chars-forward " \t\f")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
858 (if (= (following-char) ?{)
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
859 0 ; move to beginning of line if it starts a function body
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
860 ;; indent a little if this is a continuation line
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
861 (perl-backward-to-noncomment)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
862 (if (or (bobp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
863 (memq (preceding-char) '(?\; ?\})))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
864 0 perl-continued-statement-offset)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
865 ((/= (char-after containing-sexp) ?{)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
866 ;; line is expression, not statement:
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
867 ;; indent to just after the surrounding open.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
868 (goto-char (1+ containing-sexp))
48268
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
869 (if (perl-hanging-paren-p)
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
870 ;; We're indenting an arg of a call like:
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
871 ;; $a = foobarlongnamefun (
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
872 ;; arg1
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
873 ;; arg2
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
874 ;; );
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
875 (progn
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
876 (skip-syntax-backward "(")
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
877 (condition-case err
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
878 (while (save-excursion
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
879 (skip-syntax-backward " ") (not (bolp)))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
880 (forward-sexp -1))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
881 (scan-error nil))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
882 (+ (current-column) perl-indent-level))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
883 (if perl-indent-continued-arguments
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
884 (+ perl-indent-continued-arguments (current-indentation))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
885 (skip-chars-forward " \t")
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
886 (current-column))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
887 (t
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
888 ;; Statement level. Is it a continuation or a new statement?
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
889 (if (perl-continuation-line-p containing-sexp)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
890 ;; This line is continuation of preceding line's statement;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
891 ;; indent perl-continued-statement-offset more than the
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
892 ;; previous line of the statement.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
893 (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
894 (perl-backward-to-start-of-continued-exp containing-sexp)
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
895 (+ (if (save-excursion
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
896 (perl-continuation-line-p containing-sexp))
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
897 ;; If the continued line is itself a continuation
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
898 ;; line, then align, otherwise add an offset.
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
899 0 perl-continued-statement-offset)
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
900 (current-column)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
901 (if (save-excursion (goto-char indent-point)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
902 (looking-at "[ \t]*{"))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
903 perl-continued-brace-offset 0)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
904 ;; This line starts a new statement.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
905 ;; Position at last unclosed open.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
906 (goto-char containing-sexp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
907 (or
48268
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
908 ;; Is line first statement after an open-brace?
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
909 ;; If no, find that first statement and indent like it.
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
910 (save-excursion
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
911 (forward-char 1)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
912 ;; Skip over comments and labels following openbrace.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
913 (while (progn
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
914 (skip-chars-forward " \t\f\n")
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
915 (cond ((looking-at ";?#")
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
916 (forward-line 1) t)
59328
7f974399bee1 (perl-nochange, perl-calculate-indent):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59249
diff changeset
917 ((looking-at "\\(\\w\\|\\s_\\)+:[^:]")
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
918 (save-excursion
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
919 (end-of-line)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
920 (setq colon-line-end (point)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
921 (search-forward ":")))))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
922 ;; The first following code counts
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
923 ;; if it is before the line we want to indent.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
924 (and (< (point) indent-point)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
925 (if (> colon-line-end (point))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
926 (- (current-indentation) perl-label-offset)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
927 (current-column))))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
928 ;; If no previous statement,
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
929 ;; indent it relative to line brace is on.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
930 ;; For open paren in column zero, don't let statement
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
931 ;; start there too. If perl-indent-level is zero,
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
932 ;; use perl-brace-offset + perl-continued-statement-offset
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
933 ;; For open-braces not the first thing in a line,
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
934 ;; add in perl-brace-imaginary-offset.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
935 (+ (if (and (bolp) (zerop perl-indent-level))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
936 (+ perl-brace-offset perl-continued-statement-offset)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
937 perl-indent-level)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
938 ;; Move back over whitespace before the openbrace.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
939 ;; If openbrace is not first nonwhite thing on the line,
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
940 ;; add the perl-brace-imaginary-offset.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
941 (progn (skip-chars-backward " \t")
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
942 (if (bolp) 0 perl-brace-imaginary-offset))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
943 ;; If the openbrace is preceded by a parenthesized exp,
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
944 ;; move to the beginning of that;
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
945 ;; possibly a different line
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
946 (progn
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
947 (if (eq (preceding-char) ?\))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
948 (forward-sexp -1))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
949 ;; Get initial indentation of the line we are on.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
950 (current-indentation))))))))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
951
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
952 (defun perl-backward-to-noncomment ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
953 "Move point backward to after the first non-white-space, skipping comments."
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
954 (interactive)
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
955 (forward-comment (- (point-max))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
956
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
957 (defun perl-backward-to-start-of-continued-exp (lim)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
958 (if (= (preceding-char) ?\))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
959 (forward-sexp -1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
960 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
961 (if (<= (point) lim)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
962 (goto-char (1+ lim)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
963 (skip-chars-forward " \t\f"))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
964
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
965 ;; note: this may be slower than the c-mode version, but I can understand it.
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
966 (defalias 'indent-perl-exp 'perl-indent-exp)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
967 (defun perl-indent-exp ()
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
968 "Indent each line of the Perl grouping following point."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
969 (interactive)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
970 (let* ((case-fold-search nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
971 (oldpnt (point-marker))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
972 (bof-mark (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
973 (end-of-line 2)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
974 (perl-beginning-of-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
975 (point-marker)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
976 eol last-mark lsexp-mark delta)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
977 (if (= (char-after (marker-position bof-mark)) ?=)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
978 (message "Can't indent a format statement")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
979 (message "Indenting Perl expression...")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
980 (save-excursion (end-of-line) (setq eol (point)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
981 (save-excursion ; locate matching close paren
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
982 (while (and (not (eobp)) (<= (point) eol))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
983 (parse-partial-sexp (point) (point-max) 0))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
984 (setq last-mark (point-marker)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
985 (setq lsexp-mark bof-mark)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
986 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
987 (while (< (point) (marker-position last-mark))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
988 (setq delta (perl-indent-line nil (marker-position bof-mark)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
989 (if (numberp delta) ; unquoted start-of-line?
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
990 (progn
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
991 (if (eolp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
992 (delete-horizontal-space))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
993 (setq lsexp-mark (point-marker))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
994 (end-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
995 (setq eol (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
996 (if (nth 4 (parse-partial-sexp (marker-position lsexp-mark) eol))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
997 (progn ; line ends in a comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
998 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
999 (if (or (not (looking-at "\\s-*;?#"))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1000 (listp delta)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1001 (and (/= 0 delta)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1002 (= (- (current-indentation) delta) comment-column)))
16472
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
1003 (if (and comment-start-skip
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
1004 (re-search-forward comment-start-skip eol t))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1005 (indent-for-comment))))) ; indent existing comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1006 (forward-line 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1007 (goto-char (marker-position oldpnt))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1008 (message "Indenting Perl expression...done"))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1009
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1010 (defun perl-beginning-of-function (&optional arg)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1011 "Move backward to next beginning-of-function, or as far as possible.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1012 With argument, repeat that many times; negative args move forward.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1013 Returns new value of point in all cases."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1014 (interactive "p")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1015 (or arg (setq arg 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1016 (if (< arg 0) (forward-char 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1017 (and (/= arg 0)
70376
64d64506f4b1 (perl-beginning-of-function): Skip anonymous subs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 69948
diff changeset
1018 (re-search-backward
64d64506f4b1 (perl-beginning-of-function): Skip anonymous subs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 69948
diff changeset
1019 "^\\s(\\|^\\s-*sub\\b[ \t\n]*\\_<[^{]+{\\|^\\s-*format\\b[^=]*=\\|^\\."
64d64506f4b1 (perl-beginning-of-function): Skip anonymous subs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 69948
diff changeset
1020 nil 'move arg)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1021 (goto-char (1- (match-end 0))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1022 (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1023
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1024 ;; note: this routine is adapted directly from emacs lisp.el, end-of-defun;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1025 ;; no bugs have been removed :-)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1026 (defun perl-end-of-function (&optional arg)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1027 "Move forward to next end-of-function.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1028 The end of a function is found by moving forward from the beginning of one.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1029 With argument, repeat that many times; negative args move backward."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1030 (interactive "p")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1031 (or arg (setq arg 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1032 (let ((first t))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1033 (while (and (> arg 0) (< (point) (point-max)))
51054
cd2cb7e0cc7e (perl-tab-always-indent): Default to tab-always-indent.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 49598
diff changeset
1034 (let ((pos (point)))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1035 (while (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1036 (if (and first
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1037 (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1038 (forward-char 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1039 (perl-beginning-of-function 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1040 (not (bobp))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1041 nil
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1042 (or (bobp) (forward-char -1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1043 (perl-beginning-of-function -1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1044 (setq first nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1045 (forward-list 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1046 (skip-chars-forward " \t")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1047 (if (looking-at "[#\n]")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1048 (forward-line 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1049 (<= (point) pos))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1050 (setq arg (1- arg)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1051 (while (< arg 0)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1052 (let ((pos (point)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1053 (perl-beginning-of-function 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1054 (forward-sexp 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1055 (forward-line 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1056 (if (>= (point) pos)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1057 (if (progn (perl-beginning-of-function 2) (not (bobp)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1058 (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1059 (forward-list 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1060 (skip-chars-forward " \t")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1061 (if (looking-at "[#\n]")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1062 (forward-line 1)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1063 (goto-char (point-min)))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1064 (setq arg (1+ arg)))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1065
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
1066 (defalias 'mark-perl-function 'perl-mark-function)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
1067 (defun perl-mark-function ()
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1068 "Put mark at end of Perl function, point at beginning."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1069 (interactive)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1070 (push-mark (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1071 (perl-end-of-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1072 (push-mark (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1073 (perl-beginning-of-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1074 (backward-paragraph))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1075
16358
8b36369ba4de Add `provide' call.
Richard M. Stallman <rms@gnu.org>
parents: 14633
diff changeset
1076 (provide 'perl-mode)
8b36369ba4de Add `provide' call.
Richard M. Stallman <rms@gnu.org>
parents: 14633
diff changeset
1077
59328
7f974399bee1 (perl-nochange, perl-calculate-indent):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59249
diff changeset
1078 ;; arch-tag: 8c7ff68d-15f3-46a2-ade2-b7c41f176826
16358
8b36369ba4de Add `provide' call.
Richard M. Stallman <rms@gnu.org>
parents: 14633
diff changeset
1079 ;;; perl-mode.el ends here