annotate lisp/textmodes/tex-mode.el @ 37896:5cc52d5c2f2b

(tex-mode-syntax-table): Add ^. (tex-font-lock-keywords-1, tex-font-lock-keywords-2): Allow spaces around macro arguments. (tex-mode-map): Inherit from text-mode-map, but rebind \t to indent-for-tab-command. (latex-mode-map, plain-tex-mode-map): New keymaps. Inherit from tex-mode-map. (tex-common-initialization): Don't setup the keymap any more since it's now done right by define-derived-mode. (latex-mode): Set skeleton-end-hook to nil. (latex-skeleton-end-hook): Remove. (tex-latex-block, latex-insert-item): Simplify. (latex-syntax-after): Use following-char rather than char-after. (tex-discount-args-cmds, tex-count-words): New functions.
author Stefan Monnier <monnier@iro.umontreal.ca>
date Fri, 25 May 2001 22:08:34 +0000
parents 595ee2f062cf
children 0f57d8b106f1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
657
fec3f9a1e3e5 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
1 ;;; tex-mode.el --- TeX, LaTeX, and SliTeX mode commands.
fec3f9a1e3e5 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
2
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
3 ;; Copyright (C) 1985, 86, 89, 92, 94, 95, 96, 97, 98, 1999
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
4 ;; Free Software Foundation, Inc.
840
113281b361ec *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 814
diff changeset
5
10215
7690653b9231 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 10204
diff changeset
6 ;; Maintainer: FSF
814
38b2499cb3e9 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 807
diff changeset
7 ;; Keywords: tex
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 758
diff changeset
8
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
9 ;; Contributions over the years by William F. Schelter, Dick King,
10215
7690653b9231 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 10204
diff changeset
10 ;; Stephen Gildea, Michael Prange, Jacob Gore, and Edward M. Reingold.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
11
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
12 ;; This file is part of GNU Emacs.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
13
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
14 ;; GNU Emacs is free software; you can redistribute it and/or modify
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
15 ;; it under the terms of the GNU General Public License as published by
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 758
diff changeset
16 ;; the Free Software Foundation; either version 2, or (at your option)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
17 ;; any later version.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
18
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
19 ;; GNU Emacs is distributed in the hope that it will be useful,
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
20 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
21 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
22 ;; GNU General Public License for more details.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
23
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
24 ;; You should have received a copy of the GNU General Public License
14383
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
25 ;; along with GNU Emacs; see the file COPYING. If not, write to the
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
26 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
27 ;; Boston, MA 02111-1307, USA.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
28
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 758
diff changeset
29 ;;; Code:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 758
diff changeset
30
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
31 ;; Pacify the byte-compiler
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
32 (eval-when-compile
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
33 (require 'compare-w)
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
34 (require 'cl)
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
35 (require 'skeleton))
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
36
6632
652dc23b83fd (tex-start-shell): Use shell-mode-map (instead of comint-mode-map) because
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 6479
diff changeset
37 (require 'shell)
2576
48318133e7a6 (tex-compilation-parse-errors): Added. At the moment, this would have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2571
diff changeset
38 (require 'compile)
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
39
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
40 (defgroup tex-file nil
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
41 "TeX files and directories"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
42 :prefix "tex-"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
43 :group 'tex)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
44
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
45 (defgroup tex-run nil
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
46 "Running external commands from TeX mode"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
47 :prefix "tex-"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
48 :group 'tex)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
49
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
50 (defgroup tex-view nil
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
51 "Viewing and printing TeX files"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
52 :prefix "tex-"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
53 :group 'tex)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
54
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
55 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
56 (defcustom tex-shell-file-name nil
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
57 "*If non-nil, the shell file name to run in the subshell used to run TeX."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
58 :type '(choice (const :tag "None" nil)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
59 string)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
60 :group 'tex-run)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
61
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
62 ;;;###autoload
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
63 (defcustom tex-directory "."
15916
61e90a3e66aa (tex-main-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 15644
diff changeset
64 "*Directory in which temporary files are written.
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
65 You can make this `/tmp' if your TEXINPUTS has no relative directories in it
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
66 and you don't try to apply \\[tex-region] or \\[tex-buffer] when there are
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
67 `\\input' commands with relative directories."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
68 :type 'directory
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
69 :group 'tex-file)
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
70
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
71 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
72 (defcustom tex-first-line-header-regexp nil
16777
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
73 "Regexp for matching a first line which `tex-region' should include.
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
74 If this is non-nil, it should be a regular expression string;
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
75 if it matches the first line of the file,
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
76 `tex-region' always includes the first line in the TeX run."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
77 :type '(choice (const :tag "None" nil)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
78 regexp)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
79 :group 'tex-file)
16777
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
80
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
81 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
82 (defcustom tex-main-file nil
15916
61e90a3e66aa (tex-main-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 15644
diff changeset
83 "*The main TeX source file which includes this buffer's file.
22847
31924d388b84 (tex-main-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 22707
diff changeset
84 The command `tex-file' runs TeX on the file specified by `tex-main-file'
31924d388b84 (tex-main-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 22707
diff changeset
85 if the variable is non-nil."
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
86 :type '(choice (const :tag "None" nil)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
87 file)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
88 :group 'tex-file)
15916
61e90a3e66aa (tex-main-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 15644
diff changeset
89
61e90a3e66aa (tex-main-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 15644
diff changeset
90 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
91 (defcustom tex-offer-save t
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
92 "*If non-nil, ask about saving modified buffers before \\[tex-file] is run."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
93 :type 'boolean
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
94 :group 'tex-file)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
95
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
96 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
97 (defcustom tex-run-command "tex"
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
98 "*Command used to run TeX subjob.
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
99 TeX Mode sets `tex-command' to this string.
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
100 See the documentation of that variable."
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
101 :type 'string
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
102 :group 'tex-run)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
103
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
104 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
105 (defcustom latex-run-command "latex"
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
106 "*Command used to run LaTeX subjob.
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
107 LaTeX Mode sets `tex-command' to this string.
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
108 See the documentation of that variable."
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
109 :type 'string
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
110 :group 'tex-run)
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
111
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
112 ;;;###autoload
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
113 (defcustom slitex-run-command "slitex"
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
114 "*Command used to run SliTeX subjob.
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
115 SliTeX Mode sets `tex-command' to this string.
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
116 See the documentation of that variable."
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
117 :type 'string
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
118 :group 'tex-run)
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
119
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
120 ;;;###autoload
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
121 (defcustom tex-start-options-string "\\nonstopmode\\input"
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
122 "*TeX options to use when running TeX.
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
123 These precede the input file name. If nil, TeX runs without option.
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
124 See the documentation of `tex-command'."
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
125 :type '(radio (const :tag "Interactive \(nil\)" nil)
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
126 (const :tag "Nonstop \(\"\\nonstopmode\\input\"\)"
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
127 "\\nonstopmode\\input")
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
128 (string :tag "String at your choice"))
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
129 :group 'tex-run
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
130 :version "20.4")
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
131
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
132 (defvar standard-latex-block-names
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
133 '("abstract" "array" "center" "description"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
134 "displaymath" "document" "enumerate" "eqnarray"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
135 "eqnarray*" "equation" "figure" "figure*"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
136 "flushleft" "flushright" "itemize" "letter"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
137 "list" "minipage" "picture" "quotation"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
138 "quote" "slide" "sloppypar" "tabbing"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
139 "table" "table*" "tabular" "tabular*"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
140 "thebibliography" "theindex*" "titlepage" "trivlist"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
141 "verbatim" "verbatim*" "verse" "math")
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
142 "Standard LaTeX block names.")
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
143
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
144 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
145 (defcustom latex-block-names nil
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
146 "*User defined LaTeX block names.
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
147 Combined with `standard-latex-block-names' for minibuffer completion."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
148 :type '(repeat string)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
149 :group 'tex-run)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
150
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
151 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
152 (defcustom tex-bibtex-command "bibtex"
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
153 "*Command used by `tex-bibtex-file' to gather bibliographic data.
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
154 If this string contains an asterisk (`*'), that is replaced by the file name;
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
155 otherwise, the file name, preceded by blank, is added at the end."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
156 :type 'string
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
157 :group 'tex-run)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
158
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
159 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
160 (defcustom tex-dvi-print-command "lpr -d"
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
161 "*Command used by \\[tex-print] to print a .dvi file.
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
162 If this string contains an asterisk (`*'), that is replaced by the file name;
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
163 otherwise, the file name, preceded by blank, is added at the end."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
164 :type 'string
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
165 :group 'tex-view)
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
166
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
167 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
168 (defcustom tex-alt-dvi-print-command "lpr -d"
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
169 "*Command used by \\[tex-print] with a prefix arg to print a .dvi file.
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
170 If this string contains an asterisk (`*'), that is replaced by the file name;
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
171 otherwise, the file name, preceded by blank, is added at the end.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
172
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
173 If two printers are not enough of a choice, you can set the variable
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
174 `tex-alt-dvi-print-command' to an expression that asks what you want;
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
175 for example,
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
176
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
177 (setq tex-alt-dvi-print-command
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
178 '(format \"lpr -P%s\" (read-string \"Use printer: \")))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
179
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
180 would tell \\[tex-print] with a prefix argument to ask you which printer to
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
181 use."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
182 :type '(choice (string :tag "Command")
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
183 (sexp :tag "Expression"))
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
184 :group 'tex-view)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
185
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
186 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
187 (defcustom tex-dvi-view-command nil
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
188 "*Command used by \\[tex-view] to display a `.dvi' file.
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
189 If this string contains an asterisk (`*'), that is replaced by the file name;
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
190 otherwise, the file name, preceded by blank, is added at the end.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
191
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
192 This can be set conditionally so that the previewer used is suitable for the
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
193 window system being used. For example,
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
194
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
195 (setq tex-dvi-view-command
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
196 (if (eq window-system 'x) \"xdvi\" \"dvi2tty * | cat -s\"))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
197
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
198 would tell \\[tex-view] to use xdvi under X windows and to use dvi2tty
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
199 otherwise."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
200 :type '(choice (const nil) string)
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
201 :group 'tex-view)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
202
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
203 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
204 (defcustom tex-show-queue-command "lpq"
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
205 "*Command used by \\[tex-show-print-queue] to show the print queue.
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
206 Should show the queue(s) that \\[tex-print] puts jobs on."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
207 :type 'string
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
208 :group 'tex-view)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
209
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
210 ;;;###autoload
26270
14dbec3a82b4 (tex-default-mode): Changed to latex-mode.
Gerd Moellmann <gerd@gnu.org>
parents: 25414
diff changeset
211 (defcustom tex-default-mode 'latex-mode
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
212 "*Mode to enter for a new file that might be either TeX or LaTeX.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
213 This variable is used when it can't be determined whether the file
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
214 is plain TeX or LaTeX or what because the file contains no commands.
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
215 Normally set to either `plain-tex-mode' or `latex-mode'."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
216 :type 'function
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
217 :group 'tex)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
218
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
219 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
220 (defcustom tex-open-quote "``"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
221 "*String inserted by typing \\[tex-insert-quote] to open a quotation."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
222 :type 'string
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
223 :group 'tex)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
224
957
2619b7a9c11e entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 870
diff changeset
225 ;;;###autoload
17435
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
226 (defcustom tex-close-quote "''"
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
227 "*String inserted by typing \\[tex-insert-quote] to close a quotation."
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
228 :type 'string
b104a6fb7fa3 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 16807
diff changeset
229 :group 'tex)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
230
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
231 (defvar tex-last-temp-file nil
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
232 "Latest temporary file generated by \\[tex-region] and \\[tex-buffer].
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
233 Deleted when the \\[tex-region] or \\[tex-buffer] is next run, or when the
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
234 tex shell terminates.")
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
235
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
236 (defvar tex-command nil
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
237 "*Command to run TeX.
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
238 If this string contains an asterisk \(`*'\), that is replaced by the file name\;
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
239 otherwise the \(shell-quoted\) value of `tex-start-options-string' and
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
240 the file name are added at the end, with blanks as separators.
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
241
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
242 In TeX, LaTeX, and SliTeX Mode this variable becomes buffer local.
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
243 In these modes, use \\[set-variable] if you want to change it for the
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
244 current buffer.")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
245
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
246 (defvar tex-trailer nil
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
247 "String appended after the end of a region sent to TeX by \\[tex-region].")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
248
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
249 (defvar tex-start-of-header nil
13248
a7e83f7eb499 (tex-start-of-header): Now a regexp.
Richard M. Stallman <rms@gnu.org>
parents: 12704
diff changeset
250 "Regular expression used by \\[tex-region] to find start of file's header.")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
251
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
252 (defvar tex-end-of-header nil
13248
a7e83f7eb499 (tex-start-of-header): Now a regexp.
Richard M. Stallman <rms@gnu.org>
parents: 12704
diff changeset
253 "Regular expression used by \\[tex-region] to find end of file's header.")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
254
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
255 (defvar tex-shell-cd-command "cd"
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
256 "Command to give to shell running TeX to change directory.
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
257 The value of `tex-directory' is appended to this, separated by a space.")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
258
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
259 (defvar tex-zap-file nil
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
260 "Temporary file name used for text being sent as input to TeX.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
261 Should be a simple file name with no extension or directory specification.")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
262
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
263 (defvar tex-last-buffer-texed nil
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
264 "Buffer which was last TeXed.")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
265
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
266 (defvar tex-print-file nil
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
267 "File name that \\[tex-print] prints.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
268 Set by \\[tex-region], \\[tex-buffer], and \\[tex-file].")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
269
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
270 (easy-mmode-defsyntax tex-mode-syntax-table
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
271 '((?% . "<")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
272 (?\n . ">")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
273 (?\f . ">")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
274 (?\C-@ . "w")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
275 (?' . "w")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
276 (?@ . "_")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
277 (?* . "_")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
278 (?\t . " ")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
279 (?~ . " ")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
280 (?$ . "$$")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
281 (?\\ . "/")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
282 (?\" . ".")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
283 (?& . ".")
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
284 (?_ . ".")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
285 (?^ . "."))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
286 "Syntax table used while in TeX mode.")
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
287
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
288 ;;;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
289 ;;;; Imenu support
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
290 ;;;;
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
291
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
292 (defcustom latex-imenu-indent-string ". "
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
293 "*String to add repeated in front of nested sectional units for Imenu.
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
294 An alternative value is \" . \", if you use a font with a narrow period."
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
295 :type 'string
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
296 :group 'tex)
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
297
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
298 (defvar latex-section-alist
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
299 '(("part" . 0) ("chapter" . 1)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
300 ("section" . 2) ("subsection" . 3)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
301 ("subsubsection" . 4)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
302 ("paragraph" . 5) ("subparagraph" . 6)))
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
303
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
304 (defvar latex-metasection-list
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
305 '("documentstyle" "documentclass"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
306 "begin{document}" "end{document}"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
307 "appendix" "frontmatter" "mainmatter" "backmatter"))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
308
15240
21998d33460f (latex-imenu-create-index):
Richard M. Stallman <rms@gnu.org>
parents: 14734
diff changeset
309 (defun latex-imenu-create-index ()
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
310 "Generate an alist for imenu from a LaTeX buffer."
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
311 (let ((section-regexp
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
312 (concat "\\\\" (regexp-opt (mapcar 'car latex-section-alist) t)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
313 "\\*?[ \t]*{"))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
314 (metasection-regexp
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
315 (concat "\\\\" (regexp-opt latex-metasection-list t)))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
316 i0 menu case-fold-search)
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
317 (save-excursion
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
318 ;; Find the top-most level in this file but don't allow it to be
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
319 ;; any deeper than "section" (which is top-level in an article).
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
320 (goto-char (point-min))
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
321 (if (search-forward-regexp "\\\\part\\*?[ \t]*{" nil t)
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
322 (setq i0 0)
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
323 (if (search-forward-regexp "\\\\chapter\\*?[ \t]*{" nil t)
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
324 (setq i0 1)
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
325 (setq i0 2)))
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
326
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
327 ;; Look for chapters and sections.
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
328 (goto-char (point-min))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
329 (while (search-forward-regexp section-regexp nil t)
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
330 (let ((start (match-beginning 0))
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
331 (here (point))
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
332 (i (cdr (assoc (buffer-substring-no-properties
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
333 (match-beginning 1)
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
334 (match-end 1))
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
335 latex-section-alist))))
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
336 (backward-char 1)
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
337 (condition-case err
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
338 (progn
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
339 ;; Using sexps allows some use of matching {...} inside
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
340 ;; titles.
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
341 (forward-sexp 1)
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
342 (push (cons (concat (apply 'concat
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
343 (make-list
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
344 (max 0 (- i i0))
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
345 latex-imenu-indent-string))
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
346 (buffer-substring-no-properties
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
347 here (1- (point))))
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
348 start)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
349 menu))
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
350 (error nil))))
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
351
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
352 ;; Look for included material.
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
353 (goto-char (point-min))
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
354 (while (search-forward-regexp
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
355 "\\\\\\(include\\|input\\|verbatiminput\\|bibliography\\)\
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
356 \[ \t]*{\\([^}\n]+\\)}"
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
357 nil t)
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
358 (push (cons (concat "<<" (buffer-substring-no-properties
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
359 (match-beginning 2)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
360 (match-end 2))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
361 (if (= (char-after (match-beginning 1)) ?b)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
362 ".bbl"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
363 ".tex"))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
364 (match-beginning 0))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
365 menu))
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
366
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
367 ;; Look for \frontmatter, \mainmatter, \backmatter, and \appendix.
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
368 (goto-char (point-min))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
369 (while (search-forward-regexp metasection-regexp nil t)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
370 (push (cons "--" (match-beginning 0)) menu))
18393
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
371
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
372 ;; Sort in increasing buffer position order.
f34e9defc58c (latex-imenu-create-index): Make it much smarter.
Richard M. Stallman <rms@gnu.org>
parents: 17435
diff changeset
373 (sort menu (function (lambda (a b) (< (cdr a) (cdr b))))))))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
374
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
375 ;;;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
376 ;;;; Outline support
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
377 ;;;;
12704
0b36e50fb5af (latex-imenu-generic-expression): Var defined.
Karl Heuer <kwzh@gnu.org>
parents: 11617
diff changeset
378
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
379 (defvar latex-outline-regexp
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
380 (concat "\\\\"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
381 (regexp-opt (append latex-metasection-list
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
382 (mapcar 'car latex-section-alist)) t)))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
383
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
384 (defun latex-outline-level ()
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
385 (if (looking-at latex-outline-regexp)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
386 (1+ (or (cdr (assoc (match-string 1) latex-section-alist)) -1))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
387 1000))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
388
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
389 ;;;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
390 ;;;; Font-Lock support
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
391 ;;;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
392
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
393 ;(defvar tex-font-lock-keywords
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
394 ; ;; Regexps updated with help from Ulrik Dickow <dickow@nbi.dk>.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
395 ; '(("\\\\\\(begin\\|end\\|newcommand\\){\\([a-zA-Z0-9\\*]+\\)}"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
396 ; 2 font-lock-function-name-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
397 ; ("\\\\\\(cite\\|label\\|pageref\\|ref\\){\\([^} \t\n]+\\)}"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
398 ; 2 font-lock-constant-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
399 ; ;; It seems a bit dubious to use `bold' and `italic' faces since we might
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
400 ; ;; not be able to display those fonts.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
401 ; ("{\\\\bf\\([^}]+\\)}" 1 'bold keep)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
402 ; ("{\\\\\\(em\\|it\\|sl\\)\\([^}]+\\)}" 2 'italic keep)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
403 ; ("\\\\\\([a-zA-Z@]+\\|.\\)" . font-lock-keyword-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
404 ; ("^[ \t\n]*\\\\def[\\\\@]\\(\\w+\\)" 1 font-lock-function-name-face keep))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
405 ; ;; Rewritten and extended for LaTeX2e by Ulrik Dickow <dickow@nbi.dk>.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
406 ; '(("\\\\\\(begin\\|end\\|newcommand\\){\\([a-zA-Z0-9\\*]+\\)}"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
407 ; 2 font-lock-function-name-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
408 ; ("\\\\\\(cite\\|label\\|pageref\\|ref\\){\\([^} \t\n]+\\)}"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
409 ; 2 font-lock-constant-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
410 ; ("^[ \t]*\\\\def\\\\\\(\\(\\w\\|@\\)+\\)" 1 font-lock-function-name-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
411 ; "\\\\\\([a-zA-Z@]+\\|.\\)"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
412 ; ;; It seems a bit dubious to use `bold' and `italic' faces since we might
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
413 ; ;; not be able to display those fonts.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
414 ; ;; LaTeX2e: \emph{This is emphasized}.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
415 ; ("\\\\emph{\\([^}]+\\)}" 1 'italic keep)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
416 ; ;; LaTeX2e: \textbf{This is bold}, \textit{...}, \textsl{...}
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
417 ; ("\\\\text\\(\\(bf\\)\\|it\\|sl\\){\\([^}]+\\)}"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
418 ; 3 (if (match-beginning 2) 'bold 'italic) keep)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
419 ; ;; Old-style bf/em/it/sl. Stop at `\\' and un-escaped `&', for tables.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
420 ; ("\\\\\\(\\(bf\\)\\|em\\|it\\|sl\\)\\>\\(\\([^}&\\]\\|\\\\[^\\]\\)+\\)"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
421 ; 3 (if (match-beginning 2) 'bold 'italic) keep))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
422
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
423 ;; Rewritten with the help of Alexandra Bac <abac@welcome.disi.unige.it>.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
424 (defconst tex-font-lock-keywords-1
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
425 (eval-when-compile
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
426 (let* (;; Names of commands whose arg should be fontified as heading, etc.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
427 (headings (regexp-opt
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
428 '("title" "begin" "end" "chapter" "part"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
429 "section" "subsection" "subsubsection"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
430 "paragraph" "subparagraph" "subsubparagraph"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
431 "newcommand" "renewcommand" "newenvironment"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
432 "newtheorem")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
433 t))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
434 (variables (regexp-opt
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
435 '("newcounter" "newcounter*" "setcounter" "addtocounter"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
436 "setlength" "addtolength" "settowidth")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
437 t))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
438 (includes (regexp-opt
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
439 '("input" "include" "includeonly" "bibliography"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
440 "epsfig" "psfig" "epsf" "nofiles" "usepackage"
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
441 "documentstyle" "documentclass" "verbatiminput"
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
442 "includegraphics" "includegraphics*")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
443 t))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
444 ;; Miscellany.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
445 (slash "\\\\")
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
446 (opt " *\\(\\[[^]]*\\] *\\)*")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
447 ;; This would allow highlighting \newcommand\CMD but requires
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
448 ;; adapting subgroup numbers below.
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
449 ;; (arg "\\(?:{\\(\\(?:[^{}\\]+\\|\\\\.\\|{[^}]*}\\)+\\)\\|\\\\[a-z*]+\\)"))
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
450 (arg "{\\(\\(?:[^{}\\]+\\|\\\\.\\|{[^}]*}\\)+\\)"))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
451 (list
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
452 ;; Heading args.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
453 (list (concat slash headings "\\*?" opt arg)
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
454 ;; If ARG ends up matching too much (if the {} don't match, f.ex)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
455 ;; jit-lock will do funny things: when updating the buffer
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
456 ;; the re-highlighting is only done locally so it will just
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
457 ;; match the local line, but defer-contextually will
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
458 ;; match more lines at a time, so ARG will end up matching
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
459 ;; a lot more, which might suddenly include a comment
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
460 ;; so you get things highlighted bold when you type them
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
461 ;; but they get turned back to normal a little while later
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
462 ;; because "there's already a face there".
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
463 ;; Using `keep' works around this un-intuitive behavior as well
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
464 ;; as improves the behavior in the very rare case where you do
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
465 ;; have a comment in ARG.
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
466 3 'font-lock-function-name-face 'keep)
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
467 (list (concat slash "\\(re\\)?newcommand\\** *\\(\\\\[A-Za-z@]+\\)")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
468 2 'font-lock-function-name-face 'keep)
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
469 ;; Variable args.
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
470 (list (concat slash variables " *" arg) 2 'font-lock-variable-name-face)
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
471 ;; Include args.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
472 (list (concat slash includes opt arg) 3 'font-lock-builtin-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
473 ;; Definitions. I think.
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
474 '("^[ \t]*\\\\def *\\\\\\(\\(\\w\\|@\\)+\\)"
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
475 1 font-lock-function-name-face))))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
476 "Subdued expressions to highlight in TeX modes.")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
477
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
478 (defconst tex-font-lock-keywords-2
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
479 (append tex-font-lock-keywords-1
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
480 (eval-when-compile
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
481 (let* (;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
482 ;; Names of commands whose arg should be fontified with fonts.
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
483 (bold (regexp-opt '("textbf" "textsc" "textup"
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
484 "boldsymbol" "pmb") t))
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
485 (italic (regexp-opt '("textit" "textsl" "emph") t))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
486 (type (regexp-opt '("texttt" "textmd" "textrm" "textsf") t))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
487 ;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
488 ;; Names of commands whose arg should be fontified as a citation.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
489 (citations (regexp-opt
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
490 '("label" "ref" "pageref" "vref" "eqref"
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
491 "cite" "nocite" "index" "glossary" "bibitem"
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
492 ;; These are text, rather than citations.
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
493 ;; "caption" "footnote" "footnotemark" "footnotetext"
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
494 )
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
495 t))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
496 ;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
497 ;; Names of commands that should be fontified.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
498 (specials (regexp-opt
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
499 '("\\" "\\*" ;; "-"
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
500 "linebreak" "nolinebreak" "pagebreak" "nopagebreak"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
501 "newline" "newpage" "clearpage" "cleardoublepage"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
502 "displaybreak" "allowdisplaybreaks" "enlargethispage")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
503 t))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
504 (general "\\([a-zA-Z@]+\\**\\|[^ \t\n]\\)")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
505 ;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
506 ;; Miscellany.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
507 (slash "\\\\")
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
508 (opt " *\\(\\[[^]]*\\] *\\)*")
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
509 (arg "{\\(\\(?:[^{}\\]+\\|\\\\.\\|{[^}]*}\\)+\\)"))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
510 (list
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
511 ;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
512 ;; Citation args.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
513 (list (concat slash citations opt arg) 3 'font-lock-constant-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
514 ;;
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
515 ;; Text between `` quotes ''.
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
516 (cons (concat (regexp-opt `("``" "\"<" "\"`" "<<" "«") t)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
517 "[^'\">»]+" ;a bit pessimistic
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
518 (regexp-opt `("''" "\">" "\"'" ">>" "»") t))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
519 'font-lock-string-face)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
520 ;;
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
521 ;; Command names, special and general.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
522 (cons (concat slash specials) 'font-lock-warning-face)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
523 (concat slash general)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
524 ;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
525 ;; Font environments. It seems a bit dubious to use `bold' etc. faces
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
526 ;; since we might not be able to display those fonts.
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
527 (list (concat slash bold " *" arg) 2 '(quote bold) 'append)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
528 (list (concat slash italic " *" arg) 2 '(quote italic) 'append)
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
529 ;; (list (concat slash type arg) 2 '(quote bold-italic) 'append)
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
530 ;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
531 ;; Old-style bf/em/it/sl. Stop at `\\' and un-escaped `&', for tables.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
532 (list (concat "\\\\\\(\\(bf\\)\\|em\\|it\\|sl\\)\\>"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
533 "\\(\\([^}&\\]\\|\\\\[^\\]\\)+\\)")
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
534 3 '(if (match-beginning 2) 'bold 'italic) 'append)))))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
535 "Gaudy expressions to highlight in TeX modes.")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
536
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
537 (defvar tex-font-lock-keywords tex-font-lock-keywords-1
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
538 "Default expressions to highlight in TeX modes.")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
539
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
540
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
541 (defface tex-math-face
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
542 '((t :inherit font-lock-string-face))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
543 "Face used to highlight TeX math expressions.")
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
544 (defvar tex-math-face 'tex-math-face)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
545
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
546 ;; Use string syntax but math face for $...$.
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
547 (defun tex-font-lock-syntactic-face-function (state)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
548 (if (nth 3 state) tex-math-face font-lock-comment-face))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
549
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
550
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
551 (defun tex-define-common-keys (keymap)
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
552 "Define the keys that we want defined both in TeX mode and in the TeX shell."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
553 (define-key keymap "\C-c\C-k" 'tex-kill-job)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
554 (define-key keymap "\C-c\C-l" 'tex-recenter-output-buffer)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
555 (define-key keymap "\C-c\C-q" 'tex-show-print-queue)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
556 (define-key keymap "\C-c\C-p" 'tex-print)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
557 (define-key keymap "\C-c\C-v" 'tex-view)
4900
be43750c20d2 (tex-define-common-keys): Define menu items.
Richard M. Stallman <rms@gnu.org>
parents: 4768
diff changeset
558
be43750c20d2 (tex-define-common-keys): Define menu items.
Richard M. Stallman <rms@gnu.org>
parents: 4768
diff changeset
559 (define-key keymap [menu-bar tex] (cons "TeX" (make-sparse-keymap "TeX")))
be43750c20d2 (tex-define-common-keys): Define menu items.
Richard M. Stallman <rms@gnu.org>
parents: 4768
diff changeset
560
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
561 (define-key keymap [menu-bar tex tex-kill-job]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
562 '(menu-item "Tex Kill" tex-kill-job :enable (tex-shell-running)))
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
563 (define-key keymap [menu-bar tex tex-recenter-output-buffer]
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
564 '(menu-item "Tex Recenter" tex-recenter-output-buffer
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
565 :enable (get-buffer "*tex-shell*")))
4900
be43750c20d2 (tex-define-common-keys): Define menu items.
Richard M. Stallman <rms@gnu.org>
parents: 4768
diff changeset
566 (define-key keymap [menu-bar tex tex-show-print-queue]
be43750c20d2 (tex-define-common-keys): Define menu items.
Richard M. Stallman <rms@gnu.org>
parents: 4768
diff changeset
567 '("Show Print Queue" . tex-show-print-queue))
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
568 (define-key keymap [menu-bar tex tex-alt-print]
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
569 '(menu-item "Tex Print (alt printer)" tex-alt-print
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
570 :enable (stringp tex-print-file)))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
571 (define-key keymap [menu-bar tex tex-print]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
572 '(menu-item "Tex Print" tex-print :enable (stringp tex-print-file)))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
573 (define-key keymap [menu-bar tex tex-view]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
574 '(menu-item "Tex View" tex-view :enable (stringp tex-print-file))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
575
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
576 (defvar tex-mode-map
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
577 (let ((map (make-sparse-keymap)))
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
578 (set-keymap-parent map text-mode-map)
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
579 (tex-define-common-keys map)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
580 (define-key map "\"" 'tex-insert-quote)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
581 (define-key map "(" 'skeleton-pair-insert-maybe)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
582 (define-key map "{" 'skeleton-pair-insert-maybe)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
583 (define-key map "[" 'skeleton-pair-insert-maybe)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
584 (define-key map "$" 'skeleton-pair-insert-maybe)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
585 (define-key map "\n" 'tex-terminate-paragraph)
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
586 (define-key map "\t" 'indent-for-tab-command)
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
587 (define-key map "\M-\r" 'latex-insert-item)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
588 (define-key map "\C-c}" 'up-list)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
589 (define-key map "\C-c{" 'tex-insert-braces)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
590 (define-key map "\C-c\C-r" 'tex-region)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
591 (define-key map "\C-c\C-b" 'tex-buffer)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
592 (define-key map "\C-c\C-f" 'tex-file)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
593 (define-key map "\C-c\C-i" 'tex-bibtex-file)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
594 (define-key map "\C-c\C-o" 'tex-latex-block)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
595 (define-key map "\C-c\C-e" 'tex-close-latex-block)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
596 (define-key map "\C-c\C-u" 'tex-goto-last-unclosed-latex-block)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
597 (define-key map "\C-c\C-m" 'tex-feed-input)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
598 (define-key map [(control return)] 'tex-feed-input)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
599 (define-key map [menu-bar tex tex-bibtex-file]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
600 '("BibTeX File" . tex-bibtex-file))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
601 (define-key map [menu-bar tex tex-validate-region]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
602 '(menu-item "Validate Region" tex-validate-region :enable mark-active))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
603 (define-key map [menu-bar tex tex-validate-buffer]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
604 '("Validate Buffer" . tex-validate-buffer))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
605 (define-key map [menu-bar tex tex-region]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
606 '(menu-item "TeX Region" tex-region :enable mark-active))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
607 (define-key map [menu-bar tex tex-buffer]
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
608 '("TeX Buffer" . tex-buffer))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
609 (define-key map [menu-bar tex tex-file] '("TeX File" . tex-file))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
610 map)
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
611 "Keymap shared by TeX modes.")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
612
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
613 (defvar latex-mode-map
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
614 (let ((map (make-sparse-keymap)))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
615 (set-keymap-parent map tex-mode-map)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
616 map)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
617 "Keymap for `latex-mode'. See also `tex-mode-map'.")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
618
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
619 (defvar plain-tex-mode-map
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
620 (let ((map (make-sparse-keymap)))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
621 (set-keymap-parent map tex-mode-map)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
622 map)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
623 "Keymap for `plain-tex-mode'. See also `tex-mode-map'.")
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
624
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
625 (defvar tex-shell-map
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
626 (let ((m (make-sparse-keymap)))
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
627 (set-keymap-parent m shell-mode-map)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
628 (tex-define-common-keys m)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
629 m)
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
630 "Keymap for the TeX shell.
10197
66681eddfd70 Make keymap for tex-shell the shell-mode-map.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 10190
diff changeset
631 Inherits `shell-mode-map' with a few additions.")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
632
14383
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
633 (defvar tex-face-alist
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
634 '((bold . "{\\bf ")
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
635 (italic . "{\\it ")
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
636 (bold-italic . "{\\bi ") ; hypothetical
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
637 (underline . "\\underline{")
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
638 (default . "{\\rm "))
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
639 "Alist of face and TeX font name for facemenu.")
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
640
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
641 (defvar tex-latex-face-alist
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
642 `((italic . "{\\em ")
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
643 ,@tex-face-alist)
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
644 "Alist of face and LaTeX font name for facemenu.")
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
645
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
646 ;; This would be a lot simpler if we just used a regexp search,
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
647 ;; but then it would be too slow.
256
7e4c7ef44243 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 85
diff changeset
648 ;;;###autoload
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
649 (defun tex-mode ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
650 "Major mode for editing files of input for TeX, LaTeX, or SliTeX.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
651 Tries to determine (by looking at the beginning of the file) whether
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
652 this file is for plain TeX, LaTeX, or SliTeX and calls `plain-tex-mode',
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
653 `latex-mode', or `slitex-mode', respectively. If it cannot be determined,
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
654 such as if there are no commands in the file, the value of `tex-default-mode'
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
655 says which mode to use."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
656 (interactive)
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
657 (let ((mode tex-default-mode) slash comment)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
658 (save-excursion
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
659 (goto-char (point-min))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
660 (while (and (setq slash (search-forward "\\" nil t))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
661 (setq comment (let ((search-end (point)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
662 (save-excursion
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
663 (beginning-of-line)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
664 (search-forward "%" search-end t))))))
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
665 (when (and slash (not comment))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
666 (setq mode
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
667 (if (looking-at
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
668 (eval-when-compile
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
669 (concat
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
670 (regexp-opt '("documentstyle" "documentclass"
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
671 "begin" "section" "part" "chapter") 'words)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
672 "\\|NeedsTeXFormat{LaTeX")))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
673 (if (looking-at
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
674 "document\\(style\\|class\\)\\(\\[.*\\]\\)?{slides}")
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
675 'slitex-mode
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
676 'latex-mode)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
677 'plain-tex-mode))))
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
678 (funcall mode)))
2598
2189edb30955 Removed spurious comment (obsoleted by ;;;###autoload).
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2588
diff changeset
679
269
2ca8cdb96a9f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 256
diff changeset
680 ;;;###autoload
2571
b65cf676a09b All fsets changed to defaliases.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2307
diff changeset
681 (defalias 'TeX-mode 'tex-mode)
269
2ca8cdb96a9f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 256
diff changeset
682 ;;;###autoload
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
683 (defalias 'plain-TeX-mode 'plain-tex-mode)
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
684 ;;;###autoload
2571
b65cf676a09b All fsets changed to defaliases.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2307
diff changeset
685 (defalias 'LaTeX-mode 'latex-mode)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
686
256
7e4c7ef44243 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 85
diff changeset
687 ;;;###autoload
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
688 (define-derived-mode plain-tex-mode text-mode "TeX"
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
689 "Major mode for editing files of input for plain TeX.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
690 Makes $ and } display the characters they match.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
691 Makes \" insert `` when it seems to be the beginning of a quotation,
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
692 and '' when it appears to be the end; it inserts \" only after a \\.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
693
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
694 Use \\[tex-region] to run TeX on the current region, plus a \"header\"
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
695 copied from the top of the file (containing macro definitions, etc.),
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
696 running TeX under a special subshell. \\[tex-buffer] does the whole buffer.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
697 \\[tex-file] saves the buffer and then processes the file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
698 \\[tex-print] prints the .dvi file made by any of these.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
699 \\[tex-view] previews the .dvi file made by any of these.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
700 \\[tex-bibtex-file] runs bibtex on the file of the current buffer.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
701
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
702 Use \\[tex-validate-buffer] to check buffer for paragraphs containing
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
703 mismatched $'s or braces.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
704
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
705 Special commands:
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
706 \\{plain-tex-mode-map}
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
707
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
708 Mode variables:
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
709 tex-run-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
710 Command string used by \\[tex-region] or \\[tex-buffer].
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
711 tex-directory
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
712 Directory in which to create temporary files for TeX jobs
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
713 run by \\[tex-region] or \\[tex-buffer].
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
714 tex-dvi-print-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
715 Command string used by \\[tex-print] to print a .dvi file.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
716 tex-alt-dvi-print-command
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
717 Alternative command string used by \\[tex-print] (when given a prefix
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
718 argument) to print a .dvi file.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
719 tex-dvi-view-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
720 Command string used by \\[tex-view] to preview a .dvi file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
721 tex-show-queue-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
722 Command string used by \\[tex-show-print-queue] to show the print
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
723 queue that \\[tex-print] put your job on.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
724
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
725 Entering Plain-tex mode runs the hook `text-mode-hook', then the hook
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
726 `tex-mode-hook', and finally the hook `plain-tex-mode-hook'. When the
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
727 special subshell is initiated, the hook `tex-shell-hook' is run."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
728 (tex-common-initialization)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
729 (setq tex-command tex-run-command)
13248
a7e83f7eb499 (tex-start-of-header): Now a regexp.
Richard M. Stallman <rms@gnu.org>
parents: 12704
diff changeset
730 (setq tex-start-of-header "%\\*\\*start of header")
a7e83f7eb499 (tex-start-of-header): Now a regexp.
Richard M. Stallman <rms@gnu.org>
parents: 12704
diff changeset
731 (setq tex-end-of-header "%\\*\\*end of header")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
732 (setq tex-trailer "\\bye\n")
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
733 (run-hooks 'tex-mode-hook))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
734
256
7e4c7ef44243 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 85
diff changeset
735 ;;;###autoload
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
736 (define-derived-mode latex-mode text-mode "LaTeX"
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
737 "Major mode for editing files of input for LaTeX.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
738 Makes $ and } display the characters they match.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
739 Makes \" insert `` when it seems to be the beginning of a quotation,
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
740 and '' when it appears to be the end; it inserts \" only after a \\.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
741
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
742 Use \\[tex-region] to run LaTeX on the current region, plus the preamble
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
743 copied from the top of the file (containing \\documentstyle, etc.),
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
744 running LaTeX under a special subshell. \\[tex-buffer] does the whole buffer.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
745 \\[tex-file] saves the buffer and then processes the file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
746 \\[tex-print] prints the .dvi file made by any of these.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
747 \\[tex-view] previews the .dvi file made by any of these.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
748 \\[tex-bibtex-file] runs bibtex on the file of the current buffer.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
749
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
750 Use \\[tex-validate-buffer] to check buffer for paragraphs containing
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
751 mismatched $'s or braces.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
752
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
753 Special commands:
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
754 \\{latex-mode-map}
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
755
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
756 Mode variables:
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
757 latex-run-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
758 Command string used by \\[tex-region] or \\[tex-buffer].
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
759 tex-directory
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
760 Directory in which to create temporary files for LaTeX jobs
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
761 run by \\[tex-region] or \\[tex-buffer].
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
762 tex-dvi-print-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
763 Command string used by \\[tex-print] to print a .dvi file.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
764 tex-alt-dvi-print-command
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
765 Alternative command string used by \\[tex-print] (when given a prefix
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
766 argument) to print a .dvi file.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
767 tex-dvi-view-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
768 Command string used by \\[tex-view] to preview a .dvi file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
769 tex-show-queue-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
770 Command string used by \\[tex-show-print-queue] to show the print
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
771 queue that \\[tex-print] put your job on.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
772
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
773 Entering Latex mode runs the hook `text-mode-hook', then
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
774 `tex-mode-hook', and finally `latex-mode-hook'. When the special
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
775 subshell is initiated, `tex-shell-hook' is run."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
776 (tex-common-initialization)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
777 (setq tex-command latex-run-command)
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
778 (setq tex-start-of-header "\\\\document\\(style\\|class\\)")
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
779 (setq tex-end-of-header "\\\\begin\\s-*{document}")
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
780 (setq tex-trailer "\\end\\s-*{document}\n")
5425
3dd5ff54e1cd (slitex-mode, latex-mode): Set paragraph-start and
Richard M. Stallman <rms@gnu.org>
parents: 5262
diff changeset
781 ;; A line containing just $$ is treated as a paragraph separator.
3dd5ff54e1cd (slitex-mode, latex-mode): Set paragraph-start and
Richard M. Stallman <rms@gnu.org>
parents: 5262
diff changeset
782 ;; A line starting with $$ starts a paragraph,
3dd5ff54e1cd (slitex-mode, latex-mode): Set paragraph-start and
Richard M. Stallman <rms@gnu.org>
parents: 5262
diff changeset
783 ;; but does not separate paragraphs if it has more stuff on it.
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
784 (setq paragraph-start
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
785 (concat "[\f%]\\|[ \t]*\\($\\|\\$\\$\\|"
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
786 "\\\\[][]\\|"
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
787 "\\\\" (regexp-opt (append
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
788 (mapcar 'car latex-section-alist)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
789 '("begin" "label" "end"
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
790 "item" "bibitem" "newline" "noindent"
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
791 "newpage" "footnote" "marginpar"
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
792 "parbox" "caption")) t)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
793 "\\>\\|\\\\[a-z]*" (regexp-opt '("space" "skip" "page") t)
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
794 "\\>\\)"))
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
795 (setq paragraph-separate
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
796 (concat "[\f%]\\|[ \t]*\\($\\|"
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
797 "\\\\[][]\\|"
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
798 "\\\\" (regexp-opt (append
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
799 (mapcar 'car latex-section-alist)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
800 '("begin" "label" "end" )) t)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
801 "\\>\\|\\\\\\(" (regexp-opt '("item" "bibitem" "newline"
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
802 "noindent" "newpage" "footnote"
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
803 "marginpar" "parbox" "caption"))
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
804 "\\|\\$\\$\\|[a-z]*\\(space\\|skip\\|page[a-z]*\\)"
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
805 "\\>\\)[ \t]*\\($\\|%\\)\\)"))
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
806 (set (make-local-variable 'imenu-create-index-function)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
807 'latex-imenu-create-index)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
808 (set (make-local-variable 'tex-face-alist) tex-latex-face-alist)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
809 (set (make-local-variable 'fill-nobreak-predicate)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
810 'latex-fill-nobreak-predicate)
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
811 (set (make-local-variable 'indent-line-function) 'latex-indent)
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
812 (set (make-local-variable 'fill-indent-according-to-mode) t)
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
813 (set (make-local-variable 'outline-regexp) latex-outline-regexp)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
814 (set (make-local-variable 'outline-level) 'latex-outline-level)
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
815 (set (make-local-variable 'forward-sexp-function) 'latex-forward-sexp)
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
816 (set (make-local-variable 'skeleton-end-hook) nil)
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
817 (run-hooks 'tex-mode-hook))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
818
4768
9d84105b1248 (slitex-mode): Add ###autoload magic cookie.
Brian Fox <bfox@gnu.org>
parents: 4376
diff changeset
819 ;;;###autoload
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
820 (define-derived-mode slitex-mode latex-mode "SliTeX"
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
821 "Major mode for editing files of input for SliTeX.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
822 Makes $ and } display the characters they match.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
823 Makes \" insert `` when it seems to be the beginning of a quotation,
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
824 and '' when it appears to be the end; it inserts \" only after a \\.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
825
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
826 Use \\[tex-region] to run SliTeX on the current region, plus the preamble
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
827 copied from the top of the file (containing \\documentstyle, etc.),
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
828 running SliTeX under a special subshell. \\[tex-buffer] does the whole buffer.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
829 \\[tex-file] saves the buffer and then processes the file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
830 \\[tex-print] prints the .dvi file made by any of these.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
831 \\[tex-view] previews the .dvi file made by any of these.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
832 \\[tex-bibtex-file] runs bibtex on the file of the current buffer.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
833
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
834 Use \\[tex-validate-buffer] to check buffer for paragraphs containing
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
835 mismatched $'s or braces.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
836
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
837 Special commands:
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
838 \\{slitex-mode-map}
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
839
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
840 Mode variables:
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
841 slitex-run-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
842 Command string used by \\[tex-region] or \\[tex-buffer].
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
843 tex-directory
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
844 Directory in which to create temporary files for SliTeX jobs
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
845 run by \\[tex-region] or \\[tex-buffer].
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
846 tex-dvi-print-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
847 Command string used by \\[tex-print] to print a .dvi file.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
848 tex-alt-dvi-print-command
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
849 Alternative command string used by \\[tex-print] (when given a prefix
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
850 argument) to print a .dvi file.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
851 tex-dvi-view-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
852 Command string used by \\[tex-view] to preview a .dvi file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
853 tex-show-queue-command
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
854 Command string used by \\[tex-show-print-queue] to show the print
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
855 queue that \\[tex-print] put your job on.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
856
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
857 Entering SliTeX mode runs the hook `text-mode-hook', then the hook
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
858 `tex-mode-hook', then the hook `latex-mode-hook', and finally the hook
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
859 `slitex-mode-hook'. When the special subshell is initiated, the hook
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
860 `tex-shell-hook' is run."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
861 (setq tex-command slitex-run-command)
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
862 (setq tex-start-of-header "\\\\documentstyle{slides}\\|\\\\documentclass{slides}"))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
863
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
864 (defun tex-common-initialization ()
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
865 (set-syntax-table tex-mode-syntax-table)
18587
3290767e31d8 (tex-common-initialization):
Richard M. Stallman <rms@gnu.org>
parents: 18393
diff changeset
866 ;; Regexp isearch should accept newline and formfeed as whitespace.
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
867 (set (make-local-variable 'search-whitespace-regexp) "[ \t\r\n\f]+")
5262
b3a689b41d39 (tex-common-initialization): Make paragraph-start
Richard M. Stallman <rms@gnu.org>
parents: 5088
diff changeset
868 ;; A line containing just $$ is treated as a paragraph separator.
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
869 (set (make-local-variable 'paragraph-start)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
870 "[ \t]*$\\|[\f\\\\%]\\|[ \t]*\\$\\$")
5425
3dd5ff54e1cd (slitex-mode, latex-mode): Set paragraph-start and
Richard M. Stallman <rms@gnu.org>
parents: 5262
diff changeset
871 ;; A line starting with $$ starts a paragraph,
3dd5ff54e1cd (slitex-mode, latex-mode): Set paragraph-start and
Richard M. Stallman <rms@gnu.org>
parents: 5262
diff changeset
872 ;; but does not separate paragraphs if it has more stuff on it.
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
873 (set (make-local-variable 'paragraph-separate)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
874 "[ \t]*$\\|[\f\\\\%]\\|[ \t]*\\$\\$[ \t]*$")
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
875 (set (make-local-variable 'comment-start) "%")
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
876 (set (make-local-variable 'comment-add) 1)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
877 (set (make-local-variable 'comment-start-skip)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
878 "\\(\\(^\\|[^\\]\\)\\(\\\\\\\\\\)*\\)\\(%+ *\\)")
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
879 (set (make-local-variable 'parse-sexp-ignore-comments) t)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
880 (set (make-local-variable 'compare-windows-whitespace)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
881 'tex-categorize-whitespace)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
882 (set (make-local-variable 'facemenu-add-face-function)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
883 (lambda (face end)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
884 (let ((face-text (cdr (assq face tex-face-alist))))
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
885 (if face-text
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
886 face-text
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
887 (error "Face %s not configured for %s mode" face mode-name)))))
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
888 (set (make-local-variable 'facemenu-end-add-face) "}")
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
889 (set (make-local-variable 'facemenu-remove-face-function) t)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
890 (set (make-local-variable 'font-lock-defaults)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
891 '((tex-font-lock-keywords
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
892 tex-font-lock-keywords-1 tex-font-lock-keywords-2)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
893 nil nil ((?$ . "\"")) nil
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
894 ;; Who ever uses that anyway ???
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
895 (font-lock-mark-block-function . mark-paragraph)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
896 (font-lock-syntactic-face-function
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
897 . tex-font-lock-syntactic-face-function)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
898 (make-local-variable 'tex-command)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
899 (make-local-variable 'tex-start-of-header)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
900 (make-local-variable 'tex-end-of-header)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
901 (make-local-variable 'tex-trailer))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
902
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
903 (defun tex-categorize-whitespace (backward-limit)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
904 ;; compare-windows-whitespace is set to this.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
905 ;; This is basically a finite-state machine.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
906 ;; Returns a symbol telling how TeX would treat
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
907 ;; the whitespace we are looking at: null, space, or par.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
908 (let ((category 'null)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
909 (not-finished t))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
910 (skip-chars-backward " \t\n\f" backward-limit)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
911 (while not-finished
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
912 (cond ((looking-at "[ \t]+")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
913 (goto-char (match-end 0))
18931
43b52e6a35c2 (tex-categorize-whitespace): Use eq, not eql.
Richard M. Stallman <rms@gnu.org>
parents: 18587
diff changeset
914 (if (eq category 'null)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
915 (setq category 'space)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
916 ((looking-at "\n")
18931
43b52e6a35c2 (tex-categorize-whitespace): Use eq, not eql.
Richard M. Stallman <rms@gnu.org>
parents: 18587
diff changeset
917 (cond ((eq category 'newline)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
918 (setq category 'par)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
919 (setq not-finished nil))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
920 (t
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
921 (setq category 'newline) ;a strictly internal state
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
922 (goto-char (match-end 0)))))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
923 ((looking-at "\f+")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
924 (setq category 'par)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
925 (setq not-finished nil))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
926 (t
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
927 (setq not-finished nil))))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
928 (skip-chars-forward " \t\n\f")
18931
43b52e6a35c2 (tex-categorize-whitespace): Use eq, not eql.
Richard M. Stallman <rms@gnu.org>
parents: 18587
diff changeset
929 (if (eq category 'newline)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
930 'space ;TeX doesn't distinguish
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
931 category)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
932
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
933 (defun tex-insert-quote (arg)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
934 "Insert the appropriate quote marks for TeX.
2836
d95acb2243f9 (tex-insert-quote): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 2598
diff changeset
935 Inserts the value of `tex-open-quote' (normally ``) or `tex-close-quote'
d95acb2243f9 (tex-insert-quote): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 2598
diff changeset
936 \(normally '') depending on the context. With prefix argument, always
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
937 inserts \" characters."
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
938 (interactive "*P")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
939 (if arg
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
940 (self-insert-command (prefix-numeric-value arg))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
941 (insert
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
942 (cond ((= (preceding-char) ?\\) ?\")
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
943 ((memq (char-syntax (preceding-char)) '(?\( ?> ?\ )) tex-open-quote)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
944 (t tex-close-quote)))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
945
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
946 (defun tex-validate-buffer ()
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
947 "Check current buffer for paragraphs containing mismatched braces or $s.
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
948 Their positions are recorded in the buffer `*Occur*'.
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
949 To find a particular invalidity from `*Occur*', switch to that buffer
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
950 and type C-c C-c or click with mouse-2
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
951 on the line for the invalidity you want to see."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
952 (interactive)
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
953 (let ((buffer (current-buffer))
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
954 (prevpos (point-min))
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
955 (linenum nil)
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
956 (num-matches 0))
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
957 (with-output-to-temp-buffer "*Occur*"
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
958 (princ "Mismatches:\n")
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
959 (save-excursion
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
960 (set-buffer standard-output)
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
961 (occur-mode)
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
962 (setq occur-buffer buffer)
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
963 (setq occur-nlines 0))
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
964 (save-excursion
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
965 (goto-char (point-max))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
966 (while (and (not (input-pending-p)) (not (bobp)))
15644
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
967 (let ((end (point))
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
968 prev-end)
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
969 ;; Scan the previous paragraph for invalidities.
15644
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
970 (if (search-backward "\n\n" nil t)
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
971 (progn
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
972 (setq prev-end (point))
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
973 (forward-char 2))
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
974 (goto-char (setq prev-end (point-min))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
975 (or (tex-validate-region (point) end)
15644
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
976 (let* ((oend end)
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
977 (end (save-excursion (forward-line 1) (point)))
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
978 start tem)
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
979 (beginning-of-line)
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
980 (setq start (point))
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
981 ;; Keep track of line number as we scan,
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
982 ;; in a cumulative fashion.
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
983 (if linenum
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
984 (setq linenum (- linenum (count-lines prevpos (point))))
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
985 (setq linenum (1+ (count-lines 1 start))))
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
986 (setq prevpos (point))
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
987 ;; Mention this mismatch in *Occur*.
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
988 ;; Since we scan from end of buffer to beginning,
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
989 ;; add each mismatch at the beginning of *Occur*.
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
990 (save-excursion
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
991 (setq tem (point-marker))
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
992 (set-buffer standard-output)
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
993 (goto-char (point-min))
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
994 ;; Skip "Mismatches:" header line.
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
995 (forward-line 1)
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
996 (setq num-matches (1+ num-matches))
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
997 (insert-buffer-substring buffer start end)
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
998 (let (text-beg (text-end (point-marker)))
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
999 (forward-char (- start end))
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1000 (setq text-beg (point-marker))
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1001 (insert (format "%3d: " linenum))
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1002 (put-text-property text-beg (- text-end 1)
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1003 'mouse-face 'highlight)
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1004 (put-text-property text-beg (- text-end 1)
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1005 'occur tem)))))
15644
3b4678aa4e9f (tex-validate-region): Skip fwd over whitespace
Karl Heuer <kwzh@gnu.org>
parents: 15513
diff changeset
1006 (goto-char prev-end))))
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1007 (with-current-buffer standard-output
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1008 (if (eq num-matches 0)
4376
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
1009 (insert "None!\n"))
109294166e68 (validate-tex-buffer): Record mismatches in *Occur*.
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
1010 (if (interactive-p)
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1011 (message "%d mismatches found" num-matches))))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1012
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1013 (defun tex-validate-region (start end)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1014 "Check for mismatched braces or $'s in region.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1015 Returns t if no mismatches. Returns nil and moves point to suspect
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1016 area if a mismatch is found."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1017 (interactive "r")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1018 (let ((failure-point nil) (max-possible-sexps (- end start)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1019 (save-excursion
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1020 (condition-case ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1021 (save-restriction
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1022 (narrow-to-region start end)
20203
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1023 ;; First check that the open and close parens balance in numbers.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1024 (goto-char start)
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1025 (while (<= 0 (setq max-possible-sexps (1- max-possible-sexps)))
20203
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1026 (forward-sexp 1))
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1027 ;; Now check that like matches like.
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1028 (goto-char start)
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1029 (while (progn (skip-syntax-forward "^(")
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1030 (not (eobp)))
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1031 (let ((match (matching-paren (following-char))))
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1032 (save-excursion
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1033 (forward-sexp 1)
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1034 (or (= (preceding-char) match)
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1035 (error "Mismatched parentheses"))))
f1a4588c8075 (tex-validate-region): Really check
Karl Heuer <kwzh@gnu.org>
parents: 18931
diff changeset
1036 (forward-char 1)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1037 (error
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1038 (skip-syntax-forward " .>")
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1039 (setq failure-point (point)))))
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1040 (if failure-point (goto-char failure-point))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1041 (not failure-point)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1042
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1043 (defun tex-terminate-paragraph (inhibit-validation)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1044 "Insert two newlines, breaking a paragraph for TeX.
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
1045 Check for mismatched braces or $s in paragraph being terminated.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1046 A prefix arg inhibits the checking."
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1047 (interactive "*P")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1048 (or inhibit-validation
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1049 (save-excursion
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1050 (tex-validate-region
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1051 (save-excursion
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1052 (search-backward "\n\n" nil 'move)
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1053 (point))
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1054 (point)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1055 (message "Paragraph being closed appears to contain a mismatch"))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1056 (insert "\n\n"))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1057
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1058 (defun tex-insert-braces ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1059 "Make a pair of braces and be poised to type inside of them."
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1060 (interactive "*")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1061 (insert ?\{)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1062 (save-excursion
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1063 (insert ?})))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1064
21121
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1065 ;; This function is used as the value of fill-nobreak-predicate
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1066 ;; in LaTeX mode. Its job is to prevent line-breaking inside
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1067 ;; of a \verb construct.
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1068 (defun latex-fill-nobreak-predicate ()
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1069 (let ((opoint (point))
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1070 inside)
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1071 (save-excursion
21121
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1072 (save-restriction
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1073 (beginning-of-line)
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1074 (narrow-to-region (point) opoint)
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1075 (while (re-search-forward "\\\\verb\\(.\\)" nil t)
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1076 (unless (re-search-forward (regexp-quote (match-string 1)) nil t)
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1077 (setq inside t)))))
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1078 inside))
dd5c2baa6674 (latex-mode): Set fill-nobreak-predicate.
Richard M. Stallman <rms@gnu.org>
parents: 20203
diff changeset
1079
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1080 (defvar latex-block-default "enumerate")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1081
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1082 ;; Like tex-insert-braces, but for LaTeX.
15513
1252826f389b (tex-common-initialization): Set skeleton-further-elements.
Richard M. Stallman <rms@gnu.org>
parents: 15240
diff changeset
1083 (define-skeleton tex-latex-block
1252826f389b (tex-common-initialization): Set skeleton-further-elements.
Richard M. Stallman <rms@gnu.org>
parents: 15240
diff changeset
1084 "Create a matching pair of lines \\begin[OPT]{NAME} and \\end{NAME} at point.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1085 Puts point on a blank line between them."
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1086 (let ((choice (completing-read (format "LaTeX block name [%s]: "
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1087 latex-block-default)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1088 (mapcar 'list
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1089 (append standard-latex-block-names
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1090 latex-block-names))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1091 nil nil nil nil latex-block-default)))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1092 (setq latex-block-default choice)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1093 (unless (or (member choice standard-latex-block-names)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1094 (member choice latex-block-names))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1095 ;; Remember new block names for later completion.
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1096 (push choice latex-block-names))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1097 choice)
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1098 \n "\\begin{" str ?\}
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1099 ?\[ (skeleton-read "[options]: ") & ?\] | -1
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1100 > \n _ \n
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1101 "\\end{" str ?\} > \n)
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1102
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1103 (define-skeleton latex-insert-item
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1104 "Insert a \item macro."
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1105 nil
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1106 \n "\\item " >)
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1107
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1108
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1109 ;;;;
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1110 ;;;; LaTeX syntax navigation
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1111 ;;;;
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1112
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1113 (defun tex-last-unended-begin ()
7285
27e6ef8494b2 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6632
diff changeset
1114 "Leave point at the beginning of the last `\\begin{...}' that is unended."
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1115 (while (and (re-search-backward "\\\\\\(begin\\|end\\)\\s *{")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1116 (looking-at "\\\\end"))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1117 (tex-last-unended-begin)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1118
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1119 (defun tex-next-unmatched-end ()
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1120 "Leave point at the end of the next `\\end' that is unended."
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1121 (while (and (re-search-forward "\\\\\\(begin\\|end\\)\\s *{[^}]+}")
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1122 (save-excursion (goto-char (match-beginning 0))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1123 (looking-at "\\\\begin")))
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1124 (tex-next-unmatched-end)))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1125
7297
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1126 (defun tex-goto-last-unclosed-latex-block ()
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1127 "Move point to the last unclosed \\begin{...}.
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1128 Mark is left at original location."
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1129 (interactive)
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1130 (let ((spot))
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1131 (save-excursion
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1132 (condition-case nil
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1133 (tex-last-unended-begin)
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1134 (error (error "Couldn't find unended \\begin")))
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1135 (setq spot (point)))
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1136 (push-mark)
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1137 (goto-char spot)))
a480d11d5594 (tex-goto-last-unclosed-latex-block): New function. Bound to C-c C-u in
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents: 7285
diff changeset
1138
32045
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1139 (defun latex-backward-sexp-1 ()
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1140 "Like (backward-sexp 1) but aware of multi-char elements."
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1141 (let ((pos (point))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1142 (forward-sexp-function))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1143 (backward-sexp 1)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1144 (if (looking-at "\\\\begin\\>")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1145 (signal 'scan-error
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1146 (list "Containing expression ends prematurely"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1147 (point) (prog1 (point) (goto-char pos))))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1148 (when (eq (char-after) ?{)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1149 (let ((newpos (point)))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1150 (when (ignore-errors (backward-sexp 1) t)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1151 (if (looking-at "\\\\end\\>")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1152 (tex-last-unended-begin)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1153 (goto-char newpos))))))))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1154
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1155 (defun latex-forward-sexp-1 ()
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1156 "Like (forward-sexp 1) but aware of multi-char elements."
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1157 (let ((pos (point))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1158 (forward-sexp-function))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1159 (forward-sexp 1)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1160 (let ((newpos (point)))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1161 (skip-syntax-backward "/w")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1162 (cond
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1163 ((looking-at "\\\\end\\>")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1164 (signal 'scan-error
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1165 (list "Containing expression ends prematurely"
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1166 (point)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1167 (prog1
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1168 (progn (ignore-errors (forward-sexp 2)) (point))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1169 (goto-char pos)))))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1170 ((looking-at "\\\\begin\\>")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1171 (goto-char (match-end 0))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1172 (tex-next-unmatched-end))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1173 (t (goto-char newpos))))))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1174
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1175 (defun latex-forward-sexp (&optional arg)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1176 "Like `forward-sexp' but aware of multi-char elements."
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1177 (interactive "P")
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1178 (unless arg (setq arg 1))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1179 (let ((pos (point)))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1180 (condition-case err
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1181 (while (/= arg 0)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1182 (setq arg
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1183 (if (> arg 0)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1184 (progn (latex-forward-sexp-1) (1- arg))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1185 (progn (latex-backward-sexp-1) (1+ arg)))))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1186 (scan-error
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1187 (goto-char pos)
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1188 (signal (car err) (cdr err))))))
74db1ffe4fe8 (latex-metasection-list): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31990
diff changeset
1189
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1190 (defun latex-syntax-after ()
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1191 "Like (char-syntax (char-after)) but aware of multi-char elements."
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1192 (if (looking-at "\\\\end\\>") ?\) (char-syntax (following-char))))
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1193
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1194 (defun latex-skip-close-parens ()
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1195 "Like (skip-syntax-forward \" )\") but aware of multi-char elements."
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1196 (let ((forward-sexp-function nil))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1197 (while (progn (skip-syntax-forward " )")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1198 (looking-at "\\\\end\\>"))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1199 (forward-sexp 2))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1200
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1201 (defun latex-down-list ()
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1202 "Like (down-list 1) but aware of multi-char elements."
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1203 (forward-comment (point-max))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1204 (let ((forward-sexp-function nil))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1205 (if (not (looking-at "\\\\begin\\>"))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1206 (down-list 1)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1207 (forward-sexp 1)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1208 ;; Skip arguments.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1209 (while (looking-at "[ \t]*\\s(") (forward-sexp)))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1210
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1211 (defun tex-close-latex-block ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1212 "Creates an \\end{...} to match the last unclosed \\begin{...}."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1213 (interactive "*")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1214 (let ((new-line-needed (bolp))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1215 text indentation)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1216 (save-excursion
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1217 (condition-case nil
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1218 (tex-last-unended-begin)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1219 (error (error "Couldn't find unended \\begin")))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1220 (setq indentation (current-column))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1221 (re-search-forward "\\\\begin\\(\\s *{[^}\n]*}\\)")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1222 (setq text (buffer-substring (match-beginning 1) (match-end 1))))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1223 (indent-to indentation)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1224 (insert "\\end" text)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1225 (if new-line-needed (insert ?\n))))
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1226
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1227 (defconst tex-discount-args-cmds
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1228 '("begin" "end" "input" "special" "cite" "ref" "include" "includeonly"
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1229 "documentclass" "usepackage" "label")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1230 "TeX commands whose arguments should not be counted as text.")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1231
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1232 (defun tex-count-words (begin end)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1233 "Count the number of words in the buffer."
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1234 (interactive
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1235 (if (and transient-mark-mode mark-active)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1236 (list (region-beginning) (region-end))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1237 (list (point-min) (point-max))))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1238 ;; TODO: skip comments and math and maybe some environments.
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1239 (save-excursion
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1240 (goto-char begin)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1241 (let ((count 0))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1242 (while (and (< (point) end) (re-search-forward "\\<" end t))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1243 (if (not (eq (char-syntax (preceding-char)) ?/))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1244 (progn
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1245 ;; Don't count single-char words.
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1246 (unless (looking-at ".\\>") (incf count))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1247 (forward-char 1))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1248 (let ((cmd
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1249 (buffer-substring-no-properties
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1250 (point) (progn (when (zerop (skip-chars-forward "a-zA-Z@"))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1251 (forward-char 1))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1252 (point)))))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1253 (when (member cmd tex-discount-args-cmds)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1254 (skip-chars-forward "*")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1255 (forward-comment (point-max))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1256 (when (looking-at "\\[")
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1257 (forward-sexp 1)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1258 (forward-comment (point-max)))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1259 (if (not (looking-at "{"))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1260 (forward-char 1)
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1261 (forward-sexp 1))))))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1262 (message "%s words" count))))
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1263
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1264
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1265
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1266 ;;; Invoking TeX in an inferior shell.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1267
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1268 ;; Why use a shell instead of running TeX directly? Because if TeX
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1269 ;; gets stuck, the user can switch to the shell window and type at it.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1270
37896
5cc52d5c2f2b (tex-mode-syntax-table): Add ^.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 36105
diff changeset
1271 ;; The utility functions:
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1272
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1273 (define-derived-mode tex-shell shell-mode "TeX-Shell"
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1274 (compilation-shell-minor-mode t))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1275
7834
fc1c95bf734b (tex-start-shell): Add autoload.
Richard M. Stallman <rms@gnu.org>
parents: 7827
diff changeset
1276 ;;;###autoload
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1277 (defun tex-start-shell ()
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1278 (with-current-buffer
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1279 (make-comint
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1280 "tex-shell"
34139
358adc86d127 (tex-start-shell): Obey shell-file-name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33789
diff changeset
1281 (or tex-shell-file-name (getenv "ESHELL") shell-file-name)
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1282 nil)
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1283 (let ((proc (get-process "tex-shell")))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1284 (set-process-sentinel proc 'tex-shell-sentinel)
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1285 (process-kill-without-query proc)
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1286 (tex-shell)
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1287 (while (zerop (buffer-size))
10572
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1288 (sleep-for 1)))))
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1289
23761
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1290 (defun tex-feed-input ()
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1291 "Send input to the tex shell process.
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1292 In the tex buffer this can be used to continue an interactive tex run.
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1293 In the tex shell buffer this command behaves like `comint-send-input'."
23761
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1294 (interactive)
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1295 (set-buffer (process-buffer (get-process "tex-shell")))
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1296 (comint-send-input)
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1297 (tex-recenter-output-buffer nil))
a99c30431979 (tex-feed-input): New function.
Richard M. Stallman <rms@gnu.org>
parents: 23642
diff changeset
1298
10572
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1299 (defun tex-display-shell ()
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1300 "Make the TeX shell buffer visible in a window."
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1301 (display-buffer (process-buffer (get-process "tex-shell")))
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1302 (tex-recenter-output-buffer nil))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1303
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1304 (defun tex-shell-sentinel (proc msg)
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1305 (cond ((null (buffer-name (process-buffer proc)))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1306 ;; buffer killed
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1307 (set-process-buffer proc nil)
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1308 (tex-delete-last-temp-files))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1309 ((memq (process-status proc) '(signal exit))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1310 (tex-delete-last-temp-files))))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1311
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1312 (defun tex-set-buffer-directory (buffer directory)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1313 "Set BUFFER's default directory to be DIRECTORY."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1314 (setq directory (file-name-as-directory (expand-file-name directory)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1315 (if (not (file-directory-p directory))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1316 (error "%s is not a directory" directory)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1317 (save-excursion
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1318 (set-buffer buffer)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1319 (setq default-directory directory))))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1320
5088
73a1b31b673f (tex-send-command): Wait for output first,
Richard M. Stallman <rms@gnu.org>
parents: 5087
diff changeset
1321 (defvar tex-send-command-modified-tick 0)
73a1b31b673f (tex-send-command): Wait for output first,
Richard M. Stallman <rms@gnu.org>
parents: 5087
diff changeset
1322 (make-variable-buffer-local 'tex-send-command-modified-tick)
73a1b31b673f (tex-send-command): Wait for output first,
Richard M. Stallman <rms@gnu.org>
parents: 5087
diff changeset
1323
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1324 (defun tex-shell-proc ()
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1325 (or (get-process "tex-shell") (error "No TeX subprocess")))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1326 (defun tex-shell-buf ()
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1327 (process-buffer (tex-shell-proc)))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1328
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1329 (defun tex-send-command (command &optional file background)
5087
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1330 "Send COMMAND to TeX shell process, substituting optional FILE for *.
2588
b0a1846fe3b8 Doc fixes. Also a few teaks to pacify the byte-compiler.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2576
diff changeset
1331 Do this in background if optional BACKGROUND is t. If COMMAND has no *,
b0a1846fe3b8 Doc fixes. Also a few teaks to pacify the byte-compiler.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2576
diff changeset
1332 FILE will be appended, preceded by a blank, to COMMAND. If FILE is nil, no
b0a1846fe3b8 Doc fixes. Also a few teaks to pacify the byte-compiler.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2576
diff changeset
1333 substitution will be made in COMMAND. COMMAND can be any expression that
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1334 evaluates to a command string.
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1335
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1336 Return the process in which TeX is running."
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1337 (save-excursion
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1338 (let* ((cmd (eval command))
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1339 (proc (tex-shell-proc))
5262
b3a689b41d39 (tex-common-initialization): Make paragraph-start
Richard M. Stallman <rms@gnu.org>
parents: 5088
diff changeset
1340 (buf (process-buffer proc))
2265
daf268a98d5e * tex-mode.el (tex-send-command): Fix the command sent so that no
Jim Blandy <jimb@redhat.com>
parents: 1577
diff changeset
1341 (star (string-match "\\*" cmd))
5087
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1342 (string
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1343 (concat
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1344 (if file
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1345 (if star (concat (substring cmd 0 star)
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1346 file (substring cmd (1+ star)))
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1347 (concat cmd " " file))
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1348 cmd)
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1349 (if background "&" ""))))
5262
b3a689b41d39 (tex-common-initialization): Make paragraph-start
Richard M. Stallman <rms@gnu.org>
parents: 5088
diff changeset
1350 ;; Switch to buffer before checking for subproc output in it.
b3a689b41d39 (tex-common-initialization): Make paragraph-start
Richard M. Stallman <rms@gnu.org>
parents: 5088
diff changeset
1351 (set-buffer buf)
5088
73a1b31b673f (tex-send-command): Wait for output first,
Richard M. Stallman <rms@gnu.org>
parents: 5087
diff changeset
1352 ;; If text is unchanged since previous tex-send-command,
73a1b31b673f (tex-send-command): Wait for output first,
Richard M. Stallman <rms@gnu.org>
parents: 5087
diff changeset
1353 ;; we haven't got any output. So wait for output now.
5262
b3a689b41d39 (tex-common-initialization): Make paragraph-start
Richard M. Stallman <rms@gnu.org>
parents: 5088
diff changeset
1354 (if (= (buffer-modified-tick buf) tex-send-command-modified-tick)
5088
73a1b31b673f (tex-send-command): Wait for output first,
Richard M. Stallman <rms@gnu.org>
parents: 5087
diff changeset
1355 (accept-process-output proc))
5087
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1356 (goto-char (process-mark proc))
a7b2df620d1a (tex-start-shell): Don't use -v option.
Richard M. Stallman <rms@gnu.org>
parents: 4917
diff changeset
1357 (insert string)
5088
73a1b31b673f (tex-send-command): Wait for output first,
Richard M. Stallman <rms@gnu.org>
parents: 5087
diff changeset
1358 (comint-send-input)
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1359 (setq tex-send-command-modified-tick (buffer-modified-tick buf))
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1360 proc)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1361
6479
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1362 (defun tex-delete-last-temp-files (&optional not-all)
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1363 "Delete any junk files from last temp file.
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1364 If NOT-ALL is non-nil, save the `.dvi' file."
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1365 (if tex-last-temp-file
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1366 (let* ((dir (file-name-directory tex-last-temp-file))
7536
efecdee78026 (tex-delete-last-temp-files): Don't fail on non-existent directory.
Karl Heuer <kwzh@gnu.org>
parents: 7298
diff changeset
1367 (list (and (file-directory-p dir)
efecdee78026 (tex-delete-last-temp-files): Don't fail on non-existent directory.
Karl Heuer <kwzh@gnu.org>
parents: 7298
diff changeset
1368 (file-name-all-completions
22707
4fa39e6af756 (tex-delete-last-temp-files): Use file-name-sans-extensions.
Richard M. Stallman <rms@gnu.org>
parents: 22292
diff changeset
1369 (file-name-sans-extension
4fa39e6af756 (tex-delete-last-temp-files): Use file-name-sans-extensions.
Richard M. Stallman <rms@gnu.org>
parents: 22292
diff changeset
1370 (file-name-nondirectory tex-last-temp-file))
4fa39e6af756 (tex-delete-last-temp-files): Use file-name-sans-extensions.
Richard M. Stallman <rms@gnu.org>
parents: 22292
diff changeset
1371 dir))))
7536
efecdee78026 (tex-delete-last-temp-files): Don't fail on non-existent directory.
Karl Heuer <kwzh@gnu.org>
parents: 7298
diff changeset
1372 (while list
6479
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1373 (if not-all
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1374 (and
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1375 ;; If arg is non-nil, don't delete the .dvi file.
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1376 (not (string-match "\\.dvi$" (car list)))
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1377 (delete-file (concat dir (car list))))
855f4f2d24da (tex-delete-last-temp-files): New arg NOT-ALL.
Richard M. Stallman <rms@gnu.org>
parents: 5427
diff changeset
1378 (delete-file (concat dir (car list))))
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1379 (setq list (cdr list))))))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1380
741
587f7a98341d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 739
diff changeset
1381 (add-hook 'kill-emacs-hook 'tex-delete-last-temp-files)
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1382
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1383 (defun tex-guess-main-file (&optional all)
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1384 "Find a likely `tex-main-file'.
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1385 Looks for hints in other buffers in the same directory or in
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1386 ALL other buffers."
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1387 (let ((dir default-directory)
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1388 (header-re tex-start-of-header))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1389 (catch 'found
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1390 ;; Look for a buffer with `tex-main-file' set.
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1391 (dolist (buf (if (consp all) all (buffer-list)))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1392 (with-current-buffer buf
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1393 (when (and (or all (equal dir default-directory))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1394 (stringp tex-main-file))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1395 (throw 'found (expand-file-name tex-main-file)))))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1396 ;; Look for a buffer containing the magic `tex-start-of-header'.
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1397 (dolist (buf (if (consp all) all (buffer-list)))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1398 (with-current-buffer buf
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1399 (when (and (or all (equal dir default-directory))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1400 buffer-file-name
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1401 ;; (or (easy-mmode-derived-mode-p 'latex-mode)
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1402 ;; (easy-mmode-derived-mode-p 'plain-tex-mode))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1403 (save-excursion
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1404 (goto-char (point-min))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1405 (re-search-forward header-re 10000 t)))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1406 (throw 'found (expand-file-name buffer-file-name))))))))
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1407
34139
358adc86d127 (tex-start-shell): Obey shell-file-name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33789
diff changeset
1408 (defun tex-main-file ()
358adc86d127 (tex-start-shell): Obey shell-file-name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33789
diff changeset
1409 "Return the relative name of the main file."
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1410 (let* ((file (or tex-main-file
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1411 ;; Compatibility with AUCTeX.
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1412 (and (boundp 'TeX-master) (stringp TeX-master)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1413 (set (make-local-variable 'tex-main-file) TeX-master))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1414 ;; Try to guess the main file.
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1415 (if (not buffer-file-name)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1416 (error "Buffer is not associated with any file")
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1417 (file-relative-name
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1418 (if (save-excursion
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1419 (goto-char (point-min))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1420 (re-search-forward tex-start-of-header 10000 t))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1421 ;; This is the main file.
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1422 buffer-file-name
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1423 ;; This isn't the main file, let's try to find better,
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1424 (or (tex-guess-main-file)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1425 ;; (tex-guess-main-file t)
34139
358adc86d127 (tex-start-shell): Obey shell-file-name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33789
diff changeset
1426 buffer-file-name)))))))
358adc86d127 (tex-start-shell): Obey shell-file-name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33789
diff changeset
1427 (if (file-exists-p file) file (concat file ".tex"))))
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1428
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1429
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1430 (defun tex-start-tex (command file &optional dir)
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1431 "Start a TeX run, using COMMAND on FILE."
23322
26cc35857be5 (tex-run-command): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 23296
diff changeset
1432 (let* ((star (string-match "\\*" command))
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1433 (compile-command
23322
26cc35857be5 (tex-run-command): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 23296
diff changeset
1434 (if star
26cc35857be5 (tex-run-command): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 23296
diff changeset
1435 (concat (substring command 0 star)
26cc35857be5 (tex-run-command): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 23296
diff changeset
1436 (comint-quote-filename file)
26cc35857be5 (tex-run-command): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 23296
diff changeset
1437 (substring command (1+ star)))
26cc35857be5 (tex-run-command): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 23296
diff changeset
1438 (concat command " "
24330
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
1439 (if (< 0 (length tex-start-options-string))
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
1440 (concat
fee8d10bbb21 (tex-run-command, latex-run-command)
Richard M. Stallman <rms@gnu.org>
parents: 24273
diff changeset
1441 (shell-quote-argument tex-start-options-string) " "))
23322
26cc35857be5 (tex-run-command): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 23296
diff changeset
1442 (comint-quote-filename file)))))
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1443 (tex-send-tex-command compile-command dir)))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1444
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1445 (defun tex-send-tex-command (cmd &optional dir)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1446 (unless (or (equal dir (with-current-buffer (tex-shell-buf)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1447 default-directory))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1448 (not dir))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1449 (let (shell-dirtrack-verbose)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1450 (tex-send-command tex-shell-cd-command dir)))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1451 (with-current-buffer (process-buffer (tex-send-command cmd))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1452 (make-local-variable 'compilation-parse-errors-function)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1453 (setq compilation-parse-errors-function 'tex-compilation-parse-errors)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1454 (setq compilation-last-buffer (current-buffer))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1455 (compilation-forget-errors)
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1456 ;; Don't parse previous compilations.
33472
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1457 (set-marker compilation-parsing-end (1- (point-max))))
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1458 (tex-display-shell)
1de979dabe6f (tex-font-lock-keywords-1): Use `keep'
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33363
diff changeset
1459 (setq tex-last-buffer-texed (current-buffer)))
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1460
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1461 (defvar tex-error-parse-syntax-table
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1462 (let ((st (make-syntax-table)))
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1463 (modify-syntax-entry ?\( "()" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1464 (modify-syntax-entry ?\) ")(" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1465 (modify-syntax-entry ?\\ "\\" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1466 (modify-syntax-entry ?\{ "_" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1467 (modify-syntax-entry ?\} "_" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1468 (modify-syntax-entry ?\[ "_" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1469 (modify-syntax-entry ?\] "_" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1470 ;; Single quotations may appear in errors
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1471 (modify-syntax-entry ?\" "_" st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1472 st)
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1473 "Syntax-table used while parsing TeX error messages.")
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1474
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1475 (defun tex-compilation-parse-errors (limit-search find-at-least)
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1476 "Parse the current buffer as TeX error messages.
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1477 See the variable `compilation-parse-errors-function' for the interface it uses.
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1478
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1479 This function parses only the last TeX compilation.
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1480 It works on TeX compilations only. It is necessary for that purpose,
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1481 since TeX does not put file names and line numbers on the same line as
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1482 for the error messages."
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1483 (require 'thingatpt)
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1484 (setq compilation-error-list nil)
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1485 (message "Parsing error messages...")
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1486 (let ((default-directory ; Perhaps dir has changed meanwhile.
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1487 (file-name-directory (buffer-file-name tex-last-buffer-texed)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1488 found-desired (num-errors-found 0)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1489 last-filename last-linenum last-position
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1490 begin-of-error end-of-error)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1491 ;; Don't reparse messages already seen at last parse.
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1492 (goto-char compilation-parsing-end)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1493 ;; Parse messages.
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1494 (while (and (not (or found-desired (eobp)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1495 (prog1 (re-search-forward "^! " nil 'move)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1496 (setq begin-of-error (match-beginning 0)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1497 end-of-error (match-end 0)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1498 (re-search-forward
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1499 "^l\\.\\([0-9]+\\) \\(\\.\\.\\.\\)?\\(.*\\)$" nil 'move))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1500 (let* ((this-error (set-marker (make-marker) begin-of-error))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1501 (linenum (string-to-int (match-string 1)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1502 (error-text (regexp-quote (match-string 3)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1503 (filename
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1504 (save-excursion
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1505 (with-syntax-table tex-error-parse-syntax-table
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1506 (backward-up-list 1)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1507 (skip-syntax-forward "(_")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1508 (while (not (file-readable-p (thing-at-point 'filename)))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1509 (skip-syntax-backward "(_")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1510 (backward-up-list 1)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1511 (skip-syntax-forward "(_"))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1512 (thing-at-point 'filename))))
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1513 (new-file
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1514 (or (null last-filename)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1515 (not (string-equal last-filename filename))))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1516 (error-location
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1517 (save-excursion
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1518 (if (equal filename (concat tex-zap-file ".tex"))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1519 (set-buffer tex-last-buffer-texed)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1520 (set-buffer (find-file-noselect filename)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1521 (if new-file
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1522 (progn (goto-line linenum) (setq last-position nil))
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1523 (goto-char last-position)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1524 (forward-line (- linenum last-linenum)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1525 ;; first try a forward search for the error text,
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1526 ;; then a backward search limited by the last error.
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1527 (let ((starting-point (point)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1528 (or (re-search-forward error-text nil t)
33789
3cb3c23bbe84 (tex-font-lock-keywords-1): Fix ARG regexp to skip quoted braces.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33477
diff changeset
1529 (re-search-backward error-text last-position t)
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1530 (goto-char starting-point)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1531 (point-marker))))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1532 (goto-char this-error)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1533 (if (and compilation-error-list
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1534 (or (and find-at-least
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1535 (>= num-errors-found
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1536 find-at-least))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1537 (and limit-search
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1538 (>= end-of-error limit-search)))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1539 new-file)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1540 (setq found-desired t)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1541 (setq num-errors-found (1+ num-errors-found)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1542 last-filename filename
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1543 last-linenum linenum
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1544 last-position error-location
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1545 compilation-error-list ; Add the new error
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1546 (cons (cons this-error error-location)
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1547 compilation-error-list))
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1548 (goto-char end-of-error)))))
25414
7c4808c6804b (tex-compilation-parse-errors):
Richard M. Stallman <rms@gnu.org>
parents: 24527
diff changeset
1549 (set-marker compilation-parsing-end (point))
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1550 (setq compilation-error-list (nreverse compilation-error-list))
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1551 (message "Parsing error messages...done"))
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1552
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1553 ;;; The commands:
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1554
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1555 (defun tex-region (beg end)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1556 "Run TeX on the current region, via a temporary file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1557 The file's name comes from the variable `tex-zap-file' and the
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1558 variable `tex-directory' says where to put it.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1559
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1560 If the buffer has a header, the header is given to TeX before the
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1561 region itself. The buffer's header is all lines between the strings
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1562 defined by `tex-start-of-header' and `tex-end-of-header' inclusive.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1563 The header must start in the first 100 lines of the buffer.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1564
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1565 The value of `tex-trailer' is given to TeX as input after the region.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1566
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1567 The value of `tex-command' specifies the command to use to run TeX."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1568 (interactive "r")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1569 (if (tex-shell-running)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1570 (tex-kill-job)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1571 (tex-start-shell))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1572 (or tex-zap-file
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1573 (setq tex-zap-file (tex-generate-zap-file-name)))
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1574 ;; Temp file will be written and TeX will be run in zap-directory.
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1575 ;; If the TEXINPUTS file has relative directories or if the region has
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1576 ;; \input of files, this must be the same directory as the file for
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1577 ;; TeX to access the correct inputs. That's why it's safest if
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1578 ;; tex-directory is ".".
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1579 (let* ((zap-directory
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1580 (file-name-as-directory (expand-file-name tex-directory)))
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1581 (tex-out-file (expand-file-name (concat tex-zap-file ".tex")
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1582 zap-directory)))
9450
af39d29d1386 (compare-windows-whitespace): Eliminate initial value.
Richard M. Stallman <rms@gnu.org>
parents: 8890
diff changeset
1583 ;; Don't delete temp files if we do the same buffer twice in a row.
af39d29d1386 (compare-windows-whitespace): Eliminate initial value.
Richard M. Stallman <rms@gnu.org>
parents: 8890
diff changeset
1584 (or (eq (current-buffer) tex-last-buffer-texed)
af39d29d1386 (compare-windows-whitespace): Eliminate initial value.
Richard M. Stallman <rms@gnu.org>
parents: 8890
diff changeset
1585 (tex-delete-last-temp-files t))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1586 ;; Write the new temp file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1587 (save-excursion
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1588 (save-restriction
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1589 (widen)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1590 (goto-char (point-min))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1591 (forward-line 100)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1592 (let ((search-end (point))
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1593 (default-directory zap-directory)
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1594 (already-output 0))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1595 (goto-char (point-min))
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1596
16777
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
1597 ;; Maybe copy first line, such as `\input texinfo', to temp file.
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
1598 (and tex-first-line-header-regexp
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
1599 (looking-at tex-first-line-header-regexp)
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1600 (write-region (point)
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1601 (progn (forward-line 1)
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1602 (setq already-output (point)))
16777
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
1603 tex-out-file nil nil))
b655268ba44f (tex-first-line-header-regexp): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16493
diff changeset
1604
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1605 ;; Write out the header, if there is one,
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1606 ;; and any of the specified region which extends before it.
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1607 ;; But don't repeat anything already written.
13248
a7e83f7eb499 (tex-start-of-header): Now a regexp.
Richard M. Stallman <rms@gnu.org>
parents: 12704
diff changeset
1608 (if (re-search-forward tex-start-of-header search-end t)
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1609 (let (hbeg)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1610 (beginning-of-line)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1611 (setq hbeg (point)) ;mark beginning of header
13248
a7e83f7eb499 (tex-start-of-header): Now a regexp.
Richard M. Stallman <rms@gnu.org>
parents: 12704
diff changeset
1612 (if (re-search-forward tex-end-of-header nil t)
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1613 (let (hend)
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1614 (forward-line 1)
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1615 (setq hend (point)) ;mark end of header
16807
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1616 (write-region (max (min hbeg beg) already-output)
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1617 hend
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1618 tex-out-file
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1619 (not (zerop already-output)) nil)
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1620 (setq already-output hend)))))
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1621
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1622 ;; Write out the specified region
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1623 ;; (but don't repeat anything already written).
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1624 (write-region (max beg already-output) end
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1625 tex-out-file
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1626 (not (zerop already-output)) nil))
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1627 ;; Write the trailer, if any.
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1628 ;; Precede it with a newline to make sure it
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1629 ;; is not hidden in a comment.
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1630 (if tex-trailer
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1631 (write-region (concat "\n" tex-trailer) nil
f8d567e52662 (tex-region): Correctly handle possible
Richard M. Stallman <rms@gnu.org>
parents: 16777
diff changeset
1632 tex-out-file t nil))))
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1633 ;; Record the file name to be deleted afterward.
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1634 (setq tex-last-temp-file tex-out-file)
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1635 ;; Use a relative file name here because (1) the proper dir
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1636 ;; is already current, and (2) the abs file name is sometimes
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1637 ;; too long and can make tex crash.
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1638 (tex-start-tex tex-command (concat tex-zap-file ".tex") zap-directory)
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1639 (setq tex-print-file tex-out-file)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1640
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1641 (defun tex-buffer ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1642 "Run TeX on current buffer. See \\[tex-region] for more information.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1643 Does not save the buffer, so it's useful for trying experimental versions.
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1644 See \\[tex-file] for an alternative."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1645 (interactive)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1646 (tex-region (point-min) (point-max)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1647
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1648 (defun tex-file ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1649 "Prompt to save all buffers and run TeX (or LaTeX) on current buffer's file.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1650 This function is more useful than \\[tex-buffer] when you need the
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1651 `.aux' file of LaTeX to have the correct name."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1652 (interactive)
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1653 (let* ((source-file (tex-main-file))
34139
358adc86d127 (tex-start-shell): Obey shell-file-name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33789
diff changeset
1654 (file-dir (file-name-directory (expand-file-name source-file))))
758
f8688580137c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 741
diff changeset
1655 (if tex-offer-save
741
587f7a98341d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 739
diff changeset
1656 (save-some-buffers))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1657 (if (tex-shell-running)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1658 (tex-kill-job)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1659 (tex-start-shell))
31968
dc896c1b6a26 (latex-imenu-indent-string): Add a space.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 30888
diff changeset
1660 (tex-start-tex tex-command source-file file-dir)
24129
18c751deec0d (tex-define-common-keys): Remove key binding of tex-feed-input.
Richard M. Stallman <rms@gnu.org>
parents: 24109
diff changeset
1661 (setq tex-print-file (expand-file-name source-file))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1662
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1663 (defun tex-generate-zap-file-name ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1664 "Generate a unique name suitable for use as a file name."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1665 ;; Include the shell process number and host name
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1666 ;; in case there are multiple shells (for same or different user).
23849
1f014e9d0768 (tex-generate-zap-file-name): Don't start the name with #.
Karl Heuer <kwzh@gnu.org>
parents: 23761
diff changeset
1667 ;; Dec 1998: There is a report that some versions of xdvi
1f014e9d0768 (tex-generate-zap-file-name): Don't start the name with #.
Karl Heuer <kwzh@gnu.org>
parents: 23761
diff changeset
1668 ;; don't work with file names that start with #.
24109
e1e1bb544d84 (latex-run-command): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 23849
diff changeset
1669 (format "_TZ_%d-%s"
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1670 (process-id (get-buffer-process "*tex-shell*"))
34139
358adc86d127 (tex-start-shell): Obey shell-file-name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33789
diff changeset
1671 (subst-char-in-string ?. ?- (system-name))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1672
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1673 ;; This will perhaps be useful for modifying TEXINPUTS.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1674 ;; Expand each file name, separated by colons, in the string S.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1675 (defun tex-expand-files (s)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1676 (let (elts (start 0))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1677 (while (string-match ":" s start)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1678 (setq elts (cons (substring s start (match-beginning 0)) elts))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1679 (setq start (match-end 0)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1680 (or (= start 0)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1681 (setq elts (cons (substring s start) elts)))
30888
e559f0aa6b2d Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 26270
diff changeset
1682 (mapconcat (lambda (elt)
e559f0aa6b2d Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 26270
diff changeset
1683 (if (= (length elt) 0) elt (expand-file-name elt)))
24109
e1e1bb544d84 (latex-run-command): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 23849
diff changeset
1684 (nreverse elts) ":")))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1685
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1686 (defun tex-shell-running ()
36105
595ee2f062cf tex-shell-running: Check the process buffer too
Sam Steingold <sds@gnu.org>
parents: 34139
diff changeset
1687 (let ((proc (get-process "tex-shell")))
595ee2f062cf tex-shell-running: Check the process buffer too
Sam Steingold <sds@gnu.org>
parents: 34139
diff changeset
1688 (and proc
595ee2f062cf tex-shell-running: Check the process buffer too
Sam Steingold <sds@gnu.org>
parents: 34139
diff changeset
1689 (eq (process-status (get-process "tex-shell")) 'run)
595ee2f062cf tex-shell-running: Check the process buffer too
Sam Steingold <sds@gnu.org>
parents: 34139
diff changeset
1690 (buffer-live-p (process-buffer proc)))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1691
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1692 (defun tex-kill-job ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1693 "Kill the currently running TeX job."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1694 (interactive)
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1695 ;; quit-process leads to core dumps of the tex process (except if
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1696 ;; coredumpsize has limit 0kb as on many environments). One would
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1697 ;; like to use (kill-process proc 'lambda), however that construct
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1698 ;; does not work on some systems and kills the shell itself.
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1699 (quit-process (get-process "tex-shell") t))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1700
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1701 (defun tex-recenter-output-buffer (linenum)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1702 "Redisplay buffer of TeX job output so that most recent output can be seen.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1703 The last line of the buffer is displayed on
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1704 line LINE of the window, or centered if LINE is nil."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1705 (interactive "P")
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1706 (let ((tex-shell (get-buffer "*tex-shell*"))
16493
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1707 (old-buffer (current-buffer))
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1708 (window))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1709 (if (null tex-shell)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1710 (message "No TeX output buffer")
16493
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1711 (setq window (display-buffer tex-shell))
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1712 (save-selected-window
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1713 (select-window window)
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1714 (bury-buffer tex-shell)
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1715 (goto-char (point-max))
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1716 (recenter (if linenum
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1717 (prefix-numeric-value linenum)
bdca7f3626c0 (tex-file): Fix paren error in last change.
Richard M. Stallman <rms@gnu.org>
parents: 16356
diff changeset
1718 (/ (window-height) 2)))))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1719
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1720 (defun tex-print (&optional alt)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1721 "Print the .dvi file made by \\[tex-region], \\[tex-buffer] or \\[tex-file].
1577
a52da8d63ff3 Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 957
diff changeset
1722 Runs the shell command defined by `tex-dvi-print-command'. If prefix argument
a52da8d63ff3 Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 957
diff changeset
1723 is provided, use the alternative command, `tex-alt-dvi-print-command'."
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1724 (interactive "P")
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1725 (let ((print-file-name-dvi (tex-append tex-print-file ".dvi"))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1726 test-name)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1727 (if (and (not (equal (current-buffer) tex-last-buffer-texed))
10341
f27bcd1faf07 (tex-print): Better check for when to print current
Richard M. Stallman <rms@gnu.org>
parents: 10325
diff changeset
1728 (buffer-file-name)
f27bcd1faf07 (tex-print): Better check for when to print current
Richard M. Stallman <rms@gnu.org>
parents: 10325
diff changeset
1729 ;; Check that this buffer's printed file is up to date.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1730 (file-newer-than-file-p
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1731 (setq test-name (tex-append (buffer-file-name) ".dvi"))
10341
f27bcd1faf07 (tex-print): Better check for when to print current
Richard M. Stallman <rms@gnu.org>
parents: 10325
diff changeset
1732 (buffer-file-name)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1733 (setq print-file-name-dvi test-name))
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1734 (if (not (file-exists-p print-file-name-dvi))
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1735 (error "No appropriate `.dvi' file could be found")
21314
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1736 (if (tex-shell-running)
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1737 (tex-kill-job)
7d4a55d38b2c (tex-send-command): Return the process.
Richard M. Stallman <rms@gnu.org>
parents: 21121
diff changeset
1738 (tex-start-shell))
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1739 (tex-send-command
24273
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1740 (if alt tex-alt-dvi-print-command tex-dvi-print-command)
803ec3bfa983 When compiling, require compare-w and skeleton
Richard M. Stallman <rms@gnu.org>
parents: 24222
diff changeset
1741 print-file-name-dvi t))))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1742
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1743 (defun tex-alt-print ()
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1744 "Print the .dvi file made by \\[tex-region], \\[tex-buffer] or \\[tex-file].
10296
c58e6bb97038 (tex-mode-map): Add BibTeX File menu item.
Richard M. Stallman <rms@gnu.org>
parents: 10215
diff changeset
1745 Runs the shell command defined by `tex-alt-dvi-print-command'."
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1746 (interactive)
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1747 (tex-print t))
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1748
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1749 (defun tex-view ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1750 "Preview the last `.dvi' file made by running TeX under Emacs.
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1751 This means, made using \\[tex-region], \\[tex-buffer] or \\[tex-file].
11617
9eaeed5c8a40 (tex-view): Nice error if tex-dvi-view-command is nil.
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
1752 The variable `tex-dvi-view-command' specifies the shell command for preview.
9eaeed5c8a40 (tex-view): Nice error if tex-dvi-view-command is nil.
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
1753 You must set that variable yourself before using this command,
9eaeed5c8a40 (tex-view): Nice error if tex-dvi-view-command is nil.
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
1754 because there is no standard value that would generally work."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1755 (interactive)
11617
9eaeed5c8a40 (tex-view): Nice error if tex-dvi-view-command is nil.
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
1756 (or tex-dvi-view-command
9eaeed5c8a40 (tex-view): Nice error if tex-dvi-view-command is nil.
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
1757 (error "You must set `tex-dvi-view-command'"))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1758 (let ((tex-dvi-print-command tex-dvi-view-command))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1759 (tex-print)))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1760
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1761 (defun tex-append (file-name suffix)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1762 "Append to FILENAME the suffix SUFFIX, using same algorithm TeX uses.
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1763 Pascal-based TeX scans for the first period, C TeX uses the last.
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1764 No period is retained immediately before SUFFIX,
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1765 so normally SUFFIX starts with one."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1766 (if (stringp file-name)
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1767 (let ((file (file-name-nondirectory file-name))
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1768 trial-name)
14383
af281a43a3bb (tex-face-alist, tex-latex-face-alist): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 13399
diff changeset
1769 ;; Try splitting on last period.
10778
ace814499178 (tex-append): Try splitting on last period, then
Richard M. Stallman <rms@gnu.org>
parents: 10572
diff changeset
1770 ;; The first-period split can get fooled when two files
ace814499178 (tex-append): Try splitting on last period, then
Richard M. Stallman <rms@gnu.org>
parents: 10572
diff changeset
1771 ;; named a.tex and a.b.tex are both tex'd;
ace814499178 (tex-append): Try splitting on last period, then
Richard M. Stallman <rms@gnu.org>
parents: 10572
diff changeset
1772 ;; the last-period split must be right if it matches at all.
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1773 (setq trial-name
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1774 (concat (file-name-directory file-name)
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1775 (substring file 0
10778
ace814499178 (tex-append): Try splitting on last period, then
Richard M. Stallman <rms@gnu.org>
parents: 10572
diff changeset
1776 (string-match "\\.[^.]*$" file))
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1777 suffix))
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1778 (if (or (file-exists-p trial-name)
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1779 (file-exists-p (concat trial-name ".aux"))) ;for BibTeX files
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1780 trial-name
10778
ace814499178 (tex-append): Try splitting on last period, then
Richard M. Stallman <rms@gnu.org>
parents: 10572
diff changeset
1781 ;; Not found, so split on first period.
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1782 (concat (file-name-directory file-name)
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1783 (substring file 0
10778
ace814499178 (tex-append): Try splitting on last period, then
Richard M. Stallman <rms@gnu.org>
parents: 10572
diff changeset
1784 (string-match "\\." file))
4917
550746214170 (tex-alt-print): New function for menu bar.
Richard M. Stallman <rms@gnu.org>
parents: 4908
diff changeset
1785 suffix)))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1786 " "))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1787
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1788 (defun tex-show-print-queue ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1789 "Show the print queue that \\[tex-print] put your job on.
1577
a52da8d63ff3 Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 957
diff changeset
1790 Runs the shell command defined by `tex-show-queue-command'."
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1791 (interactive)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1792 (if (tex-shell-running)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1793 (tex-kill-job)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1794 (tex-start-shell))
10572
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1795 (tex-send-command tex-show-queue-command)
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1796 (tex-display-shell))
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1797
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1798 (defun tex-bibtex-file ()
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1799 "Run BibTeX on the current buffer's file."
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1800 (interactive)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1801 (if (tex-shell-running)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1802 (tex-kill-job)
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1803 (tex-start-shell))
24222
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1804 (let (shell-dirtrack-verbose
8b2cecc76fe3 (tex-mode-map): Replace validate-tex-buffer by
Markus Rost <rost@math.uni-bielefeld.de>
parents: 24173
diff changeset
1805 (tex-out-file
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1806 (tex-append (file-name-nondirectory (buffer-file-name)) ""))
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1807 (file-dir (file-name-directory (buffer-file-name))))
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1808 (tex-send-command tex-shell-cd-command file-dir)
10572
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1809 (tex-send-command tex-bibtex-command tex-out-file))
c8717227f621 (tex-display-shell): Pass nil as arg to
Richard M. Stallman <rms@gnu.org>
parents: 10341
diff changeset
1810 (tex-display-shell))
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1811
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1812 ;;;;
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1813 ;;;; LaTeX indentation
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1814 ;;;;
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1815
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1816 (defvar tex-indent-allhanging t)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1817 (defvar tex-indent-arg 4)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1818 (defvar tex-indent-basic 2)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1819 (defvar tex-indent-item tex-indent-basic)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1820 (defvar tex-indent-item-re "\\\\\\(bib\\)?item\\>")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1821
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1822 (easy-mmode-defsyntax tex-latex-indent-syntax-table
33363
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1823 '((?$ . ".")
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1824 (?\( . ".")
1a5b4e0146bc (standard-latex-block-names): Add "math".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33113
diff changeset
1825 (?\) . "."))
32479
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1826 "Syntax table used while computing indentation."
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1827 :copy tex-mode-syntax-table)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1828
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1829 (defun latex-indent (&optional arg)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1830 (with-syntax-table tex-latex-indent-syntax-table
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1831 ;; TODO: Rather than ignore $, we should try to be more clever about it.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1832 (let ((indent
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1833 (save-excursion
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1834 (beginning-of-line)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1835 (latex-find-indent))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1836 (if (< indent 0) (setq indent 0))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1837 (if (<= (current-column) (current-indentation))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1838 (indent-line-to indent)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1839 (save-excursion (indent-line-to indent))))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1840
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1841 (defun latex-find-indent (&optional virtual)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1842 "Find the proper indentation of text after point.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1843 VIRTUAL if non-nil indicates that we're only trying to find the indentation
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1844 in order to determine the indentation of something else.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1845 There might be text before point."
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1846 (save-excursion
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1847 (skip-chars-forward " \t")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1848 (or
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1849 ;; Trust the current indentation, if such info is applicable.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1850 (and virtual (>= (current-indentation) (current-column))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1851 (current-indentation))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1852 ;; Put leading close-paren where the matching open brace would be.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1853 (and (eq (latex-syntax-after) ?\))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1854 (ignore-errors
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1855 (save-excursion
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1856 (latex-skip-close-parens)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1857 (latex-backward-sexp-1)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1858 (latex-find-indent 'virtual))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1859 ;; Default (maybe an argument)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1860 (let ((pos (point))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1861 (char (char-after))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1862 ;; Outdent \item if necessary.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1863 (indent (if (looking-at tex-indent-item-re) (- tex-indent-item) 0))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1864 up-list-pos)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1865 ;; Find the previous point which determines our current indentation.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1866 (condition-case err
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1867 (progn
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1868 (latex-backward-sexp-1)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1869 (while (> (current-column) (current-indentation))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1870 (latex-backward-sexp-1)))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1871 (scan-error
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1872 (setq up-list-pos (nth 2 err))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1873 (if (integerp up-list-pos)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1874 ;; Have to indent relative to the open-paren.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1875 (progn
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1876 (goto-char up-list-pos)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1877 (if (and (not tex-indent-allhanging)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1878 (> pos (progn (latex-down-list)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1879 (forward-comment (point-max))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1880 (point))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1881 ;; Align with the first element after the open-paren.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1882 (current-column)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1883 ;; We're the first element after a hanging brace.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1884 (goto-char up-list-pos)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1885 (+ indent tex-indent-basic (latex-find-indent 'virtual))))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1886 ;; We're now at the beginning of a line.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1887 (if (not (and (not virtual) (eq (char-after) ?\\)))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1888 ;; Nothing particular here: just keep the same indentation.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1889 (+ indent (current-column))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1890 ;; We're now looking at a macro call.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1891 (if (looking-at tex-indent-item-re)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1892 ;; Indenting relative to an item, have to re-add the outdenting.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1893 (+ indent (current-column) tex-indent-item)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1894 (let ((col (current-column)))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1895 (if (not (eq (char-syntax char) ?\())
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1896 ;; If the first char was not an open-paren, there's
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1897 ;; a risk that this is really not an argument to the
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1898 ;; macro at all.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1899 (+ indent col)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1900 (forward-sexp 1)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1901 (if (< (line-end-position)
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1902 (save-excursion (forward-comment (point-max))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1903 (point)))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1904 ;; we're indenting the first argument.
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1905 (min (current-column) (+ tex-indent-arg col))
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1906 (skip-syntax-forward " ")
783ed0889617 Require CL when compiling.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32045
diff changeset
1907 (current-column)))))))))))
739
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1908
0bb85f26b79c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 657
diff changeset
1909 (run-hooks 'tex-mode-load-hook)
85
253ec6b277ee Initial revision
root <root>
parents:
diff changeset
1910
584
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 269
diff changeset
1911 (provide 'tex-mode)
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 269
diff changeset
1912
657
fec3f9a1e3e5 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
1913 ;;; tex-mode.el ends here