annotate lisp/progmodes/python.el @ 54880:f23c0b924770

*** empty log message ***
author Stefan Monnier <monnier@iro.umontreal.ca>
date Wed, 14 Apr 2004 18:58:45 +0000
parents 3768540a819c
children fb2f71e89f5f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1 ;;; python.el --- silly walks for Python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
2
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
3 ;; Copyright (C) 2003, 04 Free Software Foundation, Inc.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
4
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
5 ;; Author: Dave Love <fx@gnu.org>
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
6 ;; Created: Nov 2003
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
7 ;; Keywords: languages
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
8
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
9 ;; This file is part of GNU Emacs.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
10
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
11 ;; This file is free software; you can redistribute it and/or modify
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
12 ;; it under the terms of the GNU General Public License as published by
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
14 ;; any later version.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
15
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
16 ;; This file is distributed in the hope that it will be useful,
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
19 ;; GNU General Public License for more details.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
20
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
23 ;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
24 ;; Boston, MA 02111-1307, USA.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
25
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
26 ;;; Commentary:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
27
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
28 ;; Major mode for editing Python, with support for inferior processes.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
29
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
30 ;; There is another Python mode, python-mode.el, used by XEmacs and
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
31 ;; maintained with Python. That isn't covered by an FSF copyright
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
32 ;; assignment, unlike this code, and seems not to be well-maintained
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
33 ;; for Emacs (though I've submitted fixes). This mode is rather
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
34 ;; simpler and is, perhaps, better in other ways. In particular,
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
35 ;; using the syntax functions with text properties maintained by
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
36 ;; font-lock should make it more correct with arbitrary string and
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
37 ;; comment contents.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
38
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
39 ;; This doesn't implement all the facilities of python-mode.el. Some
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
40 ;; just need doing, e.g. catching exceptions in the inferior Python
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
41 ;; buffer (but see M-x pdb for debugging). [Actually, the use of
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
42 ;; `compilation-minor-mode' now is probably enough for that.] Others
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
43 ;; don't seem appropriate. For instance, `forward-into-nomenclature'
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
44 ;; should be done separately, since it's not specific to Python, and
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
45 ;; I've installed a minor mode to do the job properly in Emacs 22.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
46 ;; Other things seem more natural or canonical here, e.g. the
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
47 ;; {beginning,end}-of-defun implementation dealing with nested
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
48 ;; definitions, and the inferior mode following `cmuscheme'. (The
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
49 ;; inferior mode should be able to find the source of errors from
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
50 ;; `python-send-region' & al via `compilation-minor-mode', but I can't
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
51 ;; make that work with the current (March '04) compile.el.)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
52 ;; Successive TABs cycle between possible indentations for the line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
53
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
54 ;; Even where it has similar facilities, this is incompatible with
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
55 ;; python-mode.el in various respects. For instance, various key
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
56 ;; bindings are changed to obey Emacs conventions, and things like
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
57 ;; marking blocks and `beginning-of-defun' behave differently.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
58
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
59 ;; TODO: See various Fixmes below. It should be possible to arrange
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
60 ;; some sort of completion using the inferior interpreter.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
61
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
62 ;;; Code:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
63
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
64 ;; It's messy to autoload the relevant comint functions so that comint
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
65 ;; is only required when inferior Python is used.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
66 (require 'comint)
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
67 (eval-when-compile
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
68 (require 'compile)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
69 (autoload 'Info-last "info")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
70 (autoload 'Info-exit "info")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
71 (autoload 'info-lookup-maybe-add-help "info-look"))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
72 (autoload 'compilation-start "compile") ; spurious compiler warning anyway
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
73
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
74 (defgroup python nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
75 "Silly walks in the Python language"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
76 :group 'languages
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
77 :version "21.4"
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
78 :link '(emacs-commentary-link "python"))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
79
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
80 ;;;###autoload
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
81 (add-to-list 'interpreter-mode-alist '("jython" . jython-mode))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
82 ;;;###autoload
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
83 (add-to-list 'interpreter-mode-alist '("python" . python-mode))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
84 ;;;###autoload
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
85 (add-to-list 'auto-mode-alist '("\\.py\\'" . python-mode))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
86
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
87 ;;;; Font lock
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
88
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
89 (defvar python-font-lock-keywords
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
90 `(,(rx (and word-start
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
91 ;; From v 2.3 reference.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
92 ;; def and class dealt with separately below
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
93 (or "and" "assert" "break" "continue" "del" "elif" "else"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
94 "except" "exec" "finally" "for" "from" "global" "if"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
95 "import" "in" "is" "lambda" "not" "or" "pass" "print"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
96 "raise" "return" "try" "while" "yield"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
97 ;; Future keywords
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
98 "as" "None")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
99 word-end))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
100 (,(rx (and word-start (group "class") (1+ space) (group (1+ word))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
101 (1 font-lock-keyword-face) (2 font-lock-type-face))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
102 (,(rx (and word-start (group "def") (1+ space) (group (1+ word))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
103 (1 font-lock-keyword-face) (2 font-lock-function-name-face))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
104
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
105 (defconst python-font-lock-syntactic-keywords
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
106 ;; Make outer chars of matching triple-quote sequences into generic
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
107 ;; string delimiters. Fixme: Is there a better way?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
108 `((,(rx (and (group (optional (any "uUrR"))) ; prefix gets syntax property
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
109 (optional (any "rR")) ; possible second prefix
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
110 (group (syntax string-quote)) ; maybe gets property
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
111 (backref 2) ; per first quote
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
112 (group (backref 2)))) ; maybe gets property
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
113 (1 (python-quote-syntax 1))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
114 (2 (python-quote-syntax 2))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
115 (3 (python-quote-syntax 3)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
116 ;; This doesn't really help.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
117 ;;; (,(rx (and ?\\ (group ?\n))) (1 " "))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
118 ))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
119
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
120 (defun python-quote-syntax (n)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
121 "Put `syntax-table' property correctly on triple quote.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
122 Used for syntactic keywords. N is the match number (1, 2 or 3)."
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
123 ;; Given a triple quote, we have to check the context to know
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
124 ;; whether this is an opening or closing triple or whether it's
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
125 ;; quoted anyhow, and should be ignored. (For that we need to do
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
126 ;; the same job as `syntax-ppss' to be correct and it seems to be OK
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
127 ;; to use it here despite initial worries.) We also have to sort
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
128 ;; out a possible prefix -- well, we don't _have_ to, but I think it
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
129 ;; should be treated as part of the string.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
130
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
131 ;; Test cases:
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
132 ;; ur"""ar""" x='"' # """
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
133 ;; x = ''' """ ' a
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
134 ;; '''
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
135 ;; x '"""' x
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
136 (save-excursion
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
137 (goto-char (match-beginning 0))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
138 (unless (eq ?\\ (char-before))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
139 (cond
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
140 ;; Consider property for the last char if in a fenced string.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
141 ((= n 3)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
142 (let ((syntax (syntax-ppss)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
143 (when (eq t (nth 3 syntax)) ; after unclosed fence
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
144 (goto-char (nth 8 syntax)) ; fence position
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
145 ;; Skip any prefix.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
146 (if (memq (char-after) '(?u ?U ?R ?r))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
147 (skip-chars-forward "uUrR"))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
148 ;; Is it a matching sequence?
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
149 (if (eq (char-after) (char-after (match-beginning 2)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
150 (eval-when-compile (string-to-syntax "|"))))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
151 ;; Consider property for initial char, accounting for prefixes.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
152 ((or (and (= n 2) ; not prefix
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
153 (= (match-beginning 1) (match-end 1))) ; prefix is null
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
154 (and (= n 1) ; prefix
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
155 (/= (match-beginning 1) (match-end 1)))) ; non-empty
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
156 (unless (eq 'string (syntax-ppss-context (syntax-ppss)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
157 (eval-when-compile (string-to-syntax "|")))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
158 ;; Otherwise (we're in a non-matching string) the property is
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
159 ;; nil, which is OK.
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
160 )))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
161
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
162 ;; This isn't currently in `font-lock-defaults' as probably not worth
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
163 ;; it -- we basically only mess with a few normally-symbol characters.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
164
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
165 ;; (defun python-font-lock-syntactic-face-function (state)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
166 ;; "`font-lock-syntactic-face-function' for Python mode.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
167 ;; Returns the string or comment face as usual, with side effect of putting
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
168 ;; a `syntax-table' property on the inside of the string or comment which is
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
169 ;; the standard syntax table."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
170 ;; (if (nth 3 state)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
171 ;; (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
172 ;; (goto-char (nth 8 state))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
173 ;; (condition-case nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
174 ;; (forward-sexp)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
175 ;; (error nil))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
176 ;; (put-text-property (1+ (nth 8 state)) (1- (point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
177 ;; 'syntax-table (standard-syntax-table))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
178 ;; 'font-lock-string-face)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
179 ;; (put-text-property (1+ (nth 8 state)) (line-end-position)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
180 ;; 'syntax-table (standard-syntax-table))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
181 ;; 'font-lock-comment-face))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
182
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
183 ;;;; Keymap and syntax
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
184
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
185 (defvar python-mode-map
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
186 (let ((map (make-sparse-keymap)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
187 ;; Mostly taken from python-mode.el.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
188 (define-key map ":" 'python-electric-colon)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
189 (define-key map "\177" 'python-backspace)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
190 (define-key map "\C-c<" 'python-shift-left)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
191 (define-key map "\C-c>" 'python-shift-right)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
192 (define-key map "\C-c\C-k" 'python-mark-block)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
193 (define-key map "\C-c\C-n" 'python-next-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
194 (define-key map "\C-c\C-p" 'python-previous-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
195 (define-key map "\C-c\C-u" 'python-beginning-of-block)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
196 (define-key map "\C-c\C-f" 'python-describe-symbol)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
197 (define-key map "\C-c\C-w" 'python-check)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
198 (define-key map "\C-c\C-v" 'python-check) ; a la sgml-mode
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
199 (define-key map "\C-c\C-s" 'python-send-string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
200 (define-key map [?\C-\M-x] 'python-send-defun)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
201 (define-key map "\C-c\C-r" 'python-send-region)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
202 (define-key map "\C-c\M-r" 'python-send-region-and-go)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
203 (define-key map "\C-c\C-c" 'python-send-buffer)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
204 (define-key map "\C-c\C-z" 'python-switch-to-python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
205 (define-key map "\C-c\C-m" 'python-load-file)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
206 (define-key map "\C-c\C-l" 'python-load-file) ; a la cmuscheme
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
207 ;; Fixme: Add :help to menu.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
208 (easy-menu-define python-menu map "Python Mode menu"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
209 '("Python"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
210 ["Shift region left" python-shift-left :active mark-active]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
211 ["Shift region right" python-shift-right :active mark-active]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
212 "-"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
213 ["Mark block" python-mark-block]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
214 ["Mark def/class" mark-defun
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
215 :help "Mark innermost definition around point"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
216 "-"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
217 ["Start of block" python-beginning-of-block]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
218 ["End of block" python-end-of-block]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
219 ["Start of def/class" beginning-of-defun
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
220 :help "Go to start of innermost definition around point"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
221 ["End of def/class" end-of-defun
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
222 :help "Go to end of innermost definition around point"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
223 "-"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
224 ["Start interpreter" run-python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
225 :help "Run `inferior' Python in separate buffer"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
226 ["Import/reload file" python-load-file
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
227 :help "Load into inferior Python session"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
228 ["Eval buffer" python-send-buffer
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
229 :help "Evaluate buffer en bloc in inferior Python session"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
230 ["Eval region" python-send-region :active mark-active
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
231 :help "Evaluate region en bloc in inferior Python session"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
232 ["Eval def/class" python-send-defun
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
233 :help "Evaluate current definition in inferior Python session"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
234 ["Switch to interpreter" python-switch-to-python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
235 :help "Switch to inferior Python buffer"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
236 ["Check file" python-check :help "Run pychecker"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
237 ["Debugger" pdb :help "Run pdb under GUD"]
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
238 "-"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
239 ["Help on symbol" python-describe-symbol
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
240 :help "Use pydoc on symbol at point"]))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
241 map))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
242
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
243 (defvar python-mode-syntax-table
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
244 (let ((table (make-syntax-table)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
245 ;; Give punctuation syntax to ASCII that normally has symbol
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
246 ;; syntax or has word syntax and isn't a letter.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
247 (let ((symbol (string-to-syntax "_"))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
248 (sst (standard-syntax-table)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
249 (dotimes (i 128)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
250 (unless (= i ?_)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
251 (if (equal symbol (aref sst i))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
252 (modify-syntax-entry i "." table)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
253 (modify-syntax-entry ?$ "." table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
254 (modify-syntax-entry ?% "." table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
255 ;; exceptions
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
256 (modify-syntax-entry ?# "<" table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
257 (modify-syntax-entry ?\n ">" table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
258 (modify-syntax-entry ?' "\"" table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
259 (modify-syntax-entry ?` "$" table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
260 table))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
261
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
262 ;;;; Utility stuff
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
263
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
264 (defsubst python-in-string/comment ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
265 "Return non-nil if point is in a Python literal (a comment or string).
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
266 Optional argument LIM indicates the beginning of the containing form,
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
267 i.e. the limit on how far back to scan."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
268 (syntax-ppss-context (syntax-ppss)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
269
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
270 (defconst python-space-backslash-table
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
271 (let ((table (copy-syntax-table python-mode-syntax-table)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
272 (modify-syntax-entry ?\\ " " table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
273 table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
274 "`python-mode-syntax-table' with backslash given whitespace syntax.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
275
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
276 (defun python-skip-comments/blanks (&optional backward)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
277 "Skip comments and blank lines.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
278 BACKWARD non-nil means go backwards, otherwise go forwards. Backslash is
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
279 treated as whitespace so that continued blank lines are skipped.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
280 Doesn't move out of comments -- should be outside or at end of line."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
281 (with-syntax-table python-space-backslash-table
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
282 (forward-comment (if backward
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
283 most-negative-fixnum
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
284 most-positive-fixnum))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
285
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
286 (defun python-backslash-continuation-line-p ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
287 "Non-nil if preceding line ends with backslash that is not in a comment."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
288 (and (eq ?\\ (char-before (line-end-position 0)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
289 (not (syntax-ppss-context (syntax-ppss)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
290
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
291 (defun python-continuation-line-p ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
292 "Return non-nil if current line continues a previous one.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
293 The criteria are that the previous line ends in a backslash outside
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
294 comments and strings, or that the bracket/paren nesting depth is nonzero."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
295 (or (and (eq ?\\ (char-before (line-end-position 0)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
296 (not (syntax-ppss-context (syntax-ppss))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
297 (/= 0 (syntax-ppss-depth
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
298 (save-excursion ; syntax-ppss with arg changes point
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
299 (syntax-ppss (line-beginning-position)))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
300
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
301 (defun python-comment-line-p ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
302 "Return non-nil if current line has only a comment or is blank."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
303 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
304 (back-to-indentation)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
305 (looking-at (rx (or (syntax comment-start) line-end)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
306
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
307 (defun python-beginning-of-string ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
308 "Go to beginning of string around point.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
309 Do nothing if not in string."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
310 (let ((state (syntax-ppss)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
311 (when (nth 3 state)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
312 (goto-char (nth 8 state)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
313
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
314 (defun python-open-block-statement-p (&optional bos)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
315 "Return non-nil if statement at point opens a block.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
316 BOS non-nil means point is known to be at beginning of statement."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
317 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
318 (unless bos (python-beginning-of-statement))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
319 (and (not (python-comment-line-p))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
320 (re-search-forward (rx (and ?: (0+ space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
321 (optional (and (syntax comment-start)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
322 (0+ not-newline)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
323 line-end))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
324 (save-excursion (python-end-of-statement))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
325 t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
326 (not (python-in-string/comment)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
327
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
328 (defun python-close-block-statement-p (&optional bos)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
329 "Return non-nil if current line is a statement closing a block.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
330 BOS non-nil means point is at beginning of statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
331 The criteria are that the line isn't a comment or in string and starts with
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
332 keyword `raise', `break', `continue' or `pass'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
333 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
334 (unless bos (python-beginning-of-statement))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
335 (back-to-indentation)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
336 (looking-at (rx (and (or "return" "raise" "break" "continue" "pass")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
337 word-end)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
338
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
339 (defun python-outdent-p ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
340 "Return non-nil if current line should outdent a level."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
341 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
342 (back-to-indentation)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
343 (and (looking-at (rx (and (or (and (or "else" "finally") word-end)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
344 (and (or "except" "elif") word-end
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
345 (1+ (not (any ?:)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
346 (optional space) ":" (optional space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
347 (or (syntax comment-start) line-end))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
348 (progn (end-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
349 (not (python-in-string/comment)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
350 ;; Ensure there's a previous statement and move to it.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
351 (zerop (python-previous-statement))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
352 (not (python-close-block-statement-p t))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
353 ;; Fixme: check this
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
354 (not (looking-at (rx (and (or (and (or "if" "elif" "except"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
355 "for" "while")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
356 word-end (1+ (not (any ?:))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
357 (and "try" word-end))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
358 (optional space) ":" (optional space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
359 (or (syntax comment-start) line-end)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
360 (progn (end-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
361 (not (python-in-string/comment))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
362
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
363 ;;;; Indentation.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
364
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
365 (defcustom python-indent 4
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
366 "*Number of columns for a unit of indentation in Python mode.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
367 See also `\\[python-guess-indent]'"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
368 :group 'python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
369 :type 'integer)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
370
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
371 (defcustom python-guess-indent t
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
372 "*Non-nil means Python mode guesses `python-indent' for the buffer."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
373 :type 'boolean
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
374 :group 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
375
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
376 (defcustom python-indent-string-contents t
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
377 "*Non-nil means indent contents of multi-line strings together.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
378 This means indent them the same as the preceding non-blank line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
379 Otherwise indent them to column zero."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
380 :type '(choice (const :tag "Align with preceding" t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
381 (const :tag "Indent to column 0" nil))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
382 :group 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
383
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
384 (defcustom python-honour-comment-indentation nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
385 "Non-nil means indent relative to preceding comment line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
386 Only do this for comments where the leading comment character is followed
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
387 by space."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
388 :type 'boolean
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
389 :group 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
390
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
391 (defcustom python-continuation-offset 4
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
392 "*Number of columns of additional indentation for continuation lines.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
393 Continuation lines follow a backslash-terminated line starting a statement."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
394 :group 'python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
395 :type 'integer)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
396
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
397 (defun python-guess-indent ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
398 "Guess step for indentation of current buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
399 Set `python-indent' locally to the value guessed."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
400 (interactive)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
401 (save-excursion
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
402 (save-restriction
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
403 (widen)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
404 (goto-char (point-min))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
405 (let (done indent)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
406 (while (and (not done) (not (eobp)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
407 (when (and (re-search-forward (rx (and ?: (0+ space)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
408 (or (syntax comment-start)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
409 line-end)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
410 nil 'move)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
411 (python-open-block-statement-p))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
412 (save-excursion
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
413 (python-beginning-of-statement)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
414 (let ((initial (current-indentation)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
415 (if (zerop (python-next-statement))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
416 (setq indent (- (current-indentation) initial)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
417 (if (and (>= indent 2) (<= indent 8)) ; sanity check
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
418 (setq done t))))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
419 (when done
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
420 (when (/= indent (default-value 'python-indent))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
421 (set (make-local-variable 'python-indent) indent)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
422 (unless (= tab-width python-indent)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
423 (setq indent-tabs-mode nil)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
424 indent)))))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
425
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
426 (defun python-calculate-indentation ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
427 "Calculate Python indentation for line at point."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
428 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
429 (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
430 (let ((syntax (syntax-ppss))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
431 start)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
432 (cond
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
433 ((eq 'string (syntax-ppss-context syntax)) ; multi-line string
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
434 (if (not python-indent-string-contents)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
435 0
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
436 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
437 ;; Find indentation of preceding non-blank line within string.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
438 (setq start (nth 8 syntax))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
439 (forward-line -1)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
440 (while (and (< start (point)) (looking-at "\\s-*$"))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
441 (forward-line -1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
442 (current-indentation))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
443 ((python-continuation-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
444 (let ((point (point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
445 (open-start (cadr syntax)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
446 (if open-start
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
447 ;; Inside bracketed expression.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
448 (progn
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
449 (goto-char (1+ open-start))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
450 ;; Look for first item in list (preceding point) and
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
451 ;; align with it, if found.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
452 (if (with-syntax-table python-space-backslash-table
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
453 (let ((parse-sexp-ignore-comments t))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
454 (condition-case ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
455 (progn (forward-sexp)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
456 (backward-sexp)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
457 (< (point) point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
458 (error nil))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
459 (current-column)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
460 ;; Otherwise indent relative to statement start, one
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
461 ;; level per bracketing level.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
462 (goto-char (1+ open-start))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
463 (python-beginning-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
464 (+ (current-indentation) (* (car syntax) python-indent))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
465 ;; Otherwise backslash-continued.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
466 (forward-line -1)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
467 (if (python-continuation-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
468 ;; We're past first continuation line. Align with
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
469 ;; previous line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
470 (current-indentation)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
471 ;; First continuation line. Indent one step, with an
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
472 ;; extra one if statement opens a block.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
473 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
474 (python-beginning-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
475 (+ (current-indentation) python-continuation-offset
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
476 (if (python-open-block-statement-p t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
477 python-indent
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
478 0)))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
479 ((bobp) 0)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
480 ;; Fixme: Like python-mode.el; not convinced by this.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
481 ((looking-at (rx (and (0+ space) (syntax comment-start)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
482 (not (any " \t\n"))))) ; non-indentable comment
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
483 (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
484 (t (let ((point (point)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
485 (if python-honour-comment-indentation
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
486 ;; Back over whitespace, newlines, non-indentable comments.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
487 (catch 'done
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
488 (while t
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
489 (if (cond ((bobp))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
490 ;; not at comment start
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
491 ((not (forward-comment -1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
492 (python-beginning-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
493 t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
494 ;; trailing comment
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
495 ((/= (current-column) (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
496 (python-beginning-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
497 t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
498 ;; indentable comment like python-mode.el
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
499 ((and (looking-at (rx (and (syntax comment-start)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
500 (or space line-end))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
501 (/= 0 (current-column)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
502 (throw 'done t))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
503 ;; Else back over all comments.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
504 (python-skip-comments/blanks t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
505 (python-beginning-of-statement))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
506 ;; don't lose on bogus outdent
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
507 (max 0 (+ (current-indentation)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
508 (or (cond ((python-open-block-statement-p t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
509 python-indent)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
510 ((python-close-block-statement-p t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
511 (- python-indent)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
512 (progn (goto-char point)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
513 (if (python-outdent-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
514 (- python-indent)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
515 0)))))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
516
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
517 ;;;; Cycling through the possible indentations with successive TABs.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
518
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
519 ;; These don't need to be buffer-local since they're only relevant
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
520 ;; during a cycle.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
521
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
522 ;; Alist of possible indentations and start of statement they would close.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
523 (defvar python-indent-list nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
524 "Internal use.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
525 ;; Length of the above
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
526 (defvar python-indent-list-length nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
527 "Internal use.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
528 ;; Current index into the alist.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
529 (defvar python-indent-index nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
530 "Internal use.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
531
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
532 (defun python-initial-text ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
533 "Text of line following indentation and ignoring any trailing comment."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
534 (buffer-substring (+ (line-beginning-position) (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
535 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
536 (end-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
537 (forward-comment -1)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
538 (point))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
539
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
540 (defun python-indentation-levels ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
541 "Return a list of possible indentations for this statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
542 Includes the default indentation and those which would close all
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
543 enclosing blocks."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
544 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
545 (let ((levels (list (cons (current-indentation) nil))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
546 ;; Only one possibility if we immediately follow a block open or
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
547 ;; are in a continuation line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
548 (unless (or (python-continuation-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
549 (save-excursion (and (python-previous-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
550 (python-open-block-statement-p t))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
551 (while (python-beginning-of-block)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
552 (push (cons (current-indentation) (python-initial-text))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
553 levels)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
554 levels)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
555
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
556 ;; This is basically what `python-indent-line' would be if we didn't
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
557 ;; do the cycling.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
558 (defun python-indent-line-1 ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
559 "Subroutine of `python-indent-line'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
560 (let ((target (python-calculate-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
561 (pos (- (point-max) (point))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
562 (if (= target (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
563 (if (< (current-column) (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
564 (back-to-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
565 (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
566 (delete-horizontal-space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
567 (indent-to target)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
568 (if (> (- (point-max) pos) (point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
569 (goto-char (- (point-max) pos))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
570
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
571 ;; Fixme: Is the arg necessary?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
572 (defun python-indent-line (&optional arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
573 "Indent current line as Python code.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
574 When invoked via `indent-for-tab-command', cycle through possible
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
575 indentations for current line. The cycle is broken by a command different
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
576 from `indent-for-tab-command', i.e. successive TABs do the cycling."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
577 (interactive)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
578 ;; Don't do extra work if invoked via `indent-region', for instance.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
579 (if (not (eq this-command 'indent-for-tab-command))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
580 (python-indent-line-1)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
581 (if (eq last-command this-command)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
582 (if (= 1 python-indent-list-length)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
583 (message "Sole indentation")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
584 (progn (setq python-indent-index (% (1+ python-indent-index)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
585 python-indent-list-length))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
586 (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
587 (delete-horizontal-space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
588 (indent-to (car (nth python-indent-index python-indent-list)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
589 (let ((text (cdr (nth python-indent-index
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
590 python-indent-list))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
591 (if text (message "Closes: %s" text)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
592 (python-indent-line-1)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
593 (setq python-indent-list (python-indentation-levels)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
594 python-indent-list-length (length python-indent-list)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
595 python-indent-index (1- python-indent-list-length)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
596
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
597 ;;;; Movement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
598
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
599 (defun python-beginning-of-defun ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
600 "`beginning-of-defun-function' for Python.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
601 Finds beginning of innermost nested class or method definition.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
602 Returns the name of the definition found at the end, or nil if reached
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
603 start of buffer."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
604 (let ((ci (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
605 (def-re (rx (and line-start (0+ space) (or "def" "class")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
606 (1+ space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
607 (group (1+ (or word (syntax symbol)))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
608 point found lep def-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
609 (if (python-comment-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
610 (setq ci most-positive-fixnum))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
611 (while (and (not (bobp)) (not found))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
612 ;; Treat bol at beginning of function as outside function so
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
613 ;; that successive C-M-a makes progress backwards.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
614 (setq def-line (looking-at def-re))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
615 (unless (bolp) (end-of-line))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
616 (setq lep (line-end-position))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
617 (if (and (re-search-backward def-re nil 'move)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
618 ;; Must be less indented or matching top level, or
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
619 ;; equally indented if we started on a definition line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
620 (let ((in (current-indentation)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
621 (or (and (zerop ci) (zerop in))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
622 (= lep (line-end-position)) ; on initial line
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
623 (and def-line (= in ci))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
624 (< in ci)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
625 (not (python-in-string/comment)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
626 (setq found t)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
627
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
628 (defun python-end-of-defun ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
629 "`end-of-defun-function' for Python.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
630 Finds end of innermost nested class or method definition."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
631 (let ((orig (point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
632 (pattern (rx (and line-start (0+ space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
633 (or "def" "class") space))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
634 ;; Go to start of current block and check whether it's at top
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
635 ;; level. If it is, and not a block start, look forward for
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
636 ;; definition statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
637 (when (python-comment-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
638 (end-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
639 (forward-comment most-positive-fixnum))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
640 (if (not (python-open-block-statement-p))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
641 (python-beginning-of-block))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
642 (if (zerop (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
643 (unless (python-open-block-statement-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
644 (while (and (re-search-forward pattern nil 'move)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
645 (python-in-string/comment))) ; just loop
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
646 (unless (eobp)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
647 (beginning-of-line)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
648 ;; Don't move before top-level statement that would end defun.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
649 (end-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
650 (python-beginning-of-defun))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
651 ;; If we got to the start of buffer, look forward for
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
652 ;; definition statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
653 (if (and (bobp) (not (looking-at "def\\|class")))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
654 (while (and (not (eobp))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
655 (re-search-forward pattern nil 'move)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
656 (python-in-string/comment)))) ; just loop
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
657 ;; We're at a definition statement (or end-of-buffer).
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
658 (unless (eobp)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
659 (python-end-of-block)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
660 ;; Count trailing space in defun (but not trailing comments).
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
661 (skip-syntax-forward " >")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
662 (beginning-of-line))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
663 ;; Catch pathological case like this, where the beginning-of-defun
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
664 ;; skips to a definition we're not in:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
665 ;; if ...:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
666 ;; ...
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
667 ;; else:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
668 ;; ... # point here
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
669 ;; ...
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
670 ;; def ...
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
671 (if (< (point) orig)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
672 (goto-char (point-max)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
673
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
674 (defun python-beginning-of-statement ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
675 "Go to start of current statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
676 Accounts for continuation lines, multi-line strings, and multi-line bracketed
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
677 expressions."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
678 (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
679 (python-beginning-of-string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
680 (while (python-continuation-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
681 (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
682 (if (python-backslash-continuation-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
683 (while (python-backslash-continuation-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
684 (forward-line -1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
685 (python-beginning-of-string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
686 ;; Skip forward out of nested brackets.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
687 (condition-case () ; beware invalid syntax
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
688 (progn (backward-up-list (syntax-ppss-depth (syntax-ppss))) t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
689 (error (end-of-line)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
690 (back-to-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
691
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
692 (defun python-end-of-statement ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
693 "Go to the end of the current statement and return point.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
694 Usually this is the start of the next line, but if this is a
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
695 multi-line statement we need to skip over the continuation lines.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
696 On a comment line, go to end of line."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
697 (end-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
698 (while (let (comment)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
699 ;; Move past any enclosing strings and sexps, or stop if
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
700 ;; we're in a comment.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
701 (while (let ((s (syntax-ppss)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
702 (cond ((eq 'comment (syntax-ppss-context s))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
703 (setq comment t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
704 nil)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
705 ((eq 'string (syntax-ppss-context s))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
706 ;; Go to start of string and skip it.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
707 (goto-char (nth 8 s))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
708 (condition-case () ; beware invalid syntax
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
709 (progn (forward-sexp) t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
710 (error (end-of-line))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
711 ((> (syntax-ppss-depth s) 0)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
712 ;; Skip forward out of nested brackets.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
713 (condition-case () ; beware invalid syntax
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
714 (progn (backward-up-list
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
715 (- (syntax-ppss-depth s)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
716 t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
717 (error (end-of-line))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
718 (end-of-line))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
719 (unless comment
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
720 (eq ?\\ (char-before)))) ; Line continued?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
721 (end-of-line 2)) ; Try next line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
722 (point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
723
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
724 (defun python-previous-statement (&optional count)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
725 "Go to start of previous statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
726 With argument COUNT, do it COUNT times. Stop at beginning of buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
727 Return count of statements left to move."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
728 (interactive "p")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
729 (unless count (setq count 1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
730 (if (< count 0)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
731 (python-next-statement (- count))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
732 (python-beginning-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
733 (while (and (> count 0) (not (bobp)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
734 (python-skip-comments/blanks t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
735 (python-beginning-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
736 (unless (bobp) (setq count (1- count))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
737 count))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
738
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
739 (defun python-next-statement (&optional count)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
740 "Go to start of next statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
741 With argument COUNT, do it COUNT times. Stop at end of buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
742 Return count of statements left to move."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
743 (interactive "p")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
744 (unless count (setq count 1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
745 (if (< count 0)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
746 (python-previous-statement (- count))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
747 (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
748 (while (and (> count 0) (not (eobp)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
749 (python-end-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
750 (python-skip-comments/blanks)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
751 (setq count (1- count)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
752 count))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
753
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
754 (defun python-beginning-of-block (&optional arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
755 "Go to start of current block.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
756 With numeric arg, do it that many times. If ARG is negative, call
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
757 `python-end-of-block' instead.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
758 If point is on the first line of a block, use its outer block.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
759 If current statement is in column zero, don't move and return nil.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
760 Otherwise return non-nil."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
761 (interactive "p")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
762 (unless arg (setq arg 1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
763 (cond
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
764 ((zerop arg))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
765 ((< arg 0) (python-end-of-block (- arg)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
766 (t
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
767 (let ((point (point)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
768 (if (python-comment-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
769 (python-skip-comments/blanks t))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
770 (python-beginning-of-statement)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
771 (let ((ci (current-indentation)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
772 (if (zerop ci)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
773 (not (goto-char point)) ; return nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
774 ;; Look upwards for less indented statement.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
775 (if (catch 'done
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
776 ;;; This is slower than the below.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
777 ;;; (while (zerop (python-previous-statement))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
778 ;;; (when (and (< (current-indentation) ci)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
779 ;;; (python-open-block-statement-p t))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
780 ;;; (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
781 ;;; (throw 'done t)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
782 (while (and (zerop (forward-line -1)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
783 (when (and (< (current-indentation) ci)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
784 (not (python-comment-line-p))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
785 ;; Move to beginning to save effort in case
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
786 ;; this is in string.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
787 (progn (python-beginning-of-statement) t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
788 (python-open-block-statement-p t))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
789 (beginning-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
790 (throw 'done t)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
791 (not (goto-char point))) ; Failed -- return nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
792 (python-beginning-of-block (1- arg)))))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
793
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
794 (defun python-end-of-block (&optional arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
795 "Go to end of current block.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
796 With numeric arg, do it that many times. If ARG is negative, call
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
797 `python-beginning-of-block' instead.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
798 If current statement is in column zero and doesn't open a block, don't
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
799 move and return nil. Otherwise return t."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
800 (interactive "p")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
801 (unless arg (setq arg 1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
802 (if (< arg 0)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
803 (python-beginning-of-block (- arg)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
804 (while (and (> arg 0)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
805 (let* ((point (point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
806 (_ (if (python-comment-line-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
807 (python-skip-comments/blanks t)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
808 (ci (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
809 (open (python-open-block-statement-p)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
810 (if (and (zerop ci) (not open))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
811 (not (goto-char point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
812 (catch 'done
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
813 (while (zerop (python-next-statement))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
814 (when (or (and open (<= (current-indentation) ci))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
815 (< (current-indentation) ci))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
816 (python-skip-comments/blanks t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
817 (beginning-of-line 2)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
818 (throw 'done t)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
819 (not (goto-char point))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
820 (setq arg (1- arg)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
821 (zerop arg))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
822
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
823 ;;;; Imenu.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
824
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
825 (defun python-imenu-create-index ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
826 "`imenu-create-index-function' for Python.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
827
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
828 Makes nested Imenu menus from nested `class' and `def' statements.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
829 The nested menus are headed by an item referencing the outer
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
830 definition; it has a space prepended to the name so that it sorts
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
831 first with `imenu--sort-by-name'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
832 (unless (boundp 'recursing) ; dynamically bound below
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
833 (goto-char (point-min))) ; normal call from Imenu
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
834 (let (index-alist ; accumulated value to return
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
835 name is-class pos)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
836 (while (re-search-forward
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
837 (rx (and line-start (0+ space) ; leading space
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
838 (or (group "def") (group "class")) ; type
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
839 (1+ space) (group (1+ (or word ?_))))) ; name
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
840 nil t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
841 (unless (python-in-string/comment)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
842 (let ((pos (match-beginning 0))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
843 (name (match-string-no-properties 3)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
844 (if (match-beginning 2) ; def or class?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
845 (setq name (concat "class " name)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
846 (save-restriction
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
847 (narrow-to-defun)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
848 (let* ((recursing t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
849 (sublist (python-imenu-create-index)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
850 (if sublist
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
851 (progn (push (cons (concat " " name) pos) sublist)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
852 (push (cons name sublist) index-alist))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
853 (push (cons name pos) index-alist)))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
854 (nreverse index-alist)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
855
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
856 ;;;; `Electric' commands.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
857
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
858 (defun python-electric-colon (arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
859 "Insert a colon and maybe outdent the line if it is a statement like `else'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
860 With numeric ARG, just insert that many colons. With \\[universal-argument],
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
861 just insert a single colon."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
862 (interactive "*P")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
863 (self-insert-command (if (not (integerp arg)) 1 arg))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
864 (and (not arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
865 (eolp)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
866 (python-outdent-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
867 (not (python-in-string/comment))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
868 (> (current-indentation) (python-calculate-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
869 (python-indent-line))) ; OK, do it
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
870 (put 'python-electric-colon 'delete-selection t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
871
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
872 (defun python-backspace (arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
873 "Maybe delete a level of indentation on the current line.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
874 If not at the end of line's indentation, or on a comment line, just call
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
875 `backward-delete-char-untabify'. With ARG, repeat that many times."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
876 (interactive "*p")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
877 (if (or (/= (current-indentation) (current-column))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
878 (bolp)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
879 (python-continuation-line-p))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
880 (backward-delete-char-untabify arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
881 (let ((indent 0))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
882 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
883 (while (and (> arg 0) (python-beginning-of-block))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
884 (setq arg (1- arg)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
885 (when (zerop arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
886 (setq indent (current-indentation))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
887 (message "Closes %s" (python-initial-text))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
888 (delete-horizontal-space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
889 (indent-to indent))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
890 (put 'python-backspace 'delete-selection 'supersede)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
891
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
892 ;;;; pychecker
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
893
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
894 (defcustom python-check-command "pychecker --stdlib"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
895 "*Command used to check a Python file."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
896 :type 'string
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
897 :group 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
898
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
899 (defvar python-saved-check-command nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
900 "Internal use.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
901
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
902 ;; After `sgml-validate-command'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
903 (defun python-check (command)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
904 "Check a Python file (default current buffer's file).
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
905 Runs COMMAND, a shell command, as if by `compile'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
906 See `python-check-command' for the default."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
907 (interactive
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
908 (list (read-string "Checker command: "
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
909 (or python-saved-check-command
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
910 (concat python-check-command " "
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
911 (let ((name (buffer-file-name)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
912 (if name
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
913 (file-name-nondirectory name))))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
914 (setq python-saved-check-command command)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
915 (save-some-buffers (not compilation-ask-about-save) nil)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
916 (compilation-start command))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
917
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
918 ;;;; Inferior mode stuff (following cmuscheme).
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
919
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
920 (defcustom python-python-command "python"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
921 "*Shell command to run Python interpreter.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
922 Any arguments can't contain whitespace."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
923 :group 'python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
924 :type 'string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
925
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
926 (defcustom python-jython-command "jython"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
927 "*Shell command to run Jython interpreter.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
928 Any arguments can't contain whitespace."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
929 :group 'python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
930 :type 'string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
931
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
932 (defvar python-command python-python-command
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
933 "Actual command used to run Python.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
934 May be `python-python-command' or `python-jython-command'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
935 Additional arguments are added when the command is used by `run-python'
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
936 et al.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
937
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
938 (defvar python-buffer nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
939 "*The current python process buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
940 To run multiple Python processes, start the first with \\[run-python].
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
941 It will be in a buffer named *Python*. Rename that with
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
942 \\[rename-buffer]. Now start a new process with \\[run-python]. It
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
943 will be in a new buffer, named *Python*. Switch between the different
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
944 process buffers with \\[switch-to-buffer].
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
945
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
946 Commands that send text from source buffers to Python processes have
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
947 to choose a process to send to. This is determined by global variable
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
948 `python-buffer'. Suppose you have three inferior Pythons running:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
949 Buffer Process
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
950 foo python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
951 bar python<2>
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
952 *Python* python<3>
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
953 If you do a \\[python-send-region-and-go] command on some Python source
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
954 code, what process does it go to?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
955
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
956 - In a process buffer (foo, bar, or *Python*), send it to that process.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
957 - In some other buffer (e.g. a source file), send it to the process
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
958 attached to `python-buffer'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
959 Process selection is done by function `python-proc'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
960
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
961 Whenever \\[run-python] starts a new process, it resets `python-buffer'
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
962 to be the new process's buffer. If you only run one process, this will
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
963 do the right thing. If you run multiple processes, you can change
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
964 `python-buffer' to another process buffer with \\[set-variable].")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
965
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
966 (defconst python-compilation-regexp-alist
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
967 `((,(rx (and line-start (1+ (any " \t")) "File \""
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
968 (group (1+ (not (any "\"<")))) ; avoid `<stdin>' &c
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
969 "\", line " (group (1+ digit))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
970 1 python-compilation-line-number))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
971 "`compilation-error-regexp-alist' for inferior Python.")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
972
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
973 (define-derived-mode inferior-python-mode comint-mode "Inferior Python"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
974 "Major mode for interacting with an inferior Python process.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
975 A Python process can be started with \\[run-python].
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
976
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
977 Hooks `comint-mode-hook' and `inferior-python-mode-hook' are run in
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
978 that order.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
979
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
980 You can send text to the inferior Python process from other buffers containing
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
981 Python source.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
982 * `python-switch-to-python' switches the current buffer to the Python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
983 process buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
984 * `python-send-region' sends the current region to the Python process.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
985 * `python-send-region-and-go' switches to the Python process buffer
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
986 after sending the text.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
987 For running multiple processes in multiple buffers, see `python-buffer'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
988
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
989 \\{inferior-python-mode-map}"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
990 :group 'python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
991 (set-syntax-table python-mode-syntax-table)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
992 (setq mode-line-process '(":%s"))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
993 ;; Fixme: Maybe install some python-mode bindings too.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
994 (define-key inferior-python-mode-map "\C-c\C-l" 'python-load-file)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
995 (define-key inferior-python-mode-map "\C-c\C-z" 'python-switch-to-python)
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
996 (add-hook 'comint-input-filter-functions 'python-input-filter nil t)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
997 (add-hook 'comint-preoutput-filter-functions #'python-preoutput-filter
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
998 nil t)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
999 ;; Still required by `comint-redirect-send-command', for instance:
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1000 (set (make-local-variable 'comint-prompt-regexp) "^\\([>.]\\{3\\} \\)+")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1001 (set (make-local-variable 'compilation-error-regexp-alist)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1002 python-compilation-regexp-alist)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1003 (compilation-shell-minor-mode 1))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1004
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1005 (defcustom inferior-python-filter-regexp "\\`\\s-*\\S-?\\S-?\\s-*\\'"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1006 "*Input matching this regexp is not saved on the history list.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1007 Default ignores all inputs of 0, 1, or 2 non-blank characters."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1008 :type 'regexp
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1009 :group 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1010
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1011 (defvar python-orig-start-line nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1012 "Line number at start of region sent to inferior Python.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1013
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1014 (defvar python-orig-file nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1015 "File name to associate with errors found in inferior Python.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1016
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1017 (defun python-input-filter (str)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1018 "`comint-input-filter' function for inferior Python.
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1019 Don't save anything for STR matching `inferior-python-filter-regexp'.
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1020 Also resets variables for adjusting error messages."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1021 (setq python-orig-file nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1022 python-orig-start-line 1)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1023 (not (string-match inferior-python-filter-regexp str)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1024
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1025 ;; Fixme: Loses with quoted whitespace.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1026 (defun python-args-to-list (string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1027 (let ((where (string-match "[ \t]" string)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1028 (cond ((null where) (list string))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1029 ((not (= where 0))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1030 (cons (substring string 0 where)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1031 (python-args-to-list (substring string (+ 1 where)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1032 (t (let ((pos (string-match "[^ \t]" string)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1033 (if pos (python-args-to-list (substring string pos))))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1034
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1035 (defun python-compilation-line-number (file col)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1036 "Return error descriptor of error found for FILE, column COL.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1037 Used as line-number hook function in `python-compilation-regexp-alist'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1038 (let ((line (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1039 (goto-char (match-beginning 2))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1040 (read (current-buffer)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1041 (list (point-marker) (if python-orig-file
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1042 (list python-orig-file default-directory)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1043 file)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1044 (+ line (1- python-orig-start-line))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1045 nil)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1046
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1047 (defvar python-preoutput-result nil
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1048 "Data from output line last `_emacs_out' line seen by the preoutput filter.")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1049
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1050 (defvar python-preoutput-continuation nil
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1051 "If non-nil, funcall this when `python-preoutput-filter' sees `_emacs_ok'.")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1052
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1053 ;; Using this stops us getting lines in the buffer like
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1054 ;; >>> ... ... >>>
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1055 ;; Also look for (and delete) an `_emacs_ok' string and call
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1056 ;; `python-preoutput-continuation' if we get it.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1057 (defun python-preoutput-filter (s)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1058 "`comint-preoutput-filter-functions' function: ignore prompts not at bol."
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1059 (cond ((and (string-match "\\`[.>]\\{3\\} \\'" s)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1060 (/= (let ((inhibit-field-text-motion t))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1061 (line-beginning-position))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1062 (point)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1063 "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1064 ((string= s "_emacs_ok\n")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1065 (when python-preoutput-continuation
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1066 (funcall python-preoutput-continuation)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1067 (setq python-preoutput-continuation nil))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1068 "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1069 ((string-match "_emacs_out \\(.*\\)\n" s)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1070 (setq python-preoutput-result (match-string 1 s))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1071 "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1072 (t s)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1073
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1074 ;;;###autoload
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1075 (defun run-python (&optional cmd noshow)
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1076 "Run an inferior Python process, input and output via buffer *Python*.
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1077 CMD is the Python command to run. NOSHOW non-nil means don't show the
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1078 buffer automatically.
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1079 If there is a process already running in `*Python*', switch to
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1080 that buffer. Interactively a prefix arg, allows you to edit the initial
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1081 command line (default is the value of `python-command'); `-i' etc. args
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1082 will be added to this as appropriate. Runs the hooks
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1083 `inferior-python-mode-hook' (after the `comint-mode-hook' is run).
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1084 \(Type \\[describe-mode] in the process buffer for a list of commands.)"
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1085 (interactive (list (if current-prefix-arg
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1086 (read-string "Run Python: " python-command)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1087 python-command)))
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1088 (unless cmd (setq cmd python-python-command))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1089 (setq python-command cmd)
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1090 ;; Fixme: Consider making `python-buffer' buffer-local as a buffer
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1091 ;; (not a name) in Python buffers from which `run-python' &c is
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1092 ;; invoked. Would support multiple processes better.
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1093 (unless (comint-check-proc "*Python*")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1094 (let ((cmdlist (append (python-args-to-list cmd) '("-i"))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1095 (set-buffer (apply 'make-comint "Python" (car cmdlist) nil
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1096 (cdr cmdlist))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1097 (inferior-python-mode)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1098 ;; Load function defintions we need.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1099 ;; Before the preoutput function was used, this was done via -c in
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1100 ;; cmdlist, but that loses the banner and doesn't run the startup
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1101 ;; file.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1102 (python-send-string "\
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1103 def _emacs_execfile (file): # execute file and remove it
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1104 from os import remove
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1105 try: execfile (file, globals (), globals ())
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1106 finally: remove (file)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1107
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1108 def _emacs_args (name): # get arglist of name for eldoc &c
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1109 import inspect
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1110 parts = name.split ('.')
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1111 if len (parts) > 1:
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1112 try: exec 'import ' + parts[0]
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1113 except: return None
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1114 try: exec 'func='+name # lose if name is keyword or undefined
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1115 except: return None
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1116 if inspect.isbuiltin (func):
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1117 doc = func.__doc__
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1118 if doc.find (' ->') != -1:
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1119 print '_emacs_out', doc.split (' ->')[0]
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1120 elif doc.find ('\n') != -1:
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1121 print '_emacs_out', doc.split ('\n')[0]
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1122 return None
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1123 if inspect.ismethod (func): func = func.im_func
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1124 if not inspect.isfunction (func):
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1125 return None
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1126 (args, varargs, varkw, defaults) = inspect.getargspec (func)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1127 print '_emacs_out', func.__name__+inspect.formatargspec (args, varargs, varkw, defaults)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1128
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1129 print '_emacs_ok'"))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1130 (unless noshow (pop-to-buffer (setq python-buffer "*Python*"))))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1131
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1132 (defun python-mouse-2-command (event)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1133 "Command bound to `mouse-2' in inferior Python buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1134 Selects Comint or Compilation mode command as appropriate."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1135 (interactive "e")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1136 ;; This only works with the font-lock-based compilation mode.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1137 (call-interactively
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1138 (lookup-key (if (save-window-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1139 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1140 (mouse-set-point event)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1141 (consp (get-text-property (line-beginning-position)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1142 'message))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1143 compilation-mode-map
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1144 comint-mode-map)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1145 [mouse-2])))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1146
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1147 (defun python-RET-command ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1148 "Command bound to `RET' in inferior Python buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1149 Selects Comint or Compilation mode command as appropriate."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1150 (interactive)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1151 ;; This only works with the font-lock-based compilation mode.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1152 (call-interactively
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1153 (lookup-key (if (consp (get-text-property (line-beginning-position)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1154 'message))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1155 compilation-mode-map
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1156 comint-mode-map)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1157 "\C-m")))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1158
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1159 (defun python-send-region (start end)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1160 "Send the region to the inferior Python process."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1161 ;; The region is evaluated from a temporary file. This avoids
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1162 ;; problems with blank lines, which have different semantics
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1163 ;; interactively and in files. It also saves the inferior process
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1164 ;; buffer filling up with interpreter prompts. We need a function
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1165 ;; to remove the temporary file when it has been evaluated, which
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1166 ;; unfortunately means using a not-quite pristine interpreter
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1167 ;; initially. Unfortunately we also get tracebacks which look like:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1168 ;;
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1169 ;; >>> Traceback (most recent call last):
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1170 ;; File "<stdin>", line 1, in ?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1171 ;; File "<string>", line 4, in _emacs_execfile
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1172 ;; File "/tmp/py7734RSB", line 11
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1173 ;;
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1174 ;; The compilation-minor-mode parsing takes care of relating the
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1175 ;; reference to the temporary file to the source. Fixme:
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1176 ;; comint-filter the first two lines of the traceback?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1177 (interactive "r")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1178 (let* ((f (make-temp-file "py"))
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1179 (command (format "_emacs_execfile(%S)" f))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1180 (orig-file (buffer-file-name))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1181 (orig-line (save-restriction
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1182 (widen)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1183 (line-number-at-pos start))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1184 (if (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1185 (goto-char start)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1186 (/= 0 (current-indentation))) ; need dummy block
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1187 (write-region "if True:\n" nil f nil 'nomsg))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1188 (write-region start end f t 'nomsg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1189 (when python-buffer
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1190 (with-current-buffer python-buffer
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1191 (let ((end (marker-position (process-mark (python-proc)))))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1192 (set (make-local-variable 'python-orig-file) orig-file)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1193 (set (make-local-variable 'python-orig-start-line) orig-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1194 (set (make-local-variable 'compilation-error-list) nil)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1195 (let ((comint-input-filter-functions
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1196 (delete 'python-input-filter comint-input-filter-functions)))
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1197 (python-send-string command))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1198 (set-marker compilation-parsing-end end)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1199 (setq compilation-last-buffer (current-buffer)))))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1200
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1201 (defun python-send-string (string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1202 "Evaluate STRING in inferior Python process."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1203 (interactive "sPython command: ")
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1204 (comint-send-string (python-proc) string)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1205 (comint-send-string (python-proc) "\n\n"))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1206
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1207 (defun python-send-buffer ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1208 "Send the current buffer to the inferior Python process."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1209 (interactive)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1210 (python-send-region (point-min) (point-max)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1211
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1212 (defun python-send-defun ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1213 "Send the current defun (class or method) to the inferior Python process."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1214 (interactive)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1215 (save-excursion (python-send-region (progn (beginning-of-defun) (point))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1216 (progn (end-of-defun) (point)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1217
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1218 (defun python-switch-to-python (eob-p)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1219 "Switch to the Python process buffer.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1220 With prefix arg, position cursor at end of buffer."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1221 (interactive "P")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1222 (if (get-buffer python-buffer)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1223 (pop-to-buffer python-buffer)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1224 (error "No current process buffer. See variable `python-buffer'"))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1225 (when eob-p
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1226 (push-mark)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1227 (goto-char (point-max))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1228
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1229 (add-to-list 'debug-ignored-errors "^No current process buffer.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1230
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1231 (defun python-send-region-and-go (start end)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1232 "Send the region to the inferior Python process.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1233 Then switch to the process buffer."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1234 (interactive "r")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1235 (python-send-region start end)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1236 (python-switch-to-python t))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1237
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1238 (defcustom python-source-modes '(python-mode jython-mode)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1239 "*Used to determine if a buffer contains Python source code.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1240 If it's loaded into a buffer that is in one of these major modes, it's
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1241 considered a Python source file by `python-load-file'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1242 Used by these commands to determine defaults."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1243 :type '(repeat function)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1244 :group 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1245
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1246 (defvar python-prev-dir/file nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1247 "Caches (directory . file) pair used in the last `python-load-file' command.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1248 Used for determining the default in the next one.")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1249
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1250 (defun python-load-file (file-name)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1251 "Load a Python file FILE-NAME into the inferior Python process.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1252 If the file has extension `.py' import or reload it as a module.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1253 Treating it as a module keeps the global namespace clean, provides
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1254 function location information for debugging, and supports users of
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1255 module-qualified names."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1256 (interactive (comint-get-source "Load Python file: " python-prev-dir/file
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1257 python-source-modes
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1258 t)) ; because execfile needs exact name
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1259 (comint-check-source file-name) ; Check to see if buffer needs saved.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1260 (setq python-prev-dir/file (cons (file-name-directory file-name)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1261 (file-name-nondirectory file-name)))
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1262 (when python-buffer
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1263 (with-current-buffer python-buffer
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1264 (let ((end (marker-position (process-mark (python-proc)))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1265 (set (make-local-variable 'compilation-error-list) nil)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1266 ;; (set (make-local-variable 'compilation-old-error-list) nil)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1267 (let ((comint-input-filter-functions
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1268 (delete 'python-input-filter comint-input-filter-functions)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1269 (python-send-string
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1270 (if (string-match "\\.py\\'" file-name)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1271 ;; Fixme: make sure the directory is in the path list
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1272 (let ((module (file-name-sans-extension
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1273 (file-name-nondirectory file-name))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1274 (set (make-local-variable 'python-orig-file) nil)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1275 (set (make-local-variable 'python-orig-start-line) nil)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1276 (format "\
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1277 try:
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1278 if globals().has_key(%S): reload(%s)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1279 else: import %s
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1280 except: None
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1281 " module module module))
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1282 (set (make-local-variable 'python-orig-file) file-name)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1283 (set (make-local-variable 'python-orig-start-line) 1)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1284 (format "execfile('%s')" file-name))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1285 (set-marker compilation-parsing-end end)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1286 (setq compilation-last-buffer (current-buffer))))))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1287
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1288 ;; Fixme: Should this start a process if there isn't one? (Unlike cmuscheme.)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1289 (defun python-proc ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1290 "Return the current Python process. See variable `python-buffer'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1291 (let ((proc (get-buffer-process (if (eq major-mode 'inferior-python-mode)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1292 (current-buffer)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1293 python-buffer))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1294 (or proc (error "No current process. See variable `python-buffer'"))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1295
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1296 ;;;; Context-sensitive help.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1297
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1298 (defconst python-dotty-syntax-table
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1299 (let ((table (make-syntax-table)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1300 (set-char-table-parent table python-mode-syntax-table)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1301 (modify-syntax-entry ?. "_" table)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1302 table)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1303 "Syntax table giving `.' symbol syntax.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1304 Otherwise inherits from `python-mode-syntax-table'.")
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1305
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1306 ;; Fixme: Should this actually be used instead of info-look, i.e. be
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1307 ;; bound to C-h S?
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1308 (defun python-describe-symbol (symbol)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1309 "Get help on SYMBOL using `pydoc'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1310 Interactively, prompt for symbol."
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1311 ;; Note that we do this in the inferior process, not a separate one to
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1312 ;; ensure the environment is appropriate.
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1313 (interactive
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1314 (let ((symbol (with-syntax-table python-dotty-syntax-table
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1315 (current-word)))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1316 (enable-recursive-minibuffers t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1317 val)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1318 (setq val (read-string (if symbol
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1319 (format "Describe variable (default %s): "
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1320 symbol)
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1321 "Describe symbol: ")
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1322 nil nil symbol))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1323 (list (or val symbol))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1324 (if (equal symbol "") (error "No symbol"))
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1325 (let* ((func `(lambda ()
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1326 (comint-redirect-send-command (format "help(%S)\n" ,symbol)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1327 "*Help*" nil))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1328 ;; Ensure we have a suitable help buffer.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1329 (let (temp-buffer-show-hook) ; avoid xref stuff
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1330 (with-output-to-temp-buffer "*Help*"
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1331 (with-current-buffer standard-output
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1332 (set (make-local-variable 'comint-redirect-subvert-readonly) t))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1333 (if (and python-buffer (get-buffer python-buffer))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1334 (with-current-buffer python-buffer
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1335 (funcall func))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1336 (setq python-preoutput-continuation func)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1337 (run-python nil t))))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1338
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1339 (add-to-list 'debug-ignored-errors "^No symbol")
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1340
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1341 ;; Fixme: try to make it work with point in the arglist. Also, is
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1342 ;; there anything reasonable we can do with random methods?
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1343 ;; (Currently only works with functions.)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1344 (defun python-eldoc-function ()
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1345 "`eldoc-print-current-symbol-info' for Python.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1346 Only works when point is in a function name, not its arglist, for instance.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1347 Assumes an inferior Python is running."
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1348 (let ((symbol (with-syntax-table python-dotty-syntax-table
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1349 (current-word)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1350 (proc (and python-buffer (python-proc))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1351 (when (and proc symbol)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1352 (python-send-string
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1353 (format "_emacs_args(%S)" symbol))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1354 (setq python-preoutput-result nil)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1355 (accept-process-output proc 1)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1356 python-preoutput-result)))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1357
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1358 ;;;; Info-look functionality.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1359
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1360 (defun python-after-info-look ()
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1361 "Set up info-look for Python.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1362 Used with `eval-after-load'."
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1363 (let* ((version (let ((s (shell-command-to-string (concat python-command
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1364 " -V"))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1365 (string-match "^Python \\([0-9]+\\.[0-9]+\\>\\)" s)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1366 (match-string 1 s)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1367 ;; Whether info files have a Python version suffix, e.g. in Debian.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1368 (versioned
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1369 (with-temp-buffer
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1370 (Info-mode)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1371 (condition-case ()
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1372 (Info-goto-node (format "(python%s-lib)Miscellaneous Index"
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1373 version))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1374 (error nil)))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1375 (info-lookup-maybe-add-help
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1376 :mode 'python-mode
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1377 :regexp "[[:alnum:]_]+"
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1378 :doc-spec
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1379 ;; Fixme: Can this reasonably be made specific to indices with
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1380 ;; different rules? Is the order of indices optimal?
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1381 ;; (Miscellaneous in -ref first prefers lookup of keywords, for
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1382 ;; instance.)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1383 (if versioned
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1384 ;; The empty prefix just gets us highlighted terms.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1385 `((,(concat "(python" version "-ref)Miscellaneous Index") nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1386 (,(concat "(python" version "-ref)Module Index" nil ""))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1387 (,(concat "(python" version "-ref)Function-Method-Variable Index"
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1388 nil ""))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1389 (,(concat "(python" version "-ref)Class-Exception-Object Index"
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1390 nil ""))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1391 (,(concat "(python" version "-lib)Module Index" nil ""))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1392 (,(concat "(python" version "-lib)Class-Exception-Object Index"
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1393 nil ""))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1394 (,(concat "(python" version "-lib)Function-Method-Variable Index"
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1395 nil ""))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1396 (,(concat "(python" version "-lib)Miscellaneous Index" nil "")))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1397 '(("(python-ref)Miscellaneous Index" nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1398 ("(python-ref)Module Index" nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1399 ("(python-ref)Function-Method-Variable Index" nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1400 ("(python-ref)Class-Exception-Object Index" nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1401 ("(python-lib)Module Index" nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1402 ("(python-lib)Class-Exception-Object Index" nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1403 ("(python-lib)Function-Method-Variable Index" nil "")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1404 ("(python-lib)Miscellaneous Index" nil ""))))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1405 (eval-after-load "info-look" '(python-after-info-look))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1406
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1407 ;;;; Miscellancy.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1408
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1409 (defcustom python-jython-packages '("java" "javax" "org" "com")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1410 "Packages implying `jython-mode'.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1411 If these are imported near the beginning of the buffer, `python-mode'
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1412 actually punts to `jython-mode'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1413 :type '(repeat string)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1414 :group 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1415
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1416 ;; Called from `python-mode', this causes a recursive call of the
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1417 ;; mode. See logic there to break out of the recursion.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1418 (defun python-maybe-jython ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1419 "Invoke `jython-mode' if the buffer appears to contain Jython code.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1420 The criterion is either a match for `jython-mode' via
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1421 `interpreter-mode-alist' or an import of a module from the list
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1422 `python-jython-packages'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1423 ;; The logic is taken from python-mode.el.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1424 (save-excursion
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1425 (save-restriction
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1426 (widen)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1427 (goto-char (point-min))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1428 (let ((interpreter (if (looking-at auto-mode-interpreter-regexp)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1429 (match-string 2))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1430 (if (and interpreter (eq 'jython-mode
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1431 (cdr (assoc (file-name-nondirectory
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1432 interpreter)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1433 interpreter-mode-alist))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1434 (jython-mode)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1435 (if (catch 'done
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1436 (while (re-search-forward
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1437 (rx (and line-start (or "import" "from") (1+ space)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1438 (group (1+ (not (any " \t\n."))))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1439 10000 ; Probably not worth customizing.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1440 t)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1441 (if (member (match-string 1) python-jython-packages)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1442 (throw 'done t))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1443 (jython-mode)))))))
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1444
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1445 (defun python-fill-paragraph (&optional justify)
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1446 "`fill-paragraph-function' handling comments and multi-line strings.
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1447 If any of the current line is a comment, fill the comment or the
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1448 paragraph of it that point is in, preserving the comment's
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1449 indentation and initial comment characters. Similarly if the end
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1450 of the current line is in or at the end of a multi-line string.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1451 Otherwise, do nothing."
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1452 (interactive "P")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1453 (or (fill-comment-paragraph justify)
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1454 ;; The `paragraph-start' and `paragraph-separate' variables
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1455 ;; don't allow us to delimit the last paragraph in a multi-line
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1456 ;; string properly, so narrow to the string and then fill around
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1457 ;; (the end of) the current line.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1458 (save-excursion
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1459 (end-of-line)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1460 (let* ((syntax (syntax-ppss))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1461 (orig (point))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1462 (start (nth 8 syntax))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1463 end)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1464 (cond ((eq t (nth 3 syntax)) ; in fenced string
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1465 (goto-char (nth 8 syntax)) ; string start
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1466 (condition-case () ; for unbalanced quotes
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1467 (progn (forward-sexp)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1468 (setq end (point)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1469 (error (setq end (point-max)))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1470 ((re-search-backward "\\s|\\s-*\\=" nil t) ; end of fenced
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1471 ; string
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1472 (forward-char)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1473 (setq end (point))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1474 (condition-case ()
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1475 (progn (backward-sexp)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1476 (setq start (point)))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1477 (error nil))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1478 (when end
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1479 (save-restriction
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1480 (narrow-to-region start end)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1481 (goto-char orig)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1482 (fill-paragraph justify))))))
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1483 t)
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1484
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1485 (defun python-shift-left (start end &optional count)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1486 "Shift lines in region COUNT (the prefix arg) columns to the left.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1487 COUNT defaults to `python-indent'. If region isn't active, just shift
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1488 current line. The region shifted includes the lines in which START and
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1489 END lie. It is an error if any lines in the region are indented less than
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1490 COUNT columns."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1491 (interactive (if mark-active
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1492 (list (region-beginning) (region-end) current-prefix-arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1493 (list (point) (point) current-prefix-arg)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1494 (if count
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1495 (setq count (prefix-numeric-value count))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1496 (setq count python-indent))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1497 (when (> count 0)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1498 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1499 (goto-char start)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1500 (while (< (point) end)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1501 (if (and (< (current-indentation) count)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1502 (not (looking-at "[ \t]*$")))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1503 (error "Can't shift all lines enough"))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1504 (forward-line))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1505 (indent-rigidly start end (- count)))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1506
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1507 (add-to-list 'debug-ignored-errors "^Can't shift all lines enough")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1508
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1509 (defun python-shift-right (start end &optional count)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1510 "Shift lines in region COUNT (the prefix arg) columns to the right.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1511 COUNT defaults to `python-indent'. If region isn't active, just shift
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1512 current line. The region shifted includes the lines in which START and
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1513 END lie."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1514 (interactive (if mark-active
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1515 (list (region-beginning) (region-end) current-prefix-arg)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1516 (list (point) (point) current-prefix-arg)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1517 (if count
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1518 (setq count (prefix-numeric-value count))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1519 (setq count python-indent))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1520 (indent-rigidly start end count))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1521
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1522 (defun python-outline-level ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1523 "`outline-level' function for Python mode.
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1524 The level is the number of `python-indent' steps of indentation
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1525 of current line."
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1526 (/ (current-indentation) python-indent))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1527
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1528 ;; Fixme: Consider top-level assignments, imports, &c.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1529 (defun python-current-defun ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1530 "`add-log-current-defun-function' for Python."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1531 (save-excursion
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1532 ;; Move up the tree of nested `class' and `def' blocks until we
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1533 ;; get to zero indentation, accumulating the defined names.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1534 (let ((start t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1535 accum)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1536 (while (or start (> (current-indentation) 0))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1537 (setq start nil)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1538 (python-beginning-of-block)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1539 (end-of-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1540 (beginning-of-defun)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1541 (if (looking-at (rx (and (0+ space) (or "def" "class") (1+ space)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1542 (group (1+ (or word (syntax symbol))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1543 word-end)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1544 (push (match-string 1) accum)))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1545 (if accum (mapconcat 'identity accum ".")))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1546
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1547 (defun python-mark-block ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1548 "Mark the block around point.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1549 Uses `python-beginning-of-block', `python-end-of-block'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1550 (interactive)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1551 (push-mark)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1552 (python-beginning-of-block)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1553 (push-mark (point) nil t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1554 (python-end-of-block)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1555 (exchange-point-and-mark))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1556
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1557 ;;;; Modes.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1558
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1559 (defvar outline-heading-end-regexp)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1560 (defvar eldoc-print-current-symbol-info-function)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1561
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1562 ;;;###autoload
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1563 (define-derived-mode python-mode fundamental-mode "Python"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1564 "Major mode for editing Python files.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1565 Turns on Font Lock mode unconditionally since it is required for correct
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1566 parsing of the source.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1567 See also `jython-mode', which is actually invoked if the buffer appears to
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1568 contain Jython code. See also `run-python' and associated Python mode
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1569 commands for running Python under Emacs.
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1570
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1571 The Emacs commands which work with `defun's, e.g. \\[beginning-of-defun], deal
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1572 with nested `def' and `class' blocks. They take the innermost one as
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1573 current without distinguishing method and class definitions. Used multiple
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1574 times, they move over others at the same indentation level until they reach
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1575 the end of definitions at that level, when they move up a level.
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1576 \\<python-mode-map>
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1577 Colon is electric: it outdents the line if appropriate, e.g. for
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1578 an else statement. \\[python-backspace] at the beginning of an indented statement
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1579 deletes a level of indentation to close the current block; otherwise it
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1580 deletes a charcter backward. TAB indents the current line relative to
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1581 the preceding code. Successive TABs, with no intervening command, cycle
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1582 through the possibilities for indentation on the basis of enclosing blocks.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1583
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1584 \\[fill-paragraph] fills comments and multiline strings appropriately, but has no
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1585 effect outside them.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1586
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1587 Supports Eldoc mode (only for functions, using a Python process),
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1588 Info-Look and Imenu. In Outline minor mode, `class' and `def'
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1589 lines count as headers.
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1590
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1591 \\{python-mode-map}"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1592 :group 'python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1593 (set (make-local-variable 'font-lock-defaults)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1594 '(python-font-lock-keywords nil nil ((?_ . "w")) nil
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1595 (font-lock-syntactic-keywords
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1596 . python-font-lock-syntactic-keywords)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1597 ;;; This probably isn't worth it.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1598 ;;; (font-lock-syntactic-face-function
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1599 ;;; . python-font-lock-syntactic-face-function)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1600 ))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1601 (set (make-local-variable 'parse-sexp-lookup-properties) t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1602 (set (make-local-variable 'comment-start) "# ")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1603 ;; Fixme: define a comment-indent-function?
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1604 (set (make-local-variable 'indent-line-function) #'python-indent-line)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1605 (set (make-local-variable 'paragraph-start) "\\s-*$")
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1606 (set (make-local-variable 'fill-paragraph-function)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1607 'python-fill-paragraph)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1608 (set (make-local-variable 'require-final-newline) t)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1609 (set (make-local-variable 'add-log-current-defun-function)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1610 #'python-current-defun)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1611 ;; Fixme: Generalize to do all blocks?
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1612 (set (make-local-variable 'outline-regexp) "\\s-*\\(def\\|class\\)\\>")
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1613 (set (make-local-variable 'outline-heading-end-regexp) ":\\s-*\n")
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1614 (set (make-local-variable 'outline-level) #'python-outline-level)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1615 (set (make-local-variable 'open-paren-in-column-0-is-defun-start) nil)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1616 (make-local-variable 'python-saved-check-command)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1617 (set (make-local-variable 'beginning-of-defun-function)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1618 'python-beginning-of-defun)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1619 (set (make-local-variable 'end-of-defun-function) 'python-end-of-defun)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1620 (setq imenu-create-index-function #'python-imenu-create-index)
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1621 (set (make-local-variable 'eldoc-print-current-symbol-info-function)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1622 #'python-eldoc-function)
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1623 (add-hook 'eldoc-mode-hook
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1624 '(lambda () (run-python 0 t)) nil t) ; need it running
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1625 (unless font-lock-mode (font-lock-mode 1))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1626 (when python-guess-indent (python-guess-indent))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1627 (set (make-local-variable 'python-command) python-python-command)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1628 (unless (boundp 'python-mode-running) ; kill the recursion from jython-mode
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1629 (let ((python-mode-running t))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1630 (python-maybe-jython))))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1631
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1632 (custom-add-option 'python-mode-hook 'imenu-add-menubar-index)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1633 (custom-add-option 'python-mode-hook
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1634 '(lambda ()
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1635 "Turn on Indent Tabs mode."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1636 (set (make-local-variable 'indent-tabs-mode) t)))
54840
3768540a819c Doc fixes. Changes for compiler warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54838
diff changeset
1637 (custom-add-option 'python-mode-hook 'turn-on-eldoc-mode)
54789
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1638
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1639 ;;;###autoload
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1640 (define-derived-mode jython-mode python-mode "Jython"
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1641 "Major mode for editing Jython files.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1642 Like `python-mode', but sets up parameters for Jython subprocesses.
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1643 Runs `jython-mode-hook' after `python-mode-hook'."
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1644 :group 'python
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1645 (set (make-local-variable 'python-command) python-jython-command))
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1646
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1647 (provide 'python)
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1648 ;; arch-tag: 6fce1d99-a704-4de9-ba19-c6e4912b0554
9d1d7f062a4f New file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff changeset
1649 ;;; python.el ends here