annotate lisp/progmodes/perl-mode.el @ 111433:05dc9dca8729

Replace end-of-line, save-excursion etc with point-at-eol, point-at-bol. * lisp/mh-e/mh-seq.el (mh-read-msg-list): Use point-at-eol. * lisp/gnus/gnus-bookmark.el (gnus-bookmark-bmenu-show-infos) (gnus-bookmark-kill-line): Use point-at-eol. * lisp/cedet/ede/proj-elisp.el (ede-proj-flush-autoconf): Use point-at-bol. * lisp/emacs-lisp/chart.el (chart-zap-chars): * lisp/play/decipher.el (decipher-set-map): * lisp/progmodes/ada-mode.el (ada-get-current-indent) (ada-search-ignore-string-comment, ada-tab-hard, ada-untab-hard): * lisp/progmodes/ada-prj.el (ada-prj-load-from-file, ada-prj-display-help): * lisp/progmodes/ada-xref.el (ada-initialize-runtime-library) (ada-get-all-references): * lisp/progmodes/cperl-mode.el (cperl-electric-paren) (cperl-electric-rparen, cperl-electric-keyword, cperl-electric-else) (cperl-linefeed, cperl-sniff-for-indent, cperl-to-comment-or-eol) (cperl-find-pods-heres, cperl-indent-exp, cperl-fix-line-spacing) (cperl-word-at-point-hard): * lisp/progmodes/idlw-shell.el (idlwave-shell-move-or-history) (idlwave-shell-filename-string, idlwave-shell-batch-command) (idlwave-shell-display-line): * lisp/progmodes/idlwave.el (idlwave-show-begin, idlwave-fill-paragraph) (idlwave-calc-hanging-indent, idlwave-auto-fill, idlwave-template): * lisp/progmodes/js.el (js--re-search-forward-inner) (js--re-search-backward-inner): * lisp/progmodes/vhdl-mode.el (vhdl-align-region-1, vhdl-align-region-2) (vhdl-fix-clause, vhdl-compose-configuration-architecture): * lisp/progmodes/ruby-mode.el (ruby-parse-partial, eval-when-compile): * lisp/textmodes/flyspell.el (flyspell-process-localwords): * lisp/textmodes/ispell.el (ispell-buffer-local-parsing) (ispell-buffer-local-dict, ispell-buffer-local-words): Use point-at-bol and point-at-eol.
author Glenn Morris <rgm@gnu.org>
date Sat, 06 Nov 2010 18:36:33 -0700
parents 249a1455856a
children b47e85affa59
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 "."))
111325
9aff83bb4de1 * lisp/progmodes/perl-mode.el (perl-syntax-propertize-function):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 110305
diff changeset
277 ;; Turn __DATA__ trailer into a comment.
9aff83bb4de1 * lisp/progmodes/perl-mode.el (perl-syntax-propertize-function):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 110305
diff changeset
278 ("^\\(_\\)_\\(?:DATA\\|END\\)__[ \t]*\\(?:\\(\n\\)#.-\\*-.*perl.*-\\*-\\|\n.*\\)"
9aff83bb4de1 * lisp/progmodes/perl-mode.el (perl-syntax-propertize-function):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 110305
diff changeset
279 (1 "< c") (2 "> c")
9aff83bb4de1 * lisp/progmodes/perl-mode.el (perl-syntax-propertize-function):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 110305
diff changeset
280 (0 (ignore (put-text-property (match-beginning 0) (match-end 0)
9aff83bb4de1 * lisp/progmodes/perl-mode.el (perl-syntax-propertize-function):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 110305
diff changeset
281 'syntax-multiline t))))
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
282 ;; 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
283 ;; match from the division operator is ...interesting.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
284 ;; 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
285 ;; (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
286 ;; 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
287 ;; 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
288 ;; *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
289 ;; 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
290 ;; perl-font-lock-special-syntactic-constructs.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
291 ((concat "\\(?:\\(?:^\\|[^$@&%[:word:]]\\)"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
292 (regexp-opt '("split" "if" "unless" "until" "while" "split"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
293 "grep" "map" "not" "or" "and"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
294 "\\|[?:.,;=!~({[]\\|\\(^\\)\\)[ \t\n]*\\(/\\)")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
295 (2 (ignore
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
296 (if (and (match-end 1) ; / at BOL.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
297 (save-excursion
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
298 (goto-char (match-end 1))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
299 (forward-comment (- (point-max)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
300 (put-text-property (point) (match-end 2)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
301 'syntax-multiline t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
302 (not (memq (char-before)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
303 '(?? ?: ?. ?, ?\; ?= ?! ?~ ?\( ?\[)))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
304 nil ;; A division sign instead of a regexp-match.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
305 (put-text-property (match-beginning 2) (match-end 2)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
306 'syntax-table (string-to-syntax "\""))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
307 (perl-syntax-propertize-special-constructs end)))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
308 ("\\(^\\|[?:.,;=!~({[ \t]\\)\\([msy]\\|q[qxrw]?\\|tr\\)\\>\\s-*\\([^])}> \n\t]\\)"
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
309 ;; Nasty cases:
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
310 ;; /foo/m $a->m $#m $m @m %m
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
311 ;; \s (appears often in regexps).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
312 ;; -s file
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
313 ;; sub tr {...}
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
314 (3 (ignore
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
315 (if (save-excursion (goto-char (match-beginning 0))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
316 (forward-word -1)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
317 (looking-at-p "sub[ \t\n]"))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
318 ;; This is defining a function.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
319 nil
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
320 (put-text-property (match-beginning 3) (match-end 3)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
321 'syntax-table
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
322 (if (assoc (char-after (match-beginning 3))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
323 perl-quote-like-pairs)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
324 (string-to-syntax "|")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
325 (string-to-syntax "\"")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
326 (perl-syntax-propertize-special-constructs end))))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
327 (point) end)))
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
328
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
329 (defvar perl-empty-syntax-table
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
330 (let ((st (copy-syntax-table)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
331 ;; Make all chars be of punctuation syntax.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
332 (dotimes (i 256) (aset st i '(1)))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
333 (modify-syntax-entry ?\\ "\\" st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
334 st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
335 "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
336
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
337 (defun perl-quote-syntax-table (char)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
338 (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
339 (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
340 (if (not close)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
341 (modify-syntax-entry char "\"" st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
342 (modify-syntax-entry char "(" st)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
343 (modify-syntax-entry close ")" st))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
344 st))
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
345
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
346 (defun perl-syntax-propertize-special-constructs (limit)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
347 "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
348 (let ((state (syntax-ppss))
4ac8c6441408 (perl-font-lock-special-syntactic-constructs):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65358
diff changeset
349 char)
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
350 (cond
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
351 ((or (null (setq char (nth 3 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
352 (and (characterp char) (eq (char-syntax (nth 3 state)) ?\")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
353 ;; Normal text, or comment, or docstring, or normal string.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
354 nil)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
355 ((eq (nth 3 state) ?\n)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
356 ;; A `format' command.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
357 (when (re-search-forward "^\\s *\\.\\s *\n" limit 'move)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
358 (put-text-property (1- (point)) (point)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
359 'syntax-table (string-to-syntax "\""))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
360 (t
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
361 ;; This is regexp like quote thingy.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
362 (setq char (char-after (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
363 (let ((twoargs (save-excursion
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
364 (goto-char (nth 8 state))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
365 (skip-syntax-backward " ")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
366 (skip-syntax-backward "w")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
367 (member (buffer-substring
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
368 (point) (progn (forward-word 1) (point)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
369 '("tr" "s" "y"))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
370 (close (cdr (assq char perl-quote-like-pairs)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
371 (st (perl-quote-syntax-table char)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
372 (when (with-syntax-table st
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
373 (if close
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
374 ;; For paired delimiters, Perl allows nesting them, but
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
375 ;; 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
376 ;; 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
377 ;; 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
378 ;; "string" and count from there.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
379 (condition-case nil
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
380 (progn
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
381 ;; 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
382 ;; paren-syntax (an alternative would be to let-bind
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
383 ;; parse-sexp-lookup-properties).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
384 (goto-char (1+ (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
385 (up-list 1)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
386 t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
387 (scan-error nil))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
388 (not (or (nth 8 (parse-partial-sexp
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
389 (point) limit nil nil state 'syntax-table))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
390 ;; 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
391 ;; 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
392 ;; a second time.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
393 ;; In the case of s{...}{...}, we only handle the
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
394 ;; first part here and the next below.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
395 (when (and twoargs (not close))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
396 (nth 8 (parse-partial-sexp
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
397 (point) limit
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
398 nil nil state 'syntax-table)))))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
399 ;; Point is now right after the arg(s).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
400 (when (eq (char-before (1- (point))) ?$)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
401 (put-text-property (- (point) 2) (1- (point))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
402 'syntax-table '(1)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
403 (put-text-property (1- (point)) (point)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
404 'syntax-table
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
405 (if close
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
406 (string-to-syntax "|")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
407 (string-to-syntax "\"")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
408 ;; 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
409 ;; 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
410 ;; handle the second part.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
411 (when (and twoargs close)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
412 ;; Skip whitespace and make sure that font-lock will
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
413 ;; refontify the second part in the proper context.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
414 (put-text-property
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
415 (point) (progn (forward-comment (point-max)) (point))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
416 'syntax-multiline t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
417 ;;
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
418 (when (< (point) limit)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
419 (put-text-property (point) (1+ (point))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
420 'syntax-table
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
421 (if (assoc (char-after)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
422 perl-quote-like-pairs)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
423 ;; Put an `e' in the cdr to mark this
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
424 ;; char as "second arg starter".
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
425 (string-to-syntax "|e")
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
426 (string-to-syntax "\"e")))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
427 (forward-char 1)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
428 ;; 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
429 ;; 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
430 ;; 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
431 ;; as twoarg).
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
432 (perl-syntax-propertize-special-constructs limit)))))))))
66638
4ac8c6441408 (perl-font-lock-special-syntactic-constructs):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65358
diff changeset
433
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
434 (defun perl-font-lock-syntactic-face-function (state)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
435 (cond
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
436 ((and (nth 3 state)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
437 (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
438 ;; 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
439 ;; 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
440 ;; 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
441 ;; 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
442 ;; 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
443 ;; 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
444 ;; pretend it has not been syntax-propertized yet.
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
445 (let* ((parse-sexp-lookup-properties nil)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
446 (char (char-after (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
447 (paired (assq char perl-quote-like-pairs)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
448 (with-syntax-table (perl-quote-syntax-table char)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
449 (save-excursion
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
450 (if (not paired)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
451 (parse-partial-sexp (point) (point-max)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
452 nil nil state 'syntax-table)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
453 (condition-case nil
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
454 (progn
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
455 (goto-char (1+ (nth 8 state)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
456 (up-list 1))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
457 (scan-error (goto-char (point-max)))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
458 (put-text-property (nth 8 state) (point)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
459 'jit-lock-defer-multiline t)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
460 (looking-at "[ \t]*\\sw*e")))))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
461 nil)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
462 (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
463
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
464 (defcustom perl-indent-level 4
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
465 "*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
466 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
467 :group 'perl)
78660
ccfc1f1f4817 * progmodes/cperl-mode.el (cperl-indent-level): Autoload the
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78571
diff changeset
468
79553
f81c00b9c0ff * progmodes/perl-mode.el (perl-continued-statement-offset)
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79514
diff changeset
469 ;; 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
470 ;; 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
471 ;; 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
472 ;; 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
473 ;; 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
474 ;;;###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
475 ;;;###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
476 ;;;###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
477 ;;;###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
478 ;;;###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
479 ;;;###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
480
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
481 (defcustom perl-continued-statement-offset 4
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
482 "*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
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-continued-brace-offset -4
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
486 "*Extra indent for substatements that start with open-braces.
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
487 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
488 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
489 :group 'perl)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
490 (defcustom perl-brace-offset 0
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
491 "*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
492 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
493 :group 'perl)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
494 (defcustom perl-brace-imaginary-offset 0
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
495 "*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
496 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
497 :group 'perl)
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
498 (defcustom perl-label-offset -2
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
499 "*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
500 :type 'integer
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
501 :group 'perl)
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
502 (defcustom perl-indent-continued-arguments nil
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
503 "*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
504 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
505 :type '(choice integer (const nil))
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
506 :group 'perl)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
507
51054
cd2cb7e0cc7e (perl-tab-always-indent): Default to tab-always-indent.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 49598
diff changeset
508 (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
509 "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
510 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
511 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
512 :type 'boolean
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
513 :group 'perl)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
514
10807
50f00b298a2d (perl-tab-to-comment): Default is nil.
Richard M. Stallman <rms@gnu.org>
parents: 9480
diff changeset
515 ;; 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
516 ;; conventions -- rms.
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
517 (defcustom perl-tab-to-comment nil
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
518 "*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
519 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
520 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
521 create a new comment."
62531
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
522 :type 'boolean
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
523 :group 'perl)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
524
59328
7f974399bee1 (perl-nochange, perl-calculate-indent):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59249
diff changeset
525 (defcustom perl-nochange ";?#\\|\f\\|\\s(\\|\\(\\w\\|\\s_\\)+:[^:]"
20960
2f9b7d0689a9 Customized.
Stephen Eglen <stephen@gnu.org>
parents: 20953
diff changeset
526 "*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
527 :type 'regexp
c905fcf5e3d9 Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents: 60825
diff changeset
528 :group 'perl)
60300
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
529
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
530 ;; Outline support
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
531
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
532 (defvar perl-outline-regexp
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
533 (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
534 "\\|^=cut\\>"))
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
535
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
536 (defun perl-outline-level ()
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
537 (cond
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
538 ((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
539 ((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
540 ((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
541 ((looking-at "=cut") 1)
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
542 (t 3)))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
543
60693
0dab980fb0b7 (perl-mode-hook): Defvar it.
Richard M. Stallman <rms@gnu.org>
parents: 60300
diff changeset
544 (defvar perl-mode-hook nil
0dab980fb0b7 (perl-mode-hook): Defvar it.
Richard M. Stallman <rms@gnu.org>
parents: 60300
diff changeset
545 "Normal hook to run when entering Perl mode.")
0dab980fb0b7 (perl-mode-hook): Defvar it.
Richard M. Stallman <rms@gnu.org>
parents: 60300
diff changeset
546
21857
a22711be4750 (perl-mode): Add autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents: 20960
diff changeset
547 ;;;###autoload
41346
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
548 (defun perl-mode ()
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
549 "Major mode for editing Perl code.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
550 Expression and list commands understand all Perl brackets.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
551 Tab indents for Perl code.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
552 Comments are delimited with # ... \\n.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
553 Paragraphs are separated by blank lines only.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
554 Delete converts tabs to spaces as it moves back.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
555 \\{perl-mode-map}
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
556 Variables controlling indentation style:
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
557 `perl-tab-always-indent'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
558 Non-nil means TAB in Perl mode should always indent the current line,
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
559 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
560 `perl-tab-to-comment'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
561 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
562 either delete an empty comment, indent an existing comment, move
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
563 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
564 `perl-nochange'
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
565 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
566 `perl-indent-level'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
567 Indentation of Perl statements within surrounding block.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
568 The surrounding block's indentation is the indentation
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
569 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
570 `perl-continued-statement-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
571 Extra indentation given to a substatement, such as the
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
572 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
573 `perl-continued-brace-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
574 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
575 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
576 `perl-brace-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
577 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
578 `perl-brace-imaginary-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
579 An open brace following other text is treated as if it were
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
580 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
581 `perl-label-offset'
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
582 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
583 `perl-indent-continued-arguments'
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
584 Offset of argument lines relative to usual indentation.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
585
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
586 Various indentation styles: K&R BSD BLK GNU LW
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
587 perl-indent-level 5 8 0 2 4
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
588 perl-continued-statement-offset 5 8 4 2 4
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
589 perl-continued-brace-offset 0 0 0 0 -4
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
590 perl-brace-offset -5 -8 0 0 0
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
591 perl-brace-imaginary-offset 0 0 4 0 0
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
592 perl-label-offset -5 -8 -2 -2 -2
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
593
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
594 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
595 (interactive)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
596 (kill-all-local-variables)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
597 (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
598 (setq major-mode 'perl-mode)
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
599 (setq mode-name "Perl")
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
600 (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
601 (set-syntax-table perl-mode-syntax-table)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
602 (make-local-variable 'paragraph-start)
10889
de7673bb5d19 (perl-mode): Remove ^ from paragraph-start & paragraph-separate.
Boris Goldowsky <boris@gnu.org>
parents: 10807
diff changeset
603 (setq paragraph-start (concat "$\\|" page-delimiter))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
604 (make-local-variable 'paragraph-separate)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
605 (setq paragraph-separate paragraph-start)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
606 (make-local-variable 'paragraph-ignore-fill-prefix)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
607 (setq paragraph-ignore-fill-prefix t)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
608 (make-local-variable 'indent-line-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
609 (setq indent-line-function 'perl-indent-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
610 (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
611 (setq require-final-newline mode-require-final-newline)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
612 (make-local-variable 'comment-start)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
613 (setq comment-start "# ")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
614 (make-local-variable 'comment-end)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
615 (setq comment-end "")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
616 (make-local-variable 'comment-start-skip)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
617 (setq comment-start-skip "\\(^\\|\\s-\\);?#+ *")
2307
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 882
diff changeset
618 (make-local-variable 'comment-indent-function)
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 882
diff changeset
619 (setq comment-indent-function 'perl-comment-indent)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
620 (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
621 (setq parse-sexp-ignore-comments t)
14363
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
622 ;; Tell font-lock.el how to handle Perl.
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
623 (setq font-lock-defaults '((perl-font-lock-keywords
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
624 perl-font-lock-keywords-1
754031d2354f Support for Font Lock mode.
Simon Marshall <simon@gnu.org>
parents: 14169
diff changeset
625 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
626 nil nil ((?\_ . "w")) nil
110305
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
627 (font-lock-syntactic-face-function
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
628 . perl-font-lock-syntactic-face-function)))
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
629 (set (make-local-variable 'syntax-propertize-function)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
630 #'perl-syntax-propertize-function)
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
631 (add-hook 'syntax-propertize-extend-region-functions
b10051866f51 New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 106815
diff changeset
632 #'syntax-propertize-multiline 'append 'local)
12677
1504d644c6bc (perl-imenu-generic-expression) New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11370
diff changeset
633 ;; 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
634 (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
635 perl-imenu-generic-expression)
41346
42d60301f16a (perl-mode): Don't use define-derived-mode.
Richard M. Stallman <rms@gnu.org>
parents: 40539
diff changeset
636 (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
637 ;; Setup outline-minor-mode.
8da4bb4a512f (perl-imenu-generic-expression): Add entries for perldoc sections.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59328
diff changeset
638 (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
639 (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
640 (run-mode-hooks 'perl-mode-hook))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
641
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
642 ;; This is used by indent-for-comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
643 ;; to decide how much to indent a comment in Perl code
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
644 ;; based on its context.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
645 (defun perl-comment-indent ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
646 (if (and (bolp) (not (eolp)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
647 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
648 comment-column))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
649
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
650 (defalias 'electric-perl-terminator 'perl-electric-terminator)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
651 (defun perl-electric-terminator (arg)
5589
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
652 "Insert character and adjust indentation.
608926d1bd70 Change defconsts to defvars. Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 4455
diff changeset
653 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
654 (interactive "P")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
655 (let ((insertpos (point)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
656 (and (not arg) ; decide whether to indent
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
657 (eolp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
658 (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
659 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
660 (and (not ; eliminate comments quickly
16472
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
661 (and comment-start-skip
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
662 (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
663 (or (/= last-command-event ?:)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
664 ;; Colon is special only after a label ....
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
665 (looking-at "\\s-*\\(\\w\\|\\s_\\)+$"))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
666 (let ((pps (parse-partial-sexp
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
667 (perl-beginning-of-function) insertpos)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
668 (not (or (nth 3 pps) (nth 4 pps) (nth 5 pps))))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
669 (progn ; must insert, indent, delete
101002
3b3c7e10cd97 Replace last-command-char with last-command-event.
Glenn Morris <rgm@gnu.org>
parents: 100908
diff changeset
670 (insert-char last-command-event 1)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
671 (perl-indent-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
672 (delete-char -1))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
673 (self-insert-command (prefix-numeric-value arg)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
674
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
675 ;; not used anymore, but may be useful someday:
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
676 ;;(defun perl-inside-parens-p ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
677 ;; (condition-case ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
678 ;; (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
679 ;; (save-restriction
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
680 ;; (narrow-to-region (point)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
681 ;; (perl-beginning-of-function))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
682 ;; (goto-char (point-max))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
683 ;; (= (char-after (or (scan-lists (point) -1 1) (point-min))) ?\()))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
684 ;; (error nil)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
685
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
686 (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
687 "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
688 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
689 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
690 unconditionally.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
691
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
692 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
693 the indentation area at the beginning of the line, insert a tab.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
694
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
695 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
696 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
697 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
698 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
699 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
700 following list:
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
701
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
702 1) delete an empty comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
703 2) move forward to start of comment, indenting if necessary
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
704 3) move forward to end of line
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
705 4) create an empty comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
706 5) move backward to start of comment, indenting if necessary."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
707 (interactive "P")
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
708 (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
709 (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
710 (arg
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
711 (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
712 ((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
713 (> (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
714 (insert-tab))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
715 (t
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
716 (let* ((oldpnt (point))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
717 (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
718 (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
719 (delta (progn
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
720 (goto-char oldpnt)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
721 (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
722 (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
723 (= 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
724 (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
725 (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
726 (= 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
727 (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
728 state)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
729 (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
730 (if (= oldpnt eol)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
731 (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
732 ((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
733 (nth 3 state))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
734 (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
735 (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
736 (nth 3 state))))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
737 ((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
738 (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
739 (indent-for-comment)))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
740 ((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
741 (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
742 (re-search-forward
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
743 comment-start-skip eol 'move)))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
744 (if (eolp)
101593
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
745 (progn ; delete existing comment
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
746 (goto-char (match-beginning 0))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
747 (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
748 (delete-region (point) eol))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
749 (if (or (< oldpnt (point)) (= oldpnt eol))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
750 (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
751 (end-of-line))))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
752 ((/= oldpnt eol)
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
753 (end-of-line))
84cb9ad20593 (perl-indent-line-command): Call indent-region if region is active.
Chong Yidong <cyd@stupidchicken.com>
parents: 101002
diff changeset
754 (t
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
755 (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
756 (ding t)))))))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
757
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
758 (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
759 "Indent current line as Perl code.
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
760 Return the amount the indentation
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
761 changed by, or (parse-state) if line starts in a quoted string."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
762 (let ((case-fold-search nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
763 (pos (- (point-max) (point)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
764 (bof (or parse-start (save-excursion (perl-beginning-of-function))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
765 beg indent shift-amt)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
766 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
767 (setq beg (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
768 (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
769 (cond ((eq (char-after bof) ?=) 0)
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
770 ((listp (setq indent (perl-calculate-indent bof))) indent)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
771 ((looking-at (or nochange perl-nochange)) 0)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
772 (t
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
773 (skip-chars-forward " \t\f")
60762
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
774 (setq indent (perl-indent-new-calculate nil indent bof))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
775 (- indent (current-column)))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
776 (skip-chars-forward " \t\f")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
777 (if (and (numberp shift-amt) (/= 0 shift-amt))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
778 (progn (delete-region beg (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
779 (indent-to indent)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
780 ;; If initial point was within line's indentation,
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
781 ;; position after the indentation. Else stay at same point in text.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
782 (if (> (- (point-max) pos) (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
783 (goto-char (- (point-max) pos)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
784 shift-amt))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
785
38014
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
786 (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
787 "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
788 ;; 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
789 ;; 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
790 (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
791 ;; 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
792 ;; 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
793 (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
794 (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
795 (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
796 '(?w ?_))))
8c5d188dc01b (perl-font-lock-syntactic-keywords): New var, to recognize ${ $' and PODs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37893
diff changeset
797 (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
798 (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
799 (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
800 (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
801 ;; 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
802 (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
803
48268
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
804 (defun perl-hanging-paren-p ()
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
805 "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
806 (and (looking-at "[ \t]*$")
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
807 (save-excursion
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
808 (skip-syntax-backward " (") (not (bolp)))))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
809
60762
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
810 (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
811 (or
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
812 (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
813 (current-column))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
814 (and (looking-at "\\(\\w\\|\\s_\\)+:[^:]")
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
815 (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
816 perl-label-offset)))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
817 (and (= (char-syntax (following-char)) ?\))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
818 (save-excursion
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
819 (forward-char 1)
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
820 (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
821 (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
822 ;; 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
823 ;; 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
824 '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
825 (and (and (= (following-char) ?{)
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
826 (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
827 (+ (or default (perl-calculate-indent parse-start))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
828 perl-brace-offset))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
829 (or default (perl-calculate-indent parse-start))))
9d474a03949a (perl-indent-new-calculate): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60761
diff changeset
830
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
831 (defun perl-calculate-indent (&optional parse-start)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
832 "Return appropriate indentation for current line as Perl code.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
833 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
834 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
835 Optional argument PARSE-START should be the position of `beginning-of-defun'."
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
836 (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
837 (let ((indent-point (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
838 (case-fold-search nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
839 (colon-line-end 0)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
840 state containing-sexp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
841 (if parse-start ;used to avoid searching
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
842 (goto-char parse-start)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
843 (perl-beginning-of-function))
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
844 ;; 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
845 ;; 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
846 ;; 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
847 (while (and (looking-at "{")
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
848 (save-excursion
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
849 (beginning-of-line)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
850 (looking-at "\\s-+sub\\>"))
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
851 (> 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
852 (perl-beginning-of-function))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
853 (while (< (point) indent-point) ;repeat until right sexp
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
854 (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
855 ;; state = (depth_in_parens innermost_containing_list
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
856 ;; 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
857 ;; following_quotep minimum_paren-depth_this_scan)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
858 ;; Parsing stops if depth in parentheses becomes equal to third arg.
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
859 (setq containing-sexp (nth 1 state)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
860 (cond ((nth 3 state) state) ; In a quoted string?
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
861 ((null containing-sexp) ; Line is at top level.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
862 (skip-chars-forward " \t\f")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
863 (if (= (following-char) ?{)
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
864 0 ; move to beginning of line if it starts a function body
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
865 ;; indent a little if this is a continuation line
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
866 (perl-backward-to-noncomment)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
867 (if (or (bobp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
868 (memq (preceding-char) '(?\; ?\})))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
869 0 perl-continued-statement-offset)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
870 ((/= (char-after containing-sexp) ?{)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
871 ;; line is expression, not statement:
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
872 ;; indent to just after the surrounding open.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
873 (goto-char (1+ containing-sexp))
48268
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
874 (if (perl-hanging-paren-p)
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
875 ;; 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
876 ;; $a = foobarlongnamefun (
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
877 ;; arg1
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
878 ;; arg2
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
879 ;; );
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
880 (progn
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
881 (skip-syntax-backward "(")
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
882 (condition-case err
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
883 (while (save-excursion
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
884 (skip-syntax-backward " ") (not (bolp)))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
885 (forward-sexp -1))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
886 (scan-error nil))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
887 (+ (current-column) perl-indent-level))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
888 (if perl-indent-continued-arguments
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
889 (+ perl-indent-continued-arguments (current-indentation))
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
890 (skip-chars-forward " \t")
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
891 (current-column))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
892 (t
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
893 ;; 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
894 (if (perl-continuation-line-p containing-sexp)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
895 ;; This line is continuation of preceding line's statement;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
896 ;; indent perl-continued-statement-offset more than the
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
897 ;; previous line of the statement.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
898 (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
899 (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
900 (+ (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
901 (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
902 ;; 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
903 ;; 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
904 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
905 (current-column)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
906 (if (save-excursion (goto-char indent-point)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
907 (looking-at "[ \t]*{"))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
908 perl-continued-brace-offset 0)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
909 ;; This line starts a new statement.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
910 ;; Position at last unclosed open.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
911 (goto-char containing-sexp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
912 (or
48268
3177076ca9a1 (perl-hanging-paren-p): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47955
diff changeset
913 ;; 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
914 ;; 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
915 (save-excursion
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
916 (forward-char 1)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
917 ;; Skip over comments and labels following openbrace.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
918 (while (progn
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
919 (skip-chars-forward " \t\f\n")
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
920 (cond ((looking-at ";?#")
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
921 (forward-line 1) t)
59328
7f974399bee1 (perl-nochange, perl-calculate-indent):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59249
diff changeset
922 ((looking-at "\\(\\w\\|\\s_\\)+:[^:]")
111429
249a1455856a Use line-end-position rather than end-of-line, etc.
Glenn Morris <rgm@gnu.org>
parents: 111325
diff changeset
923 (setq colon-line-end (line-end-position))
47469
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
924 (search-forward ":")))))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
925 ;; The first following code counts
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
926 ;; 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
927 (and (< (point) indent-point)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
928 (if (> colon-line-end (point))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
929 (- (current-indentation) perl-label-offset)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
930 (current-column))))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
931 ;; If no previous statement,
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
932 ;; 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
933 ;; 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
934 ;; 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
935 ;; 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
936 ;; 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
937 ;; add in perl-brace-imaginary-offset.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
938 (+ (if (and (bolp) (zerop perl-indent-level))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
939 (+ perl-brace-offset perl-continued-statement-offset)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
940 perl-indent-level)
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
941 ;; Move back over whitespace before the openbrace.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
942 ;; 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
943 ;; add the perl-brace-imaginary-offset.
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
944 (progn (skip-chars-backward " \t")
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
945 (if (bolp) 0 perl-brace-imaginary-offset))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
946 ;; 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
947 ;; move to the beginning of that;
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
948 ;; possibly a different line
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
949 (progn
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
950 (if (eq (preceding-char) ?\))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
951 (forward-sexp -1))
531c20e5755b (perl-mode-syntax-table): Mark $, % and @
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 42896
diff changeset
952 ;; 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
953 (current-indentation))))))))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
954
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
955 (defun perl-backward-to-noncomment ()
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
956 "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
957 (interactive)
39569
9d258703ad61 (perl-indent-continued-arguments): New var.
Gerd Moellmann <gerd@gnu.org>
parents: 38014
diff changeset
958 (forward-comment (- (point-max))))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
959
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
960 (defun perl-backward-to-start-of-continued-exp (lim)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
961 (if (= (preceding-char) ?\))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
962 (forward-sexp -1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
963 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
964 (if (<= (point) lim)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
965 (goto-char (1+ lim)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
966 (skip-chars-forward " \t\f"))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
967
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
968 ;; 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
969 (defalias 'indent-perl-exp 'perl-indent-exp)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
970 (defun perl-indent-exp ()
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
971 "Indent each line of the Perl grouping following point."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
972 (interactive)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
973 (let* ((case-fold-search nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
974 (oldpnt (point-marker))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
975 (bof-mark (save-excursion
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
976 (end-of-line 2)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
977 (perl-beginning-of-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
978 (point-marker)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
979 eol last-mark lsexp-mark delta)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
980 (if (= (char-after (marker-position bof-mark)) ?=)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
981 (message "Can't indent a format statement")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
982 (message "Indenting Perl expression...")
111429
249a1455856a Use line-end-position rather than end-of-line, etc.
Glenn Morris <rgm@gnu.org>
parents: 111325
diff changeset
983 (setq eol (line-end-position))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
984 (save-excursion ; locate matching close paren
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
985 (while (and (not (eobp)) (<= (point) eol))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
986 (parse-partial-sexp (point) (point-max) 0))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
987 (setq last-mark (point-marker)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
988 (setq lsexp-mark bof-mark)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
989 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
990 (while (< (point) (marker-position last-mark))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
991 (setq delta (perl-indent-line nil (marker-position bof-mark)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
992 (if (numberp delta) ; unquoted start-of-line?
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48268
diff changeset
993 (progn
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
994 (if (eolp)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
995 (delete-horizontal-space))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
996 (setq lsexp-mark (point-marker))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
997 (end-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
998 (setq eol (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
999 (if (nth 4 (parse-partial-sexp (marker-position lsexp-mark) eol))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1000 (progn ; line ends in a comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1001 (beginning-of-line)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1002 (if (or (not (looking-at "\\s-*;?#"))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1003 (listp delta)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1004 (and (/= 0 delta)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1005 (= (- (current-indentation) delta) comment-column)))
16472
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
1006 (if (and comment-start-skip
dbfab9e8b6d8 (electric-perl-terminator, perl-indent-command):
Richard M. Stallman <rms@gnu.org>
parents: 16358
diff changeset
1007 (re-search-forward comment-start-skip eol t))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1008 (indent-for-comment))))) ; indent existing comment
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1009 (forward-line 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1010 (goto-char (marker-position oldpnt))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1011 (message "Indenting Perl expression...done"))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1012
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1013 (defun perl-beginning-of-function (&optional arg)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1014 "Move backward to next beginning-of-function, or as far as possible.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1015 With argument, repeat that many times; negative args move forward.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1016 Returns new value of point in all cases."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1017 (interactive "p")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1018 (or arg (setq arg 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1019 (if (< arg 0) (forward-char 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1020 (and (/= arg 0)
70376
64d64506f4b1 (perl-beginning-of-function): Skip anonymous subs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 69948
diff changeset
1021 (re-search-backward
64d64506f4b1 (perl-beginning-of-function): Skip anonymous subs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 69948
diff changeset
1022 "^\\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
1023 nil 'move arg)
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1024 (goto-char (1- (match-end 0))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1025 (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1026
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1027 ;; note: this routine is adapted directly from emacs lisp.el, end-of-defun;
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1028 ;; no bugs have been removed :-)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1029 (defun perl-end-of-function (&optional arg)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1030 "Move forward to next end-of-function.
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1031 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
1032 With argument, repeat that many times; negative args move backward."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1033 (interactive "p")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1034 (or arg (setq arg 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1035 (let ((first t))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1036 (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
1037 (let ((pos (point)))
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1038 (while (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1039 (if (and first
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1040 (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1041 (forward-char 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1042 (perl-beginning-of-function 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1043 (not (bobp))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1044 nil
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1045 (or (bobp) (forward-char -1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1046 (perl-beginning-of-function -1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1047 (setq first nil)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1048 (forward-list 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1049 (skip-chars-forward " \t")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1050 (if (looking-at "[#\n]")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1051 (forward-line 1))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1052 (<= (point) pos))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1053 (setq arg (1- arg)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1054 (while (< arg 0)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1055 (let ((pos (point)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1056 (perl-beginning-of-function 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1057 (forward-sexp 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1058 (forward-line 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1059 (if (>= (point) pos)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1060 (if (progn (perl-beginning-of-function 2) (not (bobp)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1061 (progn
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1062 (forward-list 1)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1063 (skip-chars-forward " \t")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1064 (if (looking-at "[#\n]")
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1065 (forward-line 1)))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1066 (goto-char (point-min)))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1067 (setq arg (1+ arg)))))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1068
37893
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
1069 (defalias 'mark-perl-function 'perl-mark-function)
e0beb50b7def (perl-mode): Use define-derived-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31985
diff changeset
1070 (defun perl-mark-function ()
475
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1071 "Put mark at end of Perl function, point at beginning."
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1072 (interactive)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1073 (push-mark (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1074 (perl-end-of-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1075 (push-mark (point))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1076 (perl-beginning-of-function)
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1077 (backward-paragraph))
fb215f87f4a9 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1078
16358
8b36369ba4de Add `provide' call.
Richard M. Stallman <rms@gnu.org>
parents: 14633
diff changeset
1079 (provide 'perl-mode)
8b36369ba4de Add `provide' call.
Richard M. Stallman <rms@gnu.org>
parents: 14633
diff changeset
1080
8b36369ba4de Add `provide' call.
Richard M. Stallman <rms@gnu.org>
parents: 14633
diff changeset
1081 ;;; perl-mode.el ends here