Mercurial > emacs
annotate lisp/textmodes/bibtex.el @ 76811:72a276765477
(c-forward-to-nth-EOF-}): Fix EOB bug.
author | Alan Mackenzie <acm@muc.de> |
---|---|
date | Fri, 30 Mar 2007 20:20:35 +0000 |
parents | 2600e61a031f |
children | 389303f02afc 95d0cdf160ea |
rev | line source |
---|---|
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
584
diff
changeset
|
1 ;;; bibtex.el --- BibTeX mode for GNU Emacs |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
584
diff
changeset
|
2 |
74509 | 3 ;; Copyright (C) 1992, 1994, 1995, 1996, 1997, 1998, 1999, 2001, 2002, |
75347 | 4 ;; 2003, 2004, 2005, 2006, 2007 Free Software Foundation, Inc. |
845 | 5 |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
6 ;; Author: Stefan Schoef <schoef@offis.uni-oldenburg.de> |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
7 ;; Bengt Martensson <bengt@mathematik.uni-Bremen.de> |
73792
9429d986b2d1
Fix typo in name of author of bibtex.el,
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
71044
diff
changeset
|
8 ;; Marc Shapiro <marc.shapiro@acm.org> |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
9 ;; Mike Newton <newton@gumby.cs.caltech.edu> |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
10 ;; Aaron Larson <alarson@src.honeywell.com> |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
11 ;; Dirk Herrmann <D.Herrmann@tu-bs.de> |
45849 | 12 ;; Maintainer: Roland Winkler <roland.winkler@physik.uni-erlangen.de> |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
13 ;; Keywords: BibTeX, LaTeX, TeX |
810
80303373daae
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
807
diff
changeset
|
14 |
257 | 15 ;; This file is part of GNU Emacs. |
16 | |
17 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
18 ;; it under the terms of the GNU General Public License as published by | |
1851 | 19 ;; the Free Software Foundation; either version 2, or (at your option) |
257 | 20 ;; any later version. |
21 | |
22 ;; GNU Emacs is distributed in the hope that it will be useful, | |
23 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
24 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
25 ;; GNU General Public License for more details. | |
26 | |
27 ;; You should have received a copy of the GNU General Public License | |
14169 | 28 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
64084 | 29 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
30 ;; Boston, MA 02110-1301, USA. | |
257 | 31 |
12700
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
32 ;;; Commentary: |
14169 | 33 |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
34 ;; Major mode for editing and validating BibTeX files. |
257 | 35 |
12700
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
36 ;; Usage: |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
37 ;; See documentation for function bibtex-mode or type "\M-x describe-mode" |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
38 ;; when you are in BibTeX mode. |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
39 |
12700
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
40 ;; Todo: |
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
41 ;; Distribute texinfo file. |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
42 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
43 ;;; Code: |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
44 |
57815 | 45 (require 'button) |
46 | |
26711
eac840d283b6
(bibtex-hs-forward-sexp): Added to support
Gerd Moellmann <gerd@gnu.org>
parents:
25444
diff
changeset
|
47 |
12700
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
48 ;; User Options: |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
49 |
19460 | 50 (defgroup bibtex nil |
64054
23a07b9b6687
(bibtex, bibtex-autokey): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents:
63470
diff
changeset
|
51 "BibTeX mode." |
19460 | 52 :group 'tex |
53 :prefix "bibtex-") | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
54 |
19460 | 55 (defgroup bibtex-autokey nil |
64054
23a07b9b6687
(bibtex, bibtex-autokey): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents:
63470
diff
changeset
|
56 "Generate automatically a key from the author/editor and the title field." |
19460 | 57 :group 'bibtex |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
58 :prefix "bibtex-autokey-") |
19460 | 59 |
60 (defcustom bibtex-mode-hook nil | |
61 "List of functions to call on entry to BibTeX mode." | |
62 :group 'bibtex | |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
63 :type 'hook) |
19460 | 64 |
65 (defcustom bibtex-field-delimiters 'braces | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
66 "Type of field delimiters. Allowed values are `braces' or `double-quotes'." |
19460 | 67 :group 'bibtex |
68 :type '(choice (const braces) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
69 (const double-quotes))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
70 |
19460 | 71 (defcustom bibtex-entry-delimiters 'braces |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
72 "Type of entry delimiters. Allowed values are `braces' or `parentheses'." |
19460 | 73 :group 'bibtex |
74 :type '(choice (const braces) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
75 (const parentheses))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
76 |
19460 | 77 (defcustom bibtex-include-OPTcrossref '("InProceedings" "InCollection") |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
78 "List of BibTeX entries that get an OPTcrossref field." |
19460 | 79 :group 'bibtex |
80 :type '(repeat string)) | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
81 |
19460 | 82 (defcustom bibtex-include-OPTkey t |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
83 "If non-nil, all newly created entries get an OPTkey field. |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
84 If this is a string, use it as the initial field text. |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
85 If this is a function, call it to generate the initial field text." |
19460 | 86 :group 'bibtex |
87 :type '(choice (const :tag "None" nil) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
88 (string :tag "Initial text") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
89 (function :tag "Initialize Function" :value fun) |
70808
0c087a8f2e1c
(bibtex-maintain-sorted-entries): Mark as safe.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70250
diff
changeset
|
90 (const :tag "Default" t))) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
91 (put 'bibtex-include-OPTkey 'risky-local-variable t) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
92 |
19460 | 93 (defcustom bibtex-user-optional-fields |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
94 '(("annote" "Personal annotation (ignored)")) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
95 "List of optional fields the user wants to have always present. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
96 Entries should be of the same form as the OPTIONAL and |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
97 CROSSREF-OPTIONAL lists in `bibtex-entry-field-alist' (which see)." |
19460 | 98 :group 'bibtex |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
99 :type '(repeat (group (string :tag "Field") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
100 (string :tag "Comment") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
101 (option (group :inline t |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
102 :extra-offset -4 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
103 (choice :tag "Init" :value "" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
104 string |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
105 function)))))) |
70249
eb2b6bd1c6f0
(bibtex-user-optional-fields): Mark as risky.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70210
diff
changeset
|
106 (put 'bibtex-user-optional-fields 'risky-local-variable t) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
107 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
108 (defcustom bibtex-entry-format |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
109 '(opts-or-alts required-fields numerical-fields) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
110 "Type of formatting performed by `bibtex-clean-entry'. |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
111 It may be t, nil, or a list of symbols out of the following: |
19461 | 112 opts-or-alts Delete empty optional and alternative fields and |
113 remove OPT and ALT prefixes from used fields. | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
114 required-fields Signal an error if a required field is missing. |
19461 | 115 numerical-fields Delete delimiters around numeral fields. |
116 page-dashes Change double dashes in page field to single dash | |
117 (for scribe compatibility). | |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
118 inherit-booktitle If entry contains a crossref field and the booktitle |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
119 field is empty, set the booktitle field to the content |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
120 of the title field of the crossreferenced entry. |
19461 | 121 realign Realign entries, so that field texts and perhaps equal |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
122 signs (depending on the value of |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
123 `bibtex-align-at-equal-sign') begin in the same column. |
19461 | 124 last-comma Add or delete comma on end of last field in entry, |
125 according to value of `bibtex-comma-after-last-field'. | |
126 delimiters Change delimiters according to variables | |
127 `bibtex-field-delimiters' and `bibtex-entry-delimiters'. | |
128 unify-case Change case of entry and field names. | |
129 | |
130 The value t means do all of the above formatting actions. | |
131 The value nil means do no formatting at all." | |
19460 | 132 :group 'bibtex |
133 :type '(choice (const :tag "None" nil) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
134 (const :tag "All" t) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
135 (set :menu-tag "Some" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
136 (const opts-or-alts) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
137 (const required-fields) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
138 (const numerical-fields) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
139 (const page-dashes) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
140 (const inherit-booktitle) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
141 (const realign) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
142 (const last-comma) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
143 (const delimiters) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
144 (const unify-case)))) |
257 | 145 |
19460 | 146 (defcustom bibtex-clean-entry-hook nil |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
147 "List of functions to call when entry has been cleaned. |
19461 | 148 Functions are called with point inside the cleaned entry, and the buffer |
19460 | 149 narrowed to just the entry." |
150 :group 'bibtex | |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
151 :type 'hook) |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
152 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
153 (defcustom bibtex-maintain-sorted-entries nil |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
154 "If non-nil, BibTeX mode maintains all entries in sorted order. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
155 Allowed non-nil values are: |
70808
0c087a8f2e1c
(bibtex-maintain-sorted-entries): Mark as safe.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70250
diff
changeset
|
156 plain or t All entries are sorted alphabetically. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
157 crossref All entries are sorted alphabetically unless an entry has a |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
158 crossref field. These crossrefed entries are placed in |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
159 alphabetical order immediately preceding the main entry. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
160 entry-class The entries are divided into classes according to their |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
161 entry name, see `bibtex-sort-entry-class'. Within each class |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
162 the entries are sorted alphabetically. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
163 See also `bibtex-sort-ignore-string-entries'." |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
164 :group 'bibtex |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
165 :type '(choice (const nil) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
166 (const plain) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
167 (const crossref) |
70808
0c087a8f2e1c
(bibtex-maintain-sorted-entries): Mark as safe.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70250
diff
changeset
|
168 (const entry-class) |
0c087a8f2e1c
(bibtex-maintain-sorted-entries): Mark as safe.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70250
diff
changeset
|
169 (const t))) |
0c087a8f2e1c
(bibtex-maintain-sorted-entries): Mark as safe.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70250
diff
changeset
|
170 (put 'bibtex-maintain-sorted-entries 'safe-local-variable |
70837
c60679e723c7
(bibtex-maintain-sorted-entries): Quote safe-local-variable predicate.
Reiner Steib <Reiner.Steib@gmx.de>
parents:
70808
diff
changeset
|
171 '(lambda (a) (memq a '(nil t plain crossref entry-class)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
172 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
173 (defcustom bibtex-sort-entry-class |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
174 '(("String") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
175 (catch-all) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
176 ("Book" "Proceedings")) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
177 "List of classes of BibTeX entry names, used for sorting entries. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
178 If value of `bibtex-maintain-sorted-entries' is `entry-class' |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
179 entries are ordered according to the classes they belong to. Each |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
180 class contains a list of entry names. An entry `catch-all' applies |
59733
96d73eb02751
(bibtex-format-entry): Use `bibtex-empty-field-re' only on the text of
Lute Kamstra <lute@gnu.org>
parents:
58772
diff
changeset
|
181 to all entries not explicitly mentioned." |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
182 :group 'BibTeX |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
183 :type '(repeat (choice :tag "Class" |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
184 (const :tag "catch-all" (catch-all)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
185 (repeat :tag "Entry name" string)))) |
71044
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
186 (put 'bibtex-sort-entry-class 'safe-local-variable |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
187 (lambda (x) (let ((OK t)) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
188 (while (consp x) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
189 (let ((y (pop x))) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
190 (while (consp y) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
191 (let ((z (pop y))) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
192 (unless (or (stringp z) (eq z 'catch-all)) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
193 (setq OK nil)))) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
194 (unless (null y) (setq OK nil)))) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
195 (unless (null x) (setq OK nil)) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
196 OK))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
197 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
198 (defcustom bibtex-sort-ignore-string-entries t |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
199 "If non-nil, BibTeX @String entries are not sort-significant. |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
200 That means they are ignored when determining ordering of the buffer |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
201 \(e.g., sorting, locating alphabetical position for new entries, etc.)." |
19460 | 202 :group 'bibtex |
203 :type 'boolean) | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
204 |
19460 | 205 (defcustom bibtex-field-kill-ring-max 20 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
206 "Max length of `bibtex-field-kill-ring' before discarding oldest elements." |
19460 | 207 :group 'bibtex |
208 :type 'integer) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
209 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
210 (defcustom bibtex-entry-kill-ring-max 20 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
211 "Max length of `bibtex-entry-kill-ring' before discarding oldest elements." |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
212 :group 'bibtex |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
213 :type 'integer) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
214 |
19460 | 215 (defcustom bibtex-parse-keys-timeout 60 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
216 "Time interval in seconds for parsing BibTeX buffers during idle time. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
217 Parsing initializes `bibtex-reference-keys' and `bibtex-strings'." |
19460 | 218 :group 'bibtex |
219 :type 'integer) | |
15637
405b1ecbf8ba
(bibtex-reference-head): Allow spaces and tabs between
Karl Heuer <kwzh@gnu.org>
parents:
15565
diff
changeset
|
220 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
221 (defcustom bibtex-parse-keys-fast t |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
222 "If non-nil, use fast but simplified algorithm for parsing BibTeX keys. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
223 If parsing fails, try to set this variable to nil." |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
224 :group 'bibtex |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
225 :type 'boolean) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
226 |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
227 (defvar bibtex-entry-field-alist |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
228 '(("Article" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
229 ((("author" "Author1 [and Author2 ...] [and others]") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
230 ("title" "Title of the article (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
231 ("journal" "Name of the journal (use string, remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
232 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
233 (("volume" "Volume of the journal") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
234 ("number" "Number of the journal (only allowed if entry contains volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
235 ("pages" "Pages in the journal") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
236 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
237 ("note" "Remarks to be put at the end of the \\bibitem"))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
238 ((("author" "Author1 [and Author2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
239 ("title" "Title of the article (BibTeX converts it to lowercase)")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
240 (("pages" "Pages in the journal") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
241 ("journal" "Name of the journal (use string, remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
242 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
243 ("volume" "Volume of the journal") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
244 ("number" "Number of the journal") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
245 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
246 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
247 ("Book" |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
248 ((("author" "Author1 [and Author2 ...] [and others]" nil t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
249 ("editor" "Editor1 [and Editor2 ...] [and others]" nil t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
250 ("title" "Title of the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
251 ("publisher" "Publishing company") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
252 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
253 (("volume" "Volume of the book in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
254 ("number" "Number of the book in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
255 ("series" "Series in which the book appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
256 ("address" "Address of the publisher") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
257 ("edition" "Edition of the book as a capitalized English word") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
258 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
259 ("note" "Remarks to be put at the end of the \\bibitem"))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
260 ((("author" "Author1 [and Author2 ...] [and others]" nil t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
261 ("editor" "Editor1 [and Editor2 ...] [and others]" nil t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
262 ("title" "Title of the book")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
263 (("publisher" "Publishing company") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
264 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
265 ("volume" "Volume of the book in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
266 ("number" "Number of the book in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
267 ("series" "Series in which the book appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
268 ("address" "Address of the publisher") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
269 ("edition" "Edition of the book as a capitalized English word") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
270 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
271 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
272 ("Booklet" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
273 ((("title" "Title of the booklet (BibTeX converts it to lowercase)")) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
274 (("author" "Author1 [and Author2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
275 ("howpublished" "The way in which the booklet was published") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
276 ("address" "Address of the publisher") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
277 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
278 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
279 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
280 ("InBook" |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
281 ((("author" "Author1 [and Author2 ...] [and others]" nil t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
282 ("editor" "Editor1 [and Editor2 ...] [and others]" nil t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
283 ("title" "Title of the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
284 ("chapter" "Chapter in the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
285 ("publisher" "Publishing company") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
286 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
287 (("volume" "Volume of the book in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
288 ("number" "Number of the book in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
289 ("series" "Series in which the book appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
290 ("type" "Word to use instead of \"chapter\"") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
291 ("address" "Address of the publisher") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
292 ("edition" "Edition of the book as a capitalized English word") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
293 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
294 ("pages" "Pages in the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
295 ("note" "Remarks to be put at the end of the \\bibitem"))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
296 ((("author" "Author1 [and Author2 ...] [and others]" nil t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
297 ("editor" "Editor1 [and Editor2 ...] [and others]" nil t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
298 ("title" "Title of the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
299 ("chapter" "Chapter in the book")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
300 (("pages" "Pages in the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
301 ("publisher" "Publishing company") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
302 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
303 ("volume" "Volume of the book in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
304 ("number" "Number of the book in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
305 ("series" "Series in which the book appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
306 ("type" "Word to use instead of \"chapter\"") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
307 ("address" "Address of the publisher") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
308 ("edition" "Edition of the book as a capitalized English word") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
309 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
310 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
311 ("InCollection" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
312 ((("author" "Author1 [and Author2 ...] [and others]") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
313 ("title" "Title of the article in book (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
314 ("booktitle" "Name of the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
315 ("publisher" "Publishing company") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
316 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
317 (("editor" "Editor1 [and Editor2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
318 ("volume" "Volume of the book in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
319 ("number" "Number of the book in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
320 ("series" "Series in which the book appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
321 ("type" "Word to use instead of \"chapter\"") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
322 ("chapter" "Chapter in the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
323 ("pages" "Pages in the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
324 ("address" "Address of the publisher") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
325 ("edition" "Edition of the book as a capitalized English word") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
326 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
327 ("note" "Remarks to be put at the end of the \\bibitem"))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
328 ((("author" "Author1 [and Author2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
329 ("title" "Title of the article in book (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
330 ("booktitle" "Name of the book")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
331 (("pages" "Pages in the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
332 ("publisher" "Publishing company") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
333 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
334 ("editor" "Editor1 [and Editor2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
335 ("volume" "Volume of the book in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
336 ("number" "Number of the book in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
337 ("series" "Series in which the book appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
338 ("type" "Word to use instead of \"chapter\"") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
339 ("chapter" "Chapter in the book") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
340 ("address" "Address of the publisher") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
341 ("edition" "Edition of the book as a capitalized English word") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
342 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
343 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
344 ("InProceedings" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
345 ((("author" "Author1 [and Author2 ...] [and others]") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
346 ("title" "Title of the article in proceedings (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
347 ("booktitle" "Name of the conference proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
348 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
349 (("editor" "Editor1 [and Editor2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
350 ("volume" "Volume of the conference proceedings in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
351 ("number" "Number of the conference proceedings in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
352 ("series" "Series in which the conference proceedings appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
353 ("pages" "Pages in the conference proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
354 ("address" "Location of the Proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
355 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
356 ("organization" "Sponsoring organization of the conference") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
357 ("publisher" "Publishing company, its location") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
358 ("note" "Remarks to be put at the end of the \\bibitem"))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
359 ((("author" "Author1 [and Author2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
360 ("title" "Title of the article in proceedings (BibTeX converts it to lowercase)")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
361 (("booktitle" "Name of the conference proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
362 ("pages" "Pages in the conference proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
363 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
364 ("editor" "Editor1 [and Editor2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
365 ("volume" "Volume of the conference proceedings in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
366 ("number" "Number of the conference proceedings in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
367 ("series" "Series in which the conference proceedings appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
368 ("address" "Location of the Proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
369 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
370 ("organization" "Sponsoring organization of the conference") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
371 ("publisher" "Publishing company, its location") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
372 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
373 ("Manual" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
374 ((("title" "Title of the manual")) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
375 (("author" "Author1 [and Author2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
376 ("organization" "Publishing organization of the manual") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
377 ("address" "Address of the organization") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
378 ("edition" "Edition of the manual as a capitalized English word") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
379 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
380 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
381 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
382 ("MastersThesis" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
383 ((("author" "Author1 [and Author2 ...] [and others]") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
384 ("title" "Title of the master\'s thesis (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
385 ("school" "School where the master\'s thesis was written") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
386 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
387 (("type" "Type of the master\'s thesis (if other than \"Master\'s thesis\")") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
388 ("address" "Address of the school (if not part of field \"school\") or country") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
389 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
390 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
391 ("Misc" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
392 (() |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
393 (("author" "Author1 [and Author2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
394 ("title" "Title of the work (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
395 ("howpublished" "The way in which the work was published") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
396 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
397 ("year" "Year of publication") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
398 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
399 ("PhdThesis" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
400 ((("author" "Author1 [and Author2 ...] [and others]") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
401 ("title" "Title of the PhD. thesis") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
402 ("school" "School where the PhD. thesis was written") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
403 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
404 (("type" "Type of the PhD. thesis") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
405 ("address" "Address of the school (if not part of field \"school\") or country") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
406 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
407 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
408 ("Proceedings" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
409 ((("title" "Title of the conference proceedings") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
410 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
411 (("booktitle" "Title of the proceedings for cross references") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
412 ("editor" "Editor1 [and Editor2 ...] [and others]") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
413 ("volume" "Volume of the conference proceedings in the series") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
414 ("number" "Number of the conference proceedings in a small series (overwritten by volume)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
415 ("series" "Series in which the conference proceedings appeared") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
416 ("address" "Location of the Proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
417 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
418 ("organization" "Sponsoring organization of the conference") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
419 ("publisher" "Publishing company, its location") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
420 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
421 ("TechReport" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
422 ((("author" "Author1 [and Author2 ...] [and others]") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
423 ("title" "Title of the technical report (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
424 ("institution" "Sponsoring institution of the report") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
425 ("year" "Year of publication")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
426 (("type" "Type of the report (if other than \"technical report\")") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
427 ("number" "Number of the technical report") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
428 ("address" "Address of the institution (if not part of field \"institution\") or country") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
429 ("month" "Month of the publication as a string (remove braces)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
430 ("note" "Remarks to be put at the end of the \\bibitem")))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
431 ("Unpublished" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
432 ((("author" "Author1 [and Author2 ...] [and others]") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
433 ("title" "Title of the unpublished work (BibTeX converts it to lowercase)") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
434 ("note" "Remarks to be put at the end of the \\bibitem")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
435 (("month" "Month of the publication as a string (remove braces)") |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
436 ("year" "Year of publication"))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
437 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
438 "List of BibTeX entry types and their associated fields. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
439 List elements are triples |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
440 \(ENTRY-NAME (REQUIRED OPTIONAL) (CROSSREF-REQUIRED CROSSREF-OPTIONAL)). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
441 ENTRY-NAME is the name of a BibTeX entry. The remaining pairs contain |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
442 the required and optional fields of the BibTeX entry. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
443 The second pair is used if a crossref field is present |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
444 and the first pair is used if a crossref field is absent. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
445 If the second pair is nil, the first pair is always used. |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
446 REQUIRED, OPTIONAL, CROSSREF-REQUIRED and CROSSREF-OPTIONAL are lists. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
447 Each element of these lists is a list of the form |
43950
5ef8be2a8db1
(bibtex-sort-ignore-string-entries)
Pavel Janík <Pavel@Janik.cz>
parents:
43758
diff
changeset
|
448 \(FIELD-NAME COMMENT-STRING INIT ALTERNATIVE-FLAG). |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
449 COMMENT-STRING, INIT, and ALTERNATIVE-FLAG are optional. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
450 FIELD-NAME is the name of the field, COMMENT-STRING is the comment that |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
451 appears in the echo area, INIT is either the initial content of the |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
452 field or a function, which is called to determine the initial content |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
453 of the field, and ALTERNATIVE-FLAG (either nil or t) marks if the |
19461 | 454 field is an alternative. ALTERNATIVE-FLAG may be t only in the |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
455 REQUIRED or CROSSREF-REQUIRED lists.") |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
456 (put 'bibtex-entry-field-alist 'risky-local-variable t) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
457 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
458 (defcustom bibtex-comment-start "@Comment" |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
459 "String starting a BibTeX comment." |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
460 :group 'bibtex |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
461 :type 'string) |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
462 |
19460 | 463 (defcustom bibtex-add-entry-hook nil |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
464 "List of functions to call when BibTeX entry has been inserted." |
19460 | 465 :group 'bibtex |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
466 :type 'hook) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
467 |
19460 | 468 (defcustom bibtex-predefined-month-strings |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
469 '(("jan" . "January") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
470 ("feb" . "February") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
471 ("mar" . "March") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
472 ("apr" . "April") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
473 ("may" . "May") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
474 ("jun" . "June") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
475 ("jul" . "July") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
476 ("aug" . "August") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
477 ("sep" . "September") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
478 ("oct" . "October") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
479 ("nov" . "November") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
480 ("dec" . "December")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
481 "Alist of month string definitions used in the BibTeX style files. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
482 Each element is a pair of strings (ABBREVIATION . EXPANSION)." |
19460 | 483 :group 'bibtex |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
484 :type '(repeat (cons (string :tag "Month abbreviation") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
485 (string :tag "Month expansion")))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
486 |
19460 | 487 (defcustom bibtex-predefined-strings |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
488 (append |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
489 bibtex-predefined-month-strings |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
490 '(("acmcs" . "ACM Computing Surveys") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
491 ("acta" . "Acta Informatica") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
492 ("cacm" . "Communications of the ACM") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
493 ("ibmjrd" . "IBM Journal of Research and Development") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
494 ("ibmsj" . "IBM Systems Journal") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
495 ("ieeese" . "IEEE Transactions on Software Engineering") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
496 ("ieeetc" . "IEEE Transactions on Computers") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
497 ("ieeetcad" . "IEEE Transactions on Computer-Aided Design of Integrated Circuits") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
498 ("ipl" . "Information Processing Letters") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
499 ("jacm" . "Journal of the ACM") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
500 ("jcss" . "Journal of Computer and System Sciences") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
501 ("scp" . "Science of Computer Programming") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
502 ("sicomp" . "SIAM Journal on Computing") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
503 ("tcs" . "Theoretical Computer Science") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
504 ("tocs" . "ACM Transactions on Computer Systems") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
505 ("tods" . "ACM Transactions on Database Systems") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
506 ("tog" . "ACM Transactions on Graphics") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
507 ("toms" . "ACM Transactions on Mathematical Software") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
508 ("toois" . "ACM Transactions on Office Information Systems") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
509 ("toplas" . "ACM Transactions on Programming Languages and Systems"))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
510 "Alist of string definitions used in the BibTeX style files. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
511 Each element is a pair of strings (ABBREVIATION . EXPANSION)." |
19460 | 512 :group 'bibtex |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
513 :type '(repeat (cons (string :tag "String") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
514 (string :tag "String expansion")))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
515 |
19460 | 516 (defcustom bibtex-string-files nil |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
517 "List of BibTeX files containing string definitions. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
518 List elements can be absolute file names or file names relative |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
519 to the directories specified in `bibtex-string-file-path'." |
19460 | 520 :group 'bibtex |
521 :type '(repeat file)) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
522 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
523 (defvar bibtex-string-file-path (getenv "BIBINPUTS") |
26711
eac840d283b6
(bibtex-hs-forward-sexp): Added to support
Gerd Moellmann <gerd@gnu.org>
parents:
25444
diff
changeset
|
524 "*Colon separated list of paths to search for `bibtex-string-files'.") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
525 |
57815 | 526 (defcustom bibtex-files nil |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
527 "List of BibTeX files that are searched for entry keys. |
57815 | 528 List elements can be absolute file names or file names relative to the |
529 directories specified in `bibtex-file-path'. If an element is a directory, | |
530 check all BibTeX files in this directory. If an element is the symbol | |
531 `bibtex-file-path', check all BibTeX files in `bibtex-file-path'." | |
532 :group 'bibtex | |
75356
2600e61a031f
(bibtex-files): Fix customization type.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
75347
diff
changeset
|
533 :type '(repeat (choice (const :tag "bibtex-file-path" bibtex-file-path) |
2600e61a031f
(bibtex-files): Fix customization type.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
75347
diff
changeset
|
534 directory file))) |
57815 | 535 |
536 (defvar bibtex-file-path (getenv "BIBINPUTS") | |
537 "*Colon separated list of paths to search for `bibtex-files'.") | |
538 | |
19460 | 539 (defcustom bibtex-help-message t |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
540 "If non-nil print help messages in the echo area on entering a new field." |
19460 | 541 :group 'bibtex |
542 :type 'boolean) | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
543 |
19460 | 544 (defcustom bibtex-autokey-prefix-string "" |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
545 "String prefix for automatically generated reference keys. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
546 See `bibtex-generate-autokey' for details." |
19460 | 547 :group 'bibtex-autokey |
548 :type 'string) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
549 |
19460 | 550 (defcustom bibtex-autokey-names 1 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
551 "Number of names to use for the automatically generated reference key. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
552 Possibly more names are used according to `bibtex-autokey-names-stretch'. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
553 If this variable is nil, all names are used. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
554 See `bibtex-generate-autokey' for details." |
19460 | 555 :group 'bibtex-autokey |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
556 :type '(choice (const :tag "All" infty) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
557 integer)) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
558 |
19460 | 559 (defcustom bibtex-autokey-names-stretch 0 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
560 "Number of names that can additionally be used for reference keys. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
561 These names are used only, if all names are used then. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
562 See `bibtex-generate-autokey' for details." |
19460 | 563 :group 'bibtex-autokey |
564 :type 'integer) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
565 |
19460 | 566 (defcustom bibtex-autokey-additional-names "" |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
567 "String to append to the generated key if not all names could be used. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
568 See `bibtex-generate-autokey' for details." |
19460 | 569 :group 'bibtex-autokey |
570 :type 'string) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
571 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
572 (defcustom bibtex-autokey-expand-strings nil |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
573 "If non-nil, expand strings when extracting the content of a BibTeX field. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
574 See `bibtex-generate-autokey' for details." |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
575 :group 'bibtex-autokey |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
576 :type 'boolean) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
577 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
578 (defvar bibtex-autokey-transcriptions |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
579 '(;; language specific characters |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
580 ("\\\\aa" . "a") ; \aa -> a |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
581 ("\\\\AA" . "A") ; \AA -> A |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
582 ("\\\"a\\|\\\\\\\"a\\|\\\\ae" . "ae") ; "a,\"a,\ae -> ae |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
583 ("\\\"A\\|\\\\\\\"A\\|\\\\AE" . "Ae") ; "A,\"A,\AE -> Ae |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
584 ("\\\\i" . "i") ; \i -> i |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
585 ("\\\\j" . "j") ; \j -> j |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
586 ("\\\\l" . "l") ; \l -> l |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
587 ("\\\\L" . "L") ; \L -> L |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
588 ("\\\"o\\|\\\\\\\"o\\|\\\\o\\|\\\\oe" . "oe") ; "o,\"o,\o,\oe -> oe |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
589 ("\\\"O\\|\\\\\\\"O\\|\\\\O\\|\\\\OE" . "Oe") ; "O,\"O,\O,\OE -> Oe |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
590 ("\\\"s\\|\\\\\\\"s\\|\\\\3" . "ss") ; "s,\"s,\3 -> ss |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
591 ("\\\"u\\|\\\\\\\"u" . "ue") ; "u,\"u -> ue |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
592 ("\\\"U\\|\\\\\\\"U" . "Ue") ; "U,\"U -> Ue |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
593 ;; accents |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
594 ("\\\\`\\|\\\\'\\|\\\\\\^\\|\\\\~\\|\\\\=\\|\\\\\\.\\|\\\\u\\|\\\\v\\|\\\\H\\|\\\\t\\|\\\\c\\|\\\\d\\|\\\\b" . "") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
595 ;; braces, quotes, concatenation. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
596 ("[`'\"{}#]" . "") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
597 ;; spaces |
57815 | 598 ("\\\\?[ \t\n]+\\|~" . " ")) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
599 "Alist of (OLD-REGEXP . NEW-STRING) pairs. |
19461 | 600 Used by the default values of `bibtex-autokey-name-change-strings' and |
601 `bibtex-autokey-titleword-change-strings'. Defaults to translating some | |
602 language specific characters to their ASCII transcriptions, and | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
603 removing any character accents.") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
604 |
19460 | 605 (defcustom bibtex-autokey-name-change-strings |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
606 bibtex-autokey-transcriptions |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
607 "Alist of (OLD-REGEXP . NEW-STRING) pairs. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
608 Any part of a name matching OLD-REGEXP is replaced by NEW-STRING. |
19461 | 609 Case is significant in OLD-REGEXP. All regexps are tried in the |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
610 order in which they appear in the list. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
611 See `bibtex-generate-autokey' for details." |
19460 | 612 :group 'bibtex-autokey |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
613 :type '(repeat (cons (regexp :tag "Old") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
614 (string :tag "New")))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
615 |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
616 (defcustom bibtex-autokey-name-case-convert-function 'downcase |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
617 "Function called for each name to perform case conversion. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
618 See `bibtex-generate-autokey' for details." |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
619 :group 'bibtex-autokey |
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
620 :type '(choice (const :tag "Preserve case" identity) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
621 (const :tag "Downcase" downcase) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
622 (const :tag "Capitalize" capitalize) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
623 (const :tag "Upcase" upcase) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
624 (function :tag "Conversion function"))) |
71044
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
625 (put 'bibtex-autokey-name-case-convert-function 'safe-local-variable |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
626 (lambda (x) (memq x '(upcase downcase capitalize identity)))) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
627 (defvaralias 'bibtex-autokey-name-case-convert |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
628 'bibtex-autokey-name-case-convert-function) |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
629 |
19460 | 630 (defcustom bibtex-autokey-name-length 'infty |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
631 "Number of characters from name to incorporate into key. |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
632 If this is set to anything but a number, all characters are used. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
633 See `bibtex-generate-autokey' for details." |
19460 | 634 :group 'bibtex-autokey |
635 :type '(choice (const :tag "All" infty) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
636 integer)) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
637 |
19460 | 638 (defcustom bibtex-autokey-name-separator "" |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
639 "String that comes between any two names in the key. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
640 See `bibtex-generate-autokey' for details." |
19460 | 641 :group 'bibtex-autokey |
642 :type 'string) | |
643 | |
644 (defcustom bibtex-autokey-year-length 2 | |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
645 "Number of rightmost digits from the year field to incorporate into key. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
646 See `bibtex-generate-autokey' for details." |
19460 | 647 :group 'bibtex-autokey |
648 :type 'integer) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
649 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
650 (defcustom bibtex-autokey-use-crossref t |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
651 "If non-nil use fields from crossreferenced entry if necessary. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
652 If this variable is non-nil and some field has no entry, but a |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
653 valid crossref entry, the field from the crossreferenced entry is used. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
654 See `bibtex-generate-autokey' for details." |
19460 | 655 :group 'bibtex-autokey |
656 :type 'boolean) | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
657 |
19460 | 658 (defcustom bibtex-autokey-titlewords 5 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
659 "Number of title words to use for the automatically generated reference key. |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
660 If this is set to anything but a number, all title words are used. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
661 Possibly more words from the title are used according to |
19461 | 662 `bibtex-autokey-titlewords-stretch'. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
663 See `bibtex-generate-autokey' for details." |
19460 | 664 :group 'bibtex-autokey |
665 :type '(choice (const :tag "All" infty) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
666 integer)) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
667 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
668 (defcustom bibtex-autokey-title-terminators "[.!?:;]\\|--" |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
669 "Regexp defining the termination of the main part of the title. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
670 Case of the regexps is ignored. See `bibtex-generate-autokey' for details." |
19460 | 671 :group 'bibtex-autokey |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
672 :type 'regexp) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
673 |
19460 | 674 (defcustom bibtex-autokey-titlewords-stretch 2 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
675 "Number of words that can additionally be used from the title. |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
676 These words are used only, if a sentence from the title can be ended then. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
677 See `bibtex-generate-autokey' for details." |
19460 | 678 :group 'bibtex-autokey |
679 :type 'integer) | |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
680 |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
681 (defcustom bibtex-autokey-titleword-ignore |
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
682 '("A" "An" "On" "The" "Eine?" "Der" "Die" "Das" |
61439
267229876c56
(bibtex-autokey-titleword-ignore, bibtex-reference-key)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61247
diff
changeset
|
683 "[^[:upper:]].*" ".*[^[:upper:]0-9].*") |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
684 "Determines words from the title that are not to be used in the key. |
59733
96d73eb02751
(bibtex-format-entry): Use `bibtex-empty-field-re' only on the text of
Lute Kamstra <lute@gnu.org>
parents:
58772
diff
changeset
|
685 Each item of the list is a regexp. If a word of the title matches a |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
686 regexp from that list, it is not included in the title part of the key. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
687 See `bibtex-generate-autokey' for details." |
19460 | 688 :group 'bibtex-autokey |
689 :type '(repeat regexp)) | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
690 |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
691 (defcustom bibtex-autokey-titleword-case-convert-function 'downcase |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
692 "Function called for each titleword to perform case conversion. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
693 See `bibtex-generate-autokey' for details." |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
694 :group 'bibtex-autokey |
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
695 :type '(choice (const :tag "Preserve case" identity) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
696 (const :tag "Downcase" downcase) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
697 (const :tag "Capitalize" capitalize) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
698 (const :tag "Upcase" upcase) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
699 (function :tag "Conversion function"))) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
700 (defvaralias 'bibtex-autokey-titleword-case-convert |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
701 'bibtex-autokey-titleword-case-convert-function) |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
702 |
19460 | 703 (defcustom bibtex-autokey-titleword-abbrevs nil |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
704 "Determines exceptions to the usual abbreviation mechanism. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
705 An alist of (OLD-REGEXP . NEW-STRING) pairs. Case is ignored |
19461 | 706 in matching against OLD-REGEXP, and the first matching pair is used. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
707 See `bibtex-generate-autokey' for details." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
708 :group 'bibtex-autokey |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
709 :type '(repeat (cons (regexp :tag "Old") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
710 (string :tag "New")))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
711 |
19460 | 712 (defcustom bibtex-autokey-titleword-change-strings |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
713 bibtex-autokey-transcriptions |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
714 "Alist of (OLD-REGEXP . NEW-STRING) pairs. |
19461 | 715 Any part of title word matching a OLD-REGEXP is replaced by NEW-STRING. |
716 Case is significant in OLD-REGEXP. All regexps are tried in the | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
717 order in which they appear in the list. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
718 See `bibtex-generate-autokey' for details." |
19460 | 719 :group 'bibtex-autokey |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
720 :type '(repeat (cons (regexp :tag "Old") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
721 (string :tag "New")))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
722 |
19460 | 723 (defcustom bibtex-autokey-titleword-length 5 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
724 "Number of characters from title words to incorporate into key. |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
725 If this is set to anything but a number, all characters are used. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
726 See `bibtex-generate-autokey' for details." |
19460 | 727 :group 'bibtex-autokey |
728 :type '(choice (const :tag "All" infty) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
729 integer)) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
730 |
19460 | 731 (defcustom bibtex-autokey-titleword-separator "_" |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
732 "String to be put between the title words. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
733 See `bibtex-generate-autokey' for details." |
19460 | 734 :group 'bibtex-autokey |
735 :type 'string) | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
736 |
19460 | 737 (defcustom bibtex-autokey-name-year-separator "" |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
738 "String to be put between name part and year part of key. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
739 See `bibtex-generate-autokey' for details." |
19460 | 740 :group 'bibtex-autokey |
741 :type 'string) | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
742 |
19460 | 743 (defcustom bibtex-autokey-year-title-separator ":_" |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
744 "String to be put between name part and year part of key. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
745 See `bibtex-generate-autokey' for details." |
19460 | 746 :group 'bibtex-autokey |
747 :type 'string) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
748 |
19460 | 749 (defcustom bibtex-autokey-edit-before-use t |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
750 "If non-nil, user is allowed to edit the generated key before it is used." |
19460 | 751 :group 'bibtex-autokey |
752 :type 'boolean) | |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
753 |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
754 (defcustom bibtex-autokey-before-presentation-function nil |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
755 "If non-nil, function to call before generated key is presented. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
756 The function must take one argument (the automatically generated key), |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
757 and must return a string (the key to use)." |
19460 | 758 :group 'bibtex-autokey |
35962
ad7104908c16
(bibtex-autokey-before-presentation-function): Fix :type.
Dave Love <fx@gnu.org>
parents:
27701
diff
changeset
|
759 :type '(choice (const nil) function)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
760 |
19460 | 761 (defcustom bibtex-entry-offset 0 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
762 "Offset for BibTeX entries. |
59733
96d73eb02751
(bibtex-format-entry): Use `bibtex-empty-field-re' only on the text of
Lute Kamstra <lute@gnu.org>
parents:
58772
diff
changeset
|
763 Added to the value of all other variables which determine columns." |
19460 | 764 :group 'bibtex |
765 :type 'integer) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
766 |
19460 | 767 (defcustom bibtex-field-indentation 2 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
768 "Starting column for the name part in BibTeX fields." |
19460 | 769 :group 'bibtex |
770 :type 'integer) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
771 |
19460 | 772 (defcustom bibtex-text-indentation |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
773 (+ bibtex-field-indentation |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
774 (length "organization = ")) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
775 "Starting column for the text part in BibTeX fields. |
19460 | 776 Should be equal to the space needed for the longest name part." |
777 :group 'bibtex | |
778 :type 'integer) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
779 |
19460 | 780 (defcustom bibtex-contline-indentation |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
781 (+ bibtex-text-indentation 1) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
782 "Starting column for continuation lines of BibTeX fields." |
19460 | 783 :group 'bibtex |
784 :type 'integer) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
785 |
19460 | 786 (defcustom bibtex-align-at-equal-sign nil |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
787 "If non-nil, align fields at equal sign instead of field text. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
788 If non-nil, the column for the equal sign is the value of |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
789 `bibtex-text-indentation', minus 2." |
19460 | 790 :group 'bibtex |
791 :type 'boolean) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
792 |
19460 | 793 (defcustom bibtex-comma-after-last-field nil |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
794 "If non-nil, a comma is put at end of last field in the entry template." |
19460 | 795 :group 'bibtex |
796 :type 'boolean) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
797 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
798 (defcustom bibtex-autoadd-commas t |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
799 "If non-nil automatically add missing commas at end of BibTeX fields." |
57815 | 800 :group 'bibtex |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
801 :type 'boolean) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
802 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
803 (defcustom bibtex-autofill-types '("Proceedings") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
804 "Automatically fill fields if possible for those BibTeX entry types." |
57815 | 805 :group 'bibtex |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
806 :type '(repeat string)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
807 |
57815 | 808 (defcustom bibtex-summary-function 'bibtex-summary |
62077
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
809 "Function to call for generating a summary of current BibTeX entry. |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
810 It takes no arguments. Point must be at beginning of entry. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
811 Used by `bibtex-complete-crossref-cleanup' and `bibtex-copy-summary-as-kill'." |
57815 | 812 :group 'bibtex |
813 :type '(choice (const :tag "Default" bibtex-summary) | |
814 (function :tag "Personalized function"))) | |
815 | |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
816 (defcustom bibtex-generate-url-list |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
817 '((("url" . ".*:.*"))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
818 "List of schemes for generating the URL of a BibTeX entry. |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
819 These schemes are used by `bibtex-url'. |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
820 |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
821 Each scheme should have one of these forms: |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
822 |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
823 ((FIELD . REGEXP)) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
824 ((FIELD . REGEXP) STEP...) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
825 ((FIELD . REGEXP) STRING STEP...) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
826 |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
827 FIELD is a field name as returned by `bibtex-parse-entry'. |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
828 REGEXP is matched against the text of FIELD. If the match succeeds, |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
829 then this scheme is used. If no STRING and STEPs are specified |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
830 the matched text is used as the URL, otherwise the URL is built |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
831 by evaluating STEPs. If no STRING is specified the STEPs must result |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
832 in strings which are concatenated. Otherwise the resulting objects |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
833 are passed through `format' using STRING as format control string. |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
834 |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
835 A STEP is a list (FIELD REGEXP REPLACE). The text of FIELD |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
836 is matched against REGEXP, and is replaced with REPLACE. |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
837 REPLACE can be a string, or a number (which selects the corresponding |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
838 submatch), or a function called with the field's text as argument |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
839 and with the `match-data' properly set. |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
840 |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
841 Case is always ignored. Always remove the field delimiters. |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
842 If `bibtex-expand-strings' is non-nil, BibTeX strings are expanded |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
843 for generating the URL. |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
844 |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
845 The following is a complex example, see http://link.aps.org/linkfaq.html. |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
846 |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
847 (((\"journal\" . \"\\\\=<\\(PR[ABCDEL]?\\|RMP\\)\\\\=>\") |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
848 \"http://link.aps.org/abstract/%s/v%s/p%s\" |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
849 (\"journal\" \".*\" downcase) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
850 (\"volume\" \".*\" 0) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
851 (\"pages\" \"\\`[A-Z]?[0-9]+\" 0)))" |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
852 :group 'bibtex |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
853 :type '(repeat |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
854 (cons :tag "Scheme" |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
855 (cons :tag "Matcher" :extra-offset 4 |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
856 (string :tag "BibTeX field") |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
857 (regexp :tag "Regexp")) |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
858 (choice |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
859 (const :tag "Take match as is" nil) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
860 (cons :tag "Formatted" |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
861 (string :tag "Format control string") |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
862 (repeat :tag "Steps to generate URL" |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
863 (list (string :tag "BibTeX field") |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
864 (regexp :tag "Regexp") |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
865 (choice (string :tag "Replacement") |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
866 (integer :tag "Sub-match") |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
867 (function :tag "Filter"))))) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
868 (repeat :tag "Concatenated" |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
869 (list (string :tag "BibTeX field") |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
870 (regexp :tag "Regexp") |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
871 (choice (string :tag "Replacement") |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
872 (integer :tag "Sub-match") |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
873 (function :tag "Filter")))))))) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
874 (put 'bibtex-generate-url-list 'risky-local-variable t) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
875 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
876 (defcustom bibtex-expand-strings nil |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
877 "If non-nil, expand strings when extracting the content of a BibTeX field." |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
878 :group 'bibtex |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
879 :type 'boolean) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
880 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
881 ;; `bibtex-font-lock-keywords' is a user option, too. But since the |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
882 ;; patterns used to define this variable are defined in a later |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
883 ;; section of this file, it is defined later. |
26711
eac840d283b6
(bibtex-hs-forward-sexp): Added to support
Gerd Moellmann <gerd@gnu.org>
parents:
25444
diff
changeset
|
884 |
eac840d283b6
(bibtex-hs-forward-sexp): Added to support
Gerd Moellmann <gerd@gnu.org>
parents:
25444
diff
changeset
|
885 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
886 ;; Syntax Table and Keybindings |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
887 (defvar bibtex-mode-syntax-table |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
888 (let ((st (make-syntax-table))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
889 (modify-syntax-entry ?\" "\"" st) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
890 (modify-syntax-entry ?$ "$$ " st) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
891 (modify-syntax-entry ?% "< " st) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
892 (modify-syntax-entry ?' "w " st) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
893 (modify-syntax-entry ?@ "w " st) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
894 (modify-syntax-entry ?\\ "\\" st) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
895 (modify-syntax-entry ?\f "> " st) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
896 (modify-syntax-entry ?\n "> " st) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
897 ;; Keys cannot have = in them (wrong font-lock of @string{foo=bar}). |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
898 (modify-syntax-entry ?= "." st) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
899 (modify-syntax-entry ?~ " " st) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
900 st) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
901 "Syntax table used in BibTeX mode buffers.") |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
902 |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
903 (defvar bibtex-mode-map |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
904 (let ((km (make-sparse-keymap))) |
26711
eac840d283b6
(bibtex-hs-forward-sexp): Added to support
Gerd Moellmann <gerd@gnu.org>
parents:
25444
diff
changeset
|
905 ;; The Key `C-c&' is reserved for reftex.el |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
906 (define-key km "\t" 'bibtex-find-text) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
907 (define-key km "\n" 'bibtex-next-field) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
908 (define-key km "\M-\t" 'bibtex-complete) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
909 (define-key km "\C-c\"" 'bibtex-remove-delimiters) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
910 (define-key km "\C-c{" 'bibtex-remove-delimiters) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
911 (define-key km "\C-c}" 'bibtex-remove-delimiters) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
912 (define-key km "\C-c\C-c" 'bibtex-clean-entry) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
913 (define-key km "\C-c\C-q" 'bibtex-fill-entry) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
914 (define-key km "\C-c\C-s" 'bibtex-find-entry) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
915 (define-key km "\C-c\C-x" 'bibtex-find-crossref) |
57815 | 916 (define-key km "\C-c\C-t" 'bibtex-copy-summary-as-kill) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
917 (define-key km "\C-c?" 'bibtex-print-help-message) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
918 (define-key km "\C-c\C-p" 'bibtex-pop-previous) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
919 (define-key km "\C-c\C-n" 'bibtex-pop-next) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
920 (define-key km "\C-c\C-k" 'bibtex-kill-field) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
921 (define-key km "\C-c\M-k" 'bibtex-copy-field-as-kill) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
922 (define-key km "\C-c\C-w" 'bibtex-kill-entry) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
923 (define-key km "\C-c\M-w" 'bibtex-copy-entry-as-kill) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
924 (define-key km "\C-c\C-y" 'bibtex-yank) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
925 (define-key km "\C-c\M-y" 'bibtex-yank-pop) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
926 (define-key km "\C-c\C-d" 'bibtex-empty-field) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
927 (define-key km "\C-c\C-f" 'bibtex-make-field) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
928 (define-key km "\C-c\C-u" 'bibtex-entry-update) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
929 (define-key km "\C-c$" 'bibtex-ispell-abstract) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
930 (define-key km "\M-\C-a" 'bibtex-beginning-of-entry) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
931 (define-key km "\M-\C-e" 'bibtex-end-of-entry) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
932 (define-key km "\C-\M-l" 'bibtex-reposition-window) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
933 (define-key km "\C-\M-h" 'bibtex-mark-entry) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
934 (define-key km "\C-c\C-b" 'bibtex-entry) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
935 (define-key km "\C-c\C-rn" 'bibtex-narrow-to-entry) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
936 (define-key km "\C-c\C-rw" 'widen) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
937 (define-key km "\C-c\C-l" 'bibtex-url) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
938 (define-key km "\C-c\C-o" 'bibtex-remove-OPT-or-ALT) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
939 (define-key km "\C-c\C-e\C-i" 'bibtex-InProceedings) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
940 (define-key km "\C-c\C-ei" 'bibtex-InCollection) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
941 (define-key km "\C-c\C-eI" 'bibtex-InBook) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
942 (define-key km "\C-c\C-e\C-a" 'bibtex-Article) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
943 (define-key km "\C-c\C-e\C-b" 'bibtex-InBook) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
944 (define-key km "\C-c\C-eb" 'bibtex-Book) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
945 (define-key km "\C-c\C-eB" 'bibtex-Booklet) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
946 (define-key km "\C-c\C-e\C-c" 'bibtex-InCollection) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
947 (define-key km "\C-c\C-e\C-m" 'bibtex-Manual) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
948 (define-key km "\C-c\C-em" 'bibtex-MastersThesis) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
949 (define-key km "\C-c\C-eM" 'bibtex-Misc) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
950 (define-key km "\C-c\C-e\C-p" 'bibtex-InProceedings) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
951 (define-key km "\C-c\C-ep" 'bibtex-Proceedings) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
952 (define-key km "\C-c\C-eP" 'bibtex-PhdThesis) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
953 (define-key km "\C-c\C-e\M-p" 'bibtex-Preamble) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
954 (define-key km "\C-c\C-e\C-s" 'bibtex-String) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
955 (define-key km "\C-c\C-e\C-t" 'bibtex-TechReport) |
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
956 (define-key km "\C-c\C-e\C-u" 'bibtex-Unpublished) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
957 km) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
958 "Keymap used in BibTeX mode.") |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
959 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
960 (easy-menu-define |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
961 bibtex-edit-menu bibtex-mode-map "BibTeX-Edit Menu in BibTeX mode" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
962 '("BibTeX-Edit" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
963 ("Moving inside an Entry" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
964 ["End of Field" bibtex-find-text t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
965 ["Next Field" bibtex-next-field t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
966 ["Beginning of Entry" bibtex-beginning-of-entry t] |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
967 ["End of Entry" bibtex-end-of-entry t] |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
968 "--" |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
969 ["Make Entry Visible" bibtex-reposition-window t]) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
970 ("Moving in BibTeX Buffers" |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
971 ["Find Entry" bibtex-find-entry t] |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
972 ["Find Crossref Entry" bibtex-find-crossref t]) |
57815 | 973 "--" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
974 ("Operating on Current Field" |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
975 ["Fill Field" fill-paragraph t] |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
976 ["Remove Delimiters" bibtex-remove-delimiters t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
977 ["Remove OPT or ALT Prefix" bibtex-remove-OPT-or-ALT t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
978 ["Clear Field" bibtex-empty-field t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
979 "--" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
980 ["Kill Field" bibtex-kill-field t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
981 ["Copy Field to Kill Ring" bibtex-copy-field-as-kill t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
982 ["Paste Most Recently Killed Field" bibtex-yank t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
983 ["Paste Previously Killed Field" bibtex-yank-pop t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
984 "--" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
985 ["Make New Field" bibtex-make-field t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
986 "--" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
987 ["Snatch from Similar Following Field" bibtex-pop-next t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
988 ["Snatch from Similar Preceding Field" bibtex-pop-previous t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
989 "--" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
990 ["String or Key Complete" bibtex-complete t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
991 "--" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
992 ["Help about Current Field" bibtex-print-help-message t]) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
993 ("Operating on Current Entry" |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
994 ["Fill Entry" bibtex-fill-entry t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
995 ["Clean Entry" bibtex-clean-entry t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
996 ["Update Entry" bibtex-entry-update t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
997 "--" |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
998 ["Kill Entry" bibtex-kill-entry t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
999 ["Copy Entry to Kill Ring" bibtex-copy-entry-as-kill t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1000 ["Paste Most Recently Killed Entry" bibtex-yank t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1001 ["Paste Previously Killed Entry" bibtex-yank-pop t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1002 "--" |
57815 | 1003 ["Copy Summary to Kill Ring" bibtex-copy-summary-as-kill t] |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1004 ["Browse URL" bibtex-url t] |
57815 | 1005 "--" |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1006 ["Ispell Entry" bibtex-ispell-entry t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1007 ["Ispell Entry Abstract" bibtex-ispell-abstract t] |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1008 "--" |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1009 ["Narrow to Entry" bibtex-narrow-to-entry t] |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1010 ["Mark Entry" bibtex-mark-entry t] |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1011 "--" |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1012 ["View Cite Locations (RefTeX)" reftex-view-crossref-from-bibtex |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1013 (fboundp 'reftex-view-crossref-from-bibtex)]) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1014 ("Operating on Buffer or Region" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1015 ["Validate Entries" bibtex-validate t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1016 ["Sort Entries" bibtex-sort-buffer t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1017 ["Reformat Entries" bibtex-reformat t] |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1018 ["Count Entries" bibtex-count-entries t] |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1019 "--" |
57815 | 1020 ["Convert Alien Buffer" bibtex-convert-alien t]) |
1021 ("Operating on Multiple Buffers" | |
1022 ["Validate Entries" bibtex-validate-globally t]))) | |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
1023 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1024 (easy-menu-define |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1025 bibtex-entry-menu bibtex-mode-map "Entry-Types Menu in BibTeX mode" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1026 (list "Entry-Types" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1027 ["Article in Journal" bibtex-Article t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1028 ["Article in Conference Proceedings" bibtex-InProceedings t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1029 ["Article in a Collection" bibtex-InCollection t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1030 ["Chapter or Pages in a Book" bibtex-InBook t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1031 ["Conference Proceedings" bibtex-Proceedings t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1032 ["Book" bibtex-Book t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1033 ["Booklet (Bound, but no Publisher/Institution)" bibtex-Booklet t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1034 ["PhD. Thesis" bibtex-PhdThesis t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1035 ["Master's Thesis" bibtex-MastersThesis t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1036 ["Technical Report" bibtex-TechReport t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1037 ["Technical Manual" bibtex-Manual t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1038 ["Unpublished" bibtex-Unpublished t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1039 ["Miscellaneous" bibtex-Misc t] |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1040 "--" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1041 ["String" bibtex-String t] |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1042 ["Preamble" bibtex-Preamble t])) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
1043 |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
1044 |
12700
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
1045 ;; Internal Variables |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
1046 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1047 (defvar bibtex-pop-previous-search-point nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1048 "Next point where `bibtex-pop-previous' starts looking for a similar entry.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1049 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1050 (defvar bibtex-pop-next-search-point nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1051 "Next point where `bibtex-pop-next' starts looking for a similar entry.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1052 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1053 (defvar bibtex-field-kill-ring nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1054 "Ring of least recently killed fields. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1055 At most `bibtex-field-kill-ring-max' items are kept here.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1056 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1057 (defvar bibtex-field-kill-ring-yank-pointer nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1058 "The tail of `bibtex-field-kill-ring' whose car is the last item yanked.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1059 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1060 (defvar bibtex-entry-kill-ring nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1061 "Ring of least recently killed entries. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1062 At most `bibtex-entry-kill-ring-max' items are kept here.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1063 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1064 (defvar bibtex-entry-kill-ring-yank-pointer nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1065 "The tail of `bibtex-entry-kill-ring' whose car is the last item yanked.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1066 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1067 (defvar bibtex-last-kill-command nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1068 "Type of the last kill command (either 'field or 'entry).") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1069 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1070 (defvar bibtex-strings |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1071 (lazy-completion-table bibtex-strings |
67816
d195eef388b8
(bibtex-strings, bibtex-reference-keys):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
67575
diff
changeset
|
1072 (lambda () |
d195eef388b8
(bibtex-strings, bibtex-reference-keys):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
67575
diff
changeset
|
1073 (bibtex-parse-strings (bibtex-string-files-init)))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1074 "Completion table for BibTeX string keys. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1075 Initialized from `bibtex-predefined-strings' and `bibtex-string-files'.") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1076 (make-variable-buffer-local 'bibtex-strings) |
68265
9e0c23ab13f9
(bibtex-strings, bibtex-reference-keys): Mark as risky.
Richard M. Stallman <rms@gnu.org>
parents:
68065
diff
changeset
|
1077 (put 'bibtex-strings 'risky-local-variable t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1078 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1079 (defvar bibtex-reference-keys |
67816
d195eef388b8
(bibtex-strings, bibtex-reference-keys):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
67575
diff
changeset
|
1080 (lazy-completion-table bibtex-reference-keys |
d195eef388b8
(bibtex-strings, bibtex-reference-keys):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
67575
diff
changeset
|
1081 (lambda () (bibtex-parse-keys nil t))) |
57815 | 1082 "Completion table for BibTeX reference keys. |
1083 The CDRs of the elements are t for header keys and nil for crossref keys.") | |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1084 (make-variable-buffer-local 'bibtex-reference-keys) |
68265
9e0c23ab13f9
(bibtex-strings, bibtex-reference-keys): Mark as risky.
Richard M. Stallman <rms@gnu.org>
parents:
68065
diff
changeset
|
1085 (put 'bibtex-reference-keys 'risky-local-variable t) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1086 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1087 (defvar bibtex-buffer-last-parsed-tick nil |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1088 "Value of `buffer-modified-tick' last time buffer was parsed for keys.") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1089 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1090 (defvar bibtex-parse-idle-timer nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1091 "Stores if timer is already installed.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1092 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1093 (defvar bibtex-progress-lastperc nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1094 "Last reported percentage for the progress message.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1095 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1096 (defvar bibtex-progress-lastmes nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1097 "Last reported progress message.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1098 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1099 (defvar bibtex-progress-interval nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1100 "Interval for progress messages.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1101 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1102 (defvar bibtex-key-history nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1103 "History list for reading keys.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1104 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1105 (defvar bibtex-entry-type-history nil |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1106 "History list for reading entry types.") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1107 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1108 (defvar bibtex-field-history nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1109 "History list for reading field names.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1110 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1111 (defvar bibtex-reformat-previous-options nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1112 "Last reformat options given.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1113 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1114 (defvar bibtex-reformat-previous-reference-keys nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1115 "Last reformat reference keys option given.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1116 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1117 (defconst bibtex-field-name "[^\"#%'(),={} \t\n0-9][^\"#%'(),={} \t\n]*" |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1118 "Regexp matching the name of a BibTeX field.") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1119 |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1120 (defconst bibtex-name-part |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1121 (concat ",[ \t\n]*\\(" bibtex-field-name "\\)") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1122 "Regexp matching the name part of a BibTeX field.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1123 |
61439
267229876c56
(bibtex-autokey-titleword-ignore, bibtex-reference-key)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61247
diff
changeset
|
1124 (defconst bibtex-reference-key "[][[:alnum:].:;?!`'/*@+|()<>&_^$-]+" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1125 "Regexp matching the reference key part of a BibTeX entry.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1126 |
61439
267229876c56
(bibtex-autokey-titleword-ignore, bibtex-reference-key)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61247
diff
changeset
|
1127 (defconst bibtex-field-const "[][[:alnum:].:;?!`'/*@+=|<>&_^$-]+" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1128 "Regexp matching a BibTeX field constant.") |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
1129 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1130 (defvar bibtex-entry-type |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1131 (concat "@[ \t]*\\(?:" |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1132 (regexp-opt (mapcar 'car bibtex-entry-field-alist)) "\\)") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1133 "Regexp matching the name of a BibTeX entry.") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1134 |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1135 (defvar bibtex-entry-head |
15637
405b1ecbf8ba
(bibtex-reference-head): Allow spaces and tabs between
Karl Heuer <kwzh@gnu.org>
parents:
15565
diff
changeset
|
1136 (concat "^[ \t]*\\(" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1137 bibtex-entry-type |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1138 "\\)[ \t]*[({][ \t\n]*\\(" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1139 bibtex-reference-key |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1140 "\\)") |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1141 "Regexp matching the header line of a BibTeX entry (including key).") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1142 |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1143 (defvar bibtex-entry-maybe-empty-head |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1144 (concat bibtex-entry-head "?") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1145 "Regexp matching the header line of a BibTeX entry (possibly without key).") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1146 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1147 (defconst bibtex-any-entry-maybe-empty-head |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1148 (concat "^[ \t]*\\(@[ \t]*" bibtex-field-name "\\)[ \t]*[({][ \t\n]*\\(" |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1149 bibtex-reference-key "\\)?") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1150 "Regexp matching the header line of any BibTeX entry (possibly without key).") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1151 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1152 (defvar bibtex-any-valid-entry-type |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1153 (concat "^[ \t]*@[ \t]*\\(?:" |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1154 (regexp-opt (append '("String" "Preamble") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1155 (mapcar 'car bibtex-entry-field-alist))) "\\)") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1156 "Regexp matching any valid BibTeX entry (including String and Preamble).") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1157 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1158 (defconst bibtex-type-in-head 1 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1159 "Regexp subexpression number of the type part in `bibtex-entry-head'.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1160 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1161 (defconst bibtex-key-in-head 2 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1162 "Regexp subexpression number of the key part in `bibtex-entry-head'.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1163 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1164 (defconst bibtex-string-type "^[ \t]*\\(@[ \t]*String\\)[ \t]*[({][ \t\n]*" |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1165 "Regexp matching the name of a BibTeX String entry.") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1166 |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1167 (defconst bibtex-string-maybe-empty-head |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1168 (concat bibtex-string-type "\\(" bibtex-reference-key "\\)?") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1169 "Regexp matching the header line of a BibTeX String entry.") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1170 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1171 (defconst bibtex-preamble-prefix |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1172 "[ \t]*\\(@[ \t]*Preamble\\)[ \t]*[({][ \t\n]*" |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1173 "Regexp matching the prefix part of a BibTeX Preamble entry.") |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1174 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1175 (defconst bibtex-font-lock-syntactic-keywords |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1176 `((,(concat "^[ \t]*\\(" (substring bibtex-comment-start 0 1) "\\)" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1177 (substring bibtex-comment-start 1) "\\>") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1178 1 '(11)))) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
1179 |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
1180 (defvar bibtex-font-lock-keywords |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1181 ;; entry type and reference key |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1182 `((,bibtex-any-entry-maybe-empty-head |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1183 (,bibtex-type-in-head font-lock-function-name-face) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1184 (,bibtex-key-in-head font-lock-constant-face nil t)) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1185 ;; optional field names (treated as comments) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1186 (,(concat "^[ \t]*\\(OPT" bibtex-field-name "\\)[ \t]*=") |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1187 1 font-lock-comment-face) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1188 ;; field names |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1189 (,(concat "^[ \t]*\\(" bibtex-field-name "\\)[ \t]*=") |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1190 1 font-lock-variable-name-face) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1191 ;; url |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
1192 (bibtex-font-lock-url) (bibtex-font-lock-crossref)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1193 "*Default expressions to highlight in BibTeX mode.") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1194 |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1195 (defvar bibtex-font-lock-url-regexp |
57815 | 1196 ;; Assume that field names begin at the beginning of a line. |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
1197 (concat "^[ \t]*" |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
1198 (regexp-opt (delete-dups (mapcar 'caar bibtex-generate-url-list)) t) |
57815 | 1199 "[ \t]*=[ \t]*") |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1200 "Regexp for `bibtex-font-lock-url'.") |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1201 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1202 (defvar bibtex-string-empty-key nil |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1203 "If non-nil, `bibtex-parse-string' accepts empty key.") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1204 |
71044
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
1205 (defvar bibtex-sort-entry-class-alist nil |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1206 "Alist mapping entry types to their sorting index. |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1207 Auto-generated from `bibtex-sort-entry-class'. |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1208 Used when `bibtex-maintain-sorted-entries' is `entry-class'.") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1209 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1210 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1211 ;; Support for hideshow minor mode |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1212 (defun bibtex-hs-forward-sexp (arg) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1213 "Replacement for `forward-sexp' to be used by `hs-minor-mode'. |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1214 ARG is ignored." |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1215 (if (looking-at "@\\S(*\\s(") |
57815 | 1216 (goto-char (1- (match-end 0)))) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1217 (forward-sexp 1)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1218 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1219 (add-to-list |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1220 'hs-special-modes-alist |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1221 '(bibtex-mode "@\\S(*\\s(" "\\s)" nil bibtex-hs-forward-sexp nil)) |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
1222 |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
1223 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1224 (defun bibtex-parse-association (parse-lhs parse-rhs) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1225 "Parse a string of the format <left-hand-side = right-hand-side>. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1226 The functions PARSE-LHS and PARSE-RHS are used to parse the corresponding |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1227 substrings. These functions are expected to return nil if parsing is not |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1228 successful. If the returned values of both functions are non-nil, |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1229 return a cons pair of these values. Do not move point." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1230 (save-match-data |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1231 (save-excursion |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1232 (let ((left (funcall parse-lhs)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1233 right) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1234 (if (and left |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1235 (looking-at "[ \t\n]*=[ \t\n]*") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1236 (goto-char (match-end 0)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1237 (setq right (funcall parse-rhs))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1238 (cons left right)))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1239 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1240 (defun bibtex-parse-field-name () |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1241 "Parse the name part of a BibTeX field. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1242 If the field name is found, return a triple consisting of the position of the |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1243 very first character of the match, the actual starting position of the name |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1244 part and end position of the match. Move point to end of field name. |
59733
96d73eb02751
(bibtex-format-entry): Use `bibtex-empty-field-re' only on the text of
Lute Kamstra <lute@gnu.org>
parents:
58772
diff
changeset
|
1245 If `bibtex-autoadd-commas' is non-nil add missing comma at end of preceding |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1246 BibTeX field as necessary." |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1247 (cond ((looking-at bibtex-name-part) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1248 (goto-char (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1249 (list (match-beginning 0) (match-beginning 1) (match-end 0))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1250 ;; Maybe add a missing comma. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1251 ((and bibtex-autoadd-commas |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1252 (looking-at (concat "[ \t\n]*\\(?:" bibtex-field-name |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1253 "\\)[ \t\n]*="))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1254 (skip-chars-backward " \t\n") |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1255 ;; It can be confusing if non-editing commands try to |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1256 ;; modify the buffer. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1257 (if buffer-read-only |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1258 (error "Comma missing at buffer position %s" (point))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1259 (insert ",") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1260 (forward-char -1) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1261 ;; Now try again. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1262 (bibtex-parse-field-name)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1263 |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1264 (defconst bibtex-braced-string-syntax-table |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1265 (let ((st (make-syntax-table))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1266 (modify-syntax-entry ?\{ "(}" st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1267 (modify-syntax-entry ?\} "){" st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1268 (modify-syntax-entry ?\[ "." st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1269 (modify-syntax-entry ?\] "." st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1270 (modify-syntax-entry ?\( "." st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1271 (modify-syntax-entry ?\) "." st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1272 (modify-syntax-entry ?\\ "." st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1273 (modify-syntax-entry ?\" "." st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1274 st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1275 "Syntax-table to parse matched braces.") |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1276 |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1277 (defconst bibtex-quoted-string-syntax-table |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1278 (let ((st (make-syntax-table))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1279 (modify-syntax-entry ?\\ "\\" st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1280 (modify-syntax-entry ?\" "\"" st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1281 st) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1282 "Syntax-table to parse matched quotes.") |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1283 |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1284 (defun bibtex-parse-field-string () |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1285 "Parse a BibTeX field string enclosed by braces or quotes. |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1286 If a syntactically correct string is found, a pair containing the start and |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1287 end position of the field string is returned, nil otherwise. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1288 Do not move point." |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1289 (let ((end-point |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1290 (or (and (eq (following-char) ?\") |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1291 (save-excursion |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1292 (with-syntax-table bibtex-quoted-string-syntax-table |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1293 (forward-sexp 1)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1294 (point))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1295 (and (eq (following-char) ?\{) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1296 (save-excursion |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1297 (with-syntax-table bibtex-braced-string-syntax-table |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1298 (forward-sexp 1)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1299 (point)))))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1300 (if end-point |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1301 (cons (point) end-point)))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1302 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1303 (defun bibtex-parse-field-text () |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1304 "Parse the text part of a BibTeX field. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1305 The text part is either a string, or an empty string, or a constant followed |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1306 by one or more <# (string|constant)> pairs. If a syntactically correct text |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1307 is found, a pair containing the start and end position of the text is |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1308 returned, nil otherwise. Move point to end of field text." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1309 (let ((starting-point (point)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1310 end-point failure boundaries) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1311 (while (not (or end-point failure)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1312 (cond ((looking-at bibtex-field-const) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1313 (goto-char (match-end 0))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1314 ((setq boundaries (bibtex-parse-field-string)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1315 (goto-char (cdr boundaries))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1316 ((setq failure t))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1317 (if (looking-at "[ \t\n]*#[ \t\n]*") |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1318 (goto-char (match-end 0)) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1319 (setq end-point (point)))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1320 (skip-chars-forward " \t\n") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1321 (if (and (not failure) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1322 end-point) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1323 (list starting-point end-point (point))))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1324 |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1325 (defun bibtex-parse-field () |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1326 "Parse the BibTeX field beginning at the position of point. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1327 If a syntactically correct field is found, return a cons pair containing |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1328 the boundaries of the name and text parts of the field. Do not move point." |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1329 (bibtex-parse-association 'bibtex-parse-field-name |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1330 'bibtex-parse-field-text)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1331 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1332 (defsubst bibtex-start-of-field (bounds) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1333 (nth 0 (car bounds))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1334 (defsubst bibtex-start-of-name-in-field (bounds) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1335 (nth 1 (car bounds))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1336 (defsubst bibtex-end-of-name-in-field (bounds) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1337 (nth 2 (car bounds))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1338 (defsubst bibtex-start-of-text-in-field (bounds) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1339 (nth 1 bounds)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1340 (defsubst bibtex-end-of-text-in-field (bounds) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1341 (nth 2 bounds)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1342 (defsubst bibtex-end-of-field (bounds) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1343 (nth 3 bounds)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1344 |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1345 (defun bibtex-search-forward-field (name &optional bound) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1346 "Search forward to find a BibTeX field of name NAME. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1347 If a syntactically correct field is found, return a pair containing |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1348 the boundaries of the name and text parts of the field. The search |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1349 is limited by optional arg BOUND. If BOUND is t the search is limited |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1350 by the end of the current entry. Do not move point." |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1351 (save-match-data |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1352 (save-excursion |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1353 (if (eq bound t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1354 (let ((regexp (concat bibtex-name-part "[ \t\n]*=\\|" |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1355 bibtex-any-entry-maybe-empty-head)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1356 (case-fold-search t) bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1357 (catch 'done |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1358 (if (looking-at "[ \t]*@") (goto-char (match-end 0))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1359 (while (and (not bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1360 (re-search-forward regexp nil t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1361 (if (match-beginning 2) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1362 ;; We found a new entry |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1363 (throw 'done nil) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1364 ;; We found a field |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1365 (goto-char (match-beginning 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1366 (setq bounds (bibtex-parse-field)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1367 ;; Step through all fields so that we cannot overshoot. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1368 (while bounds |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1369 (goto-char (bibtex-start-of-name-in-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1370 (if (looking-at name) (throw 'done bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1371 (goto-char (bibtex-end-of-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1372 (setq bounds (bibtex-parse-field))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1373 ;; Bounded search or bound is nil (i.e. we cannot overshoot). |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1374 ;; Indeed, the search is bounded when `bibtex-search-forward-field' |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1375 ;; is called many times. So we optimize this part of this function. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1376 (let ((name-part (concat ",[ \t\n]*\\(" name "\\)[ \t\n]*=[ \t\n]*")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1377 (case-fold-search t) left right) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1378 (while (and (not right) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1379 (re-search-forward name-part bound t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1380 (setq left (list (match-beginning 0) (match-beginning 1) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1381 (match-end 1)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1382 ;; Don't worry that the field text could be past bound. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1383 right (bibtex-parse-field-text))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1384 (if right (cons left right))))))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1385 |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1386 (defun bibtex-search-backward-field (name &optional bound) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1387 "Search backward to find a BibTeX field of name NAME. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1388 If a syntactically correct field is found, return a pair containing |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1389 the boundaries of the name and text parts of the field. The search |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1390 is limited by the optional arg BOUND. If BOUND is t the search is |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1391 limited by the beginning of the current entry. Do not move point." |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1392 (save-match-data |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1393 (if (eq bound t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1394 (setq bound (save-excursion (bibtex-beginning-of-entry)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1395 (let ((name-part (concat ",[ \t\n]*\\(" name "\\)[ \t\n]*=[ \t\n]*")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1396 (case-fold-search t) left right) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1397 (save-excursion |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1398 ;; the parsing functions are not designed for parsing backwards :-( |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1399 (when (search-backward "," bound t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1400 (or (save-excursion |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1401 (when (looking-at name-part) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1402 (setq left (list (match-beginning 0) (match-beginning 1) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1403 (match-end 1))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1404 (goto-char (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1405 (setq right (bibtex-parse-field-text)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1406 (while (and (not right) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1407 (re-search-backward name-part bound t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1408 (setq left (list (match-beginning 0) (match-beginning 1) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1409 (match-end 1))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1410 (save-excursion |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1411 (goto-char (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1412 (setq right (bibtex-parse-field-text))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1413 (if right (cons left right))))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1414 |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1415 (defun bibtex-name-in-field (bounds &optional remove-opt-alt) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1416 "Get content of name in BibTeX field defined via BOUNDS. |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1417 If optional arg REMOVE-OPT-ALT is non-nil remove \"OPT\" and \"ALT\"." |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1418 (let ((name (buffer-substring-no-properties |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1419 (bibtex-start-of-name-in-field bounds) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1420 (bibtex-end-of-name-in-field bounds)))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1421 (if (and remove-opt-alt |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1422 (string-match "\\`\\(OPT\\|ALT\\)" name)) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1423 (substring name 3) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1424 name))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1425 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1426 (defun bibtex-text-in-field-bounds (bounds &optional content) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1427 "Get text in BibTeX field defined via BOUNDS. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1428 If optional arg CONTENT is non-nil extract content of field |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1429 by removing field delimiters and concatenating the resulting string. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1430 If `bibtex-expand-strings' is non-nil, also expand BibTeX strings." |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1431 (if content |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1432 (save-excursion |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1433 (goto-char (bibtex-start-of-text-in-field bounds)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1434 (let ((epoint (bibtex-end-of-text-in-field bounds)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1435 content opoint) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1436 (while (< (setq opoint (point)) epoint) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1437 (if (looking-at bibtex-field-const) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1438 (let ((mtch (match-string-no-properties 0))) |
67897
823f54b91fe2
(bibtex-text-in-field-bounds): Handle case that assoc-string returns
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67894
diff
changeset
|
1439 (push (or (if bibtex-expand-strings |
823f54b91fe2
(bibtex-text-in-field-bounds): Handle case that assoc-string returns
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67894
diff
changeset
|
1440 (cdr (assoc-string mtch (bibtex-strings) t))) |
823f54b91fe2
(bibtex-text-in-field-bounds): Handle case that assoc-string returns
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67894
diff
changeset
|
1441 mtch) content) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1442 (goto-char (match-end 0))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1443 (let ((bounds (bibtex-parse-field-string))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1444 (push (buffer-substring-no-properties |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1445 (1+ (car bounds)) (1- (cdr bounds))) content) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1446 (goto-char (cdr bounds)))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1447 (re-search-forward "\\=[ \t\n]*#[ \t\n]*" nil t)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1448 (apply 'concat (nreverse content)))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1449 (buffer-substring-no-properties (bibtex-start-of-text-in-field bounds) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1450 (bibtex-end-of-text-in-field bounds)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1451 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1452 (defun bibtex-text-in-field (field &optional follow-crossref) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1453 "Get content of field FIELD of current BibTeX entry. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1454 Return nil if not found. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1455 If optional arg FOLLOW-CROSSREF is non-nil, follow crossref." |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1456 (save-excursion |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1457 (let* ((end (if follow-crossref (bibtex-end-of-entry) t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1458 (beg (bibtex-beginning-of-entry)) ; move point |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1459 (bounds (bibtex-search-forward-field field end))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1460 (cond (bounds (bibtex-text-in-field-bounds bounds t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1461 ((and follow-crossref |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1462 (progn (goto-char beg) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1463 (setq bounds (bibtex-search-forward-field |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1464 "\\(OPT\\)?crossref" end)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1465 (let ((crossref-field (bibtex-text-in-field-bounds bounds t))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1466 (if (bibtex-find-crossref crossref-field) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1467 ;; Do not pass FOLLOW-CROSSREF because we want |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1468 ;; to follow crossrefs only one level of recursion. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1469 (bibtex-text-in-field field)))))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1470 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1471 (defun bibtex-parse-string-prefix () |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1472 "Parse the prefix part of a BibTeX string entry, including reference key. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1473 If the string prefix is found, return a triple consisting of the position of |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1474 the very first character of the match, the actual starting position of the |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1475 reference key and the end position of the match. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1476 If `bibtex-string-empty-key' is non-nil accept empty string key." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1477 (let ((case-fold-search t)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1478 (if (looking-at bibtex-string-type) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1479 (let ((start (point))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1480 (goto-char (match-end 0)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1481 (cond ((looking-at bibtex-reference-key) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1482 (goto-char (match-end 0)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1483 (list start |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1484 (match-beginning 0) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1485 (match-end 0))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1486 ((and bibtex-string-empty-key |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1487 (looking-at "=")) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1488 (skip-chars-backward " \t\n") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1489 (list start (point) (point)))))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1490 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1491 (defun bibtex-parse-string-postfix () |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1492 "Parse the postfix part of a BibTeX string entry, including the text. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1493 If the string postfix is found, return a triple consisting of the position of |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1494 the actual starting and ending position of the text and the very last |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1495 character of the string entry. Move point past BibTeX string entry." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1496 (let* ((case-fold-search t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1497 (bounds (bibtex-parse-field-text))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1498 (when bounds |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1499 (goto-char (nth 1 bounds)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1500 (when (looking-at "[ \t\n]*[})]") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1501 (goto-char (match-end 0)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1502 (list (car bounds) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1503 (nth 1 bounds) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1504 (match-end 0)))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1505 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1506 (defun bibtex-parse-string (&optional empty-key) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1507 "Parse a BibTeX string entry beginning at the position of point. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1508 If a syntactically correct entry is found, return a cons pair containing |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1509 the boundaries of the reference key and text parts of the entry. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1510 If EMPTY-KEY is non-nil, key may be empty. Do not move point." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1511 (let ((bibtex-string-empty-key empty-key)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1512 (bibtex-parse-association 'bibtex-parse-string-prefix |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1513 'bibtex-parse-string-postfix))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1514 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1515 (defun bibtex-search-forward-string (&optional empty-key) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1516 "Search forward to find a BibTeX string entry. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1517 If a syntactically correct entry is found, a pair containing the boundaries of |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1518 the reference key and text parts of the string is returned. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1519 If EMPTY-KEY is non-nil, key may be empty. Do not move point." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1520 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1521 (save-match-data |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1522 (let ((case-fold-search t) bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1523 (while (and (not bounds) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1524 (search-forward-regexp bibtex-string-type nil t)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1525 (save-excursion (goto-char (match-beginning 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1526 (setq bounds (bibtex-parse-string empty-key)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1527 bounds)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1528 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1529 (defun bibtex-reference-key-in-string (bounds) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1530 "Return the key part of a BibTeX string defined via BOUNDS" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1531 (buffer-substring-no-properties (nth 1 (car bounds)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1532 (nth 2 (car bounds)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1533 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1534 (defun bibtex-text-in-string (bounds &optional content) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1535 "Get text in BibTeX string field defined via BOUNDS. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1536 If optional arg CONTENT is non-nil extract content |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1537 by removing field delimiters and concatenating the resulting string. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1538 If `bibtex-expand-strings' is non-nil, also expand BibTeX strings." |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1539 (bibtex-text-in-field-bounds bounds content)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1540 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1541 (defsubst bibtex-start-of-text-in-string (bounds) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1542 (nth 0 (cdr bounds))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1543 (defsubst bibtex-end-of-text-in-string (bounds) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1544 (nth 1 (cdr bounds))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1545 (defsubst bibtex-end-of-string (bounds) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1546 (nth 2 (cdr bounds))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1547 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1548 (defsubst bibtex-type-in-head () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1549 "Extract BibTeX type in head." |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1550 ;; ignore @ |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1551 (buffer-substring-no-properties (1+ (match-beginning bibtex-type-in-head)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1552 (match-end bibtex-type-in-head))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1553 |
57815 | 1554 (defsubst bibtex-key-in-head (&optional empty) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1555 "Extract BibTeX key in head. Return optional arg EMPTY if key is empty." |
57815 | 1556 (or (match-string-no-properties bibtex-key-in-head) |
1557 empty)) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1558 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1559 (defun bibtex-parse-preamble () |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1560 "Parse BibTeX preamble. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1561 Point must be at beginning of preamble. Do not move point." |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1562 (let ((case-fold-search t)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1563 (when (looking-at bibtex-preamble-prefix) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1564 (let ((start (match-beginning 0)) (pref-start (match-beginning 1)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1565 (bounds (save-excursion (goto-char (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1566 (bibtex-parse-string-postfix)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1567 (if bounds (cons (list start pref-start) bounds)))))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1568 |
12700
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
1569 ;; Helper Functions |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
1570 |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1571 (defsubst bibtex-string= (str1 str2) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1572 "Return t if STR1 and STR2 are equal, ignoring case." |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1573 (eq t (compare-strings str1 0 nil str2 0 nil t))) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1574 |
18247
ae094c1a4334
(bibtex-delete-whitespace, bibtex-current-line)
Richard M. Stallman <rms@gnu.org>
parents:
18212
diff
changeset
|
1575 (defun bibtex-delete-whitespace () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1576 "Delete all whitespace starting at point." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1577 (if (looking-at "[ \t\n]+") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1578 (delete-region (point) (match-end 0)))) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1579 |
18247
ae094c1a4334
(bibtex-delete-whitespace, bibtex-current-line)
Richard M. Stallman <rms@gnu.org>
parents:
18212
diff
changeset
|
1580 (defun bibtex-current-line () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1581 "Compute line number of point regardless whether the buffer is narrowed." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1582 (+ (count-lines 1 (point)) |
57815 | 1583 (if (bolp) 1 0))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1584 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1585 (defun bibtex-valid-entry (&optional empty-key) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1586 "Parse a valid BibTeX entry (maybe without key if EMPTY-KEY is t). |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1587 A valid entry is a syntactical correct one with type contained in |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1588 `bibtex-entry-field-alist'. Ignore @String and @Preamble entries. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1589 Return a cons pair with buffer positions of beginning and end of entry |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1590 if a valid entry is found, nil otherwise. Do not move point. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1591 After a call to this function `match-data' corresponds to the header |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1592 of the entry, see regexp `bibtex-entry-head'." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1593 (let ((case-fold-search t) end) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1594 (if (looking-at (if empty-key bibtex-entry-maybe-empty-head |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1595 bibtex-entry-head)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1596 (save-excursion |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1597 (save-match-data |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1598 (goto-char (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1599 (let ((entry-closer |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1600 (if (save-excursion |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1601 (goto-char (match-end bibtex-type-in-head)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1602 (looking-at "[ \t]*(")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1603 ",?[ \t\n]*)" ;; entry opened with `(' |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1604 ",?[ \t\n]*}")) ;; entry opened with `{' |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1605 bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1606 (skip-chars-forward " \t\n") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1607 ;; loop over all BibTeX fields |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1608 (while (setq bounds (bibtex-parse-field)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1609 (goto-char (bibtex-end-of-field bounds))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1610 ;; This matches the infix* part. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1611 (if (looking-at entry-closer) (setq end (match-end 0))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1612 (if end (cons (match-beginning 0) end)))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1613 |
18247
ae094c1a4334
(bibtex-delete-whitespace, bibtex-current-line)
Richard M. Stallman <rms@gnu.org>
parents:
18212
diff
changeset
|
1614 (defun bibtex-skip-to-valid-entry (&optional backward) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1615 "Move point to beginning of the next valid BibTeX entry. |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1616 Do not move if we are already at beginning of a valid BibTeX entry. |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1617 With optional argument BACKWARD non-nil, move backward to |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
1618 beginning of previous valid one. A valid entry is a syntactical correct one |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1619 with type contained in `bibtex-entry-field-alist' or, if |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1620 `bibtex-sort-ignore-string-entries' is nil, a syntactical correct string |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1621 entry. Return buffer position of beginning and end of entry if a valid |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1622 entry is found, nil otherwise." |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1623 (interactive "P") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1624 (let ((case-fold-search t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1625 found bounds) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1626 (beginning-of-line) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1627 ;; Loop till we look at a valid entry. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1628 (while (not (or found (if backward (bobp) (eobp)))) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1629 (cond ((setq found (or (bibtex-valid-entry) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1630 (and (not bibtex-sort-ignore-string-entries) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1631 (setq bounds (bibtex-parse-string)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1632 (cons (bibtex-start-of-field bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1633 (bibtex-end-of-string bounds)))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1634 (backward (re-search-backward "^[ \t]*@" nil 'move)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1635 (t (if (re-search-forward "\n\\([ \t]*@\\)" nil 'move) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1636 (goto-char (match-beginning 1)))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1637 found)) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
1638 |
18247
ae094c1a4334
(bibtex-delete-whitespace, bibtex-current-line)
Richard M. Stallman <rms@gnu.org>
parents:
18212
diff
changeset
|
1639 (defun bibtex-map-entries (fun) |
57815 | 1640 "Call FUN for each BibTeX entry in buffer (possibly narrowed). |
1641 FUN is called with three arguments, the key of the entry and the buffer | |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1642 positions of beginning and end of entry. Also, point is at beginning of |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1643 entry and `match-data' corresponds to the header of the entry, |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1644 see regexp `bibtex-entry-head'. If `bibtex-sort-ignore-string-entries' |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1645 is non-nil, FUN is not called for @String entries." |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1646 (let ((case-fold-search t) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1647 found) |
57815 | 1648 (save-excursion |
1649 (goto-char (point-min)) | |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1650 (while (setq found (bibtex-skip-to-valid-entry)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1651 (looking-at bibtex-any-entry-maybe-empty-head) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1652 (funcall fun (bibtex-key-in-head "") (car found) (cdr found)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1653 (goto-char (cdr found)))))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1654 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1655 (defun bibtex-progress-message (&optional flag interval) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1656 "Echo a message about progress of current buffer. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1657 If FLAG is a string, the message is initialized (in this case a |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1658 value for INTERVAL may be given as well (if not this is set to 5)). |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1659 If FLAG is `done', the message is deinitialized. |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1660 If FLAG is nil, a message is echoed if point was incremented at least |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1661 `bibtex-progress-interval' percent since last message was echoed." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1662 (cond ((stringp flag) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1663 (setq bibtex-progress-lastmes flag |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1664 bibtex-progress-interval (or interval 5) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1665 bibtex-progress-lastperc 0)) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1666 ((eq flag 'done) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1667 (message "%s (done)" bibtex-progress-lastmes) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1668 (setq bibtex-progress-lastmes nil)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1669 (t |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1670 (let* ((size (- (point-max) (point-min))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1671 (perc (if (= size 0) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1672 100 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1673 (/ (* 100 (- (point) (point-min))) size)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1674 (when (>= perc (+ bibtex-progress-lastperc |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1675 bibtex-progress-interval)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1676 (setq bibtex-progress-lastperc perc) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1677 (message "%s (%d%%)" bibtex-progress-lastmes perc)))))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1678 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1679 (defun bibtex-field-left-delimiter () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1680 "Return a string dependent on `bibtex-field-delimiters'." |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1681 (if (eq bibtex-field-delimiters 'braces) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1682 "{" |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1683 "\"")) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1684 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1685 (defun bibtex-field-right-delimiter () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1686 "Return a string dependent on `bibtex-field-delimiters'." |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1687 (if (eq bibtex-field-delimiters 'braces) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1688 "}" |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1689 "\"")) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1690 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1691 (defun bibtex-entry-left-delimiter () |
57815 | 1692 "Return a string dependent on `bibtex-entry-delimiters'." |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1693 (if (eq bibtex-entry-delimiters 'braces) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1694 "{" |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1695 "(")) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1696 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1697 (defun bibtex-entry-right-delimiter () |
57815 | 1698 "Return a string dependent on `bibtex-entry-delimiters'." |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1699 (if (eq bibtex-entry-delimiters 'braces) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1700 "}" |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1701 ")")) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1702 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1703 (defun bibtex-flash-head (prompt) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1704 "Flash at BibTeX entry head before point, if exists." |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1705 (let ((case-fold-search t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1706 (pnt (point))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1707 (save-excursion |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1708 (bibtex-beginning-of-entry) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1709 (when (and (looking-at bibtex-any-entry-maybe-empty-head) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1710 (< (point) pnt)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1711 (goto-char (match-beginning bibtex-type-in-head)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1712 (if (pos-visible-in-window-p (point)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1713 (sit-for 1) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1714 (message "%s%s" prompt (buffer-substring-no-properties |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1715 (point) (match-end bibtex-key-in-head)))))))) |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
1716 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1717 (defun bibtex-make-optional-field (field) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1718 "Make an optional field named FIELD in current BibTeX entry." |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1719 (if (consp field) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1720 (bibtex-make-field (cons (concat "OPT" (car field)) (cdr field))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1721 (bibtex-make-field (concat "OPT" field)))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1722 |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
1723 (defun bibtex-move-outside-of-entry () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1724 "Make sure point is outside of a BibTeX entry." |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
1725 (let ((orig-point (point))) |
26711
eac840d283b6
(bibtex-hs-forward-sexp): Added to support
Gerd Moellmann <gerd@gnu.org>
parents:
25444
diff
changeset
|
1726 (bibtex-end-of-entry) |
52891
a6806242012a
(bibtex-move-outside-of-entry):
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
1727 (when (< (point) orig-point) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1728 ;; We moved backward, so we weren't inside an entry to begin with. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1729 ;; Leave point at the beginning of a line, and preferably |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1730 ;; at the beginning of a paragraph. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1731 (goto-char orig-point) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1732 (beginning-of-line 1) |
52891
a6806242012a
(bibtex-move-outside-of-entry):
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
1733 (unless (= ?\n (char-before (1- (point)))) |
a6806242012a
(bibtex-move-outside-of-entry):
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
1734 (re-search-forward "^[ \t]*[@\n]" nil 'move) |
a6806242012a
(bibtex-move-outside-of-entry):
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
1735 (backward-char 1))) |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
1736 (skip-chars-forward " \t\n"))) |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
1737 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1738 (defun bibtex-beginning-of-first-entry () |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1739 "Go to beginning of line of first BibTeX entry in buffer. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1740 If `bibtex-sort-ignore-string-entries' is non-nil, @String entries |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1741 are ignored. Return point" |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
1742 (goto-char (point-min)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1743 (bibtex-skip-to-valid-entry) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1744 (point)) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
1745 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1746 (defun bibtex-enclosing-field (&optional comma noerr) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1747 "Search for BibTeX field enclosing point. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1748 For `bibtex-mode''s internal algorithms, a field begins at the comma |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1749 following the preceding field. Usually, this is not what the user expects. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1750 Thus if COMMA is non-nil, the \"current field\" includes the terminating comma. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1751 Unless NOERR is non-nil, signal an error if no enclosing field is found. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1752 On success return bounds, nil otherwise. Do not move point." |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1753 (save-excursion |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1754 (when comma |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1755 (end-of-line) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1756 (skip-chars-backward " \t") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1757 (if (= (preceding-char) ?,) (forward-char -1))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1758 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1759 (let ((bounds (bibtex-search-backward-field bibtex-field-name t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1760 (cond ((and bounds |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1761 (<= (bibtex-start-of-field bounds) (point)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1762 (>= (bibtex-end-of-field bounds) (point))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1763 bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1764 ((not noerr) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1765 (error "Can't find enclosing BibTeX field")))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1766 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1767 (defun bibtex-beginning-first-field (&optional beg) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1768 "Move point to beginning of first field. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1769 Optional arg BEG is beginning of entry." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1770 (if beg (goto-char beg) (bibtex-beginning-of-entry)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1771 (looking-at bibtex-any-entry-maybe-empty-head) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1772 (goto-char (match-end 0))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1773 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1774 (defun bibtex-insert-kill (n &optional comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1775 "Reinsert the Nth stretch of killed BibTeX text (field or entry). |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1776 Optional arg COMMA is as in `bibtex-enclosing-field'." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1777 (unless bibtex-last-kill-command (error "BibTeX kill ring is empty")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1778 (let ((fun (lambda (kryp kr) ;; adapted from `current-kill' |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1779 (car (set kryp (nthcdr (mod (- n (length (eval kryp))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1780 (length kr)) kr)))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1781 (if (eq bibtex-last-kill-command 'field) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1782 (progn |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1783 ;; insert past the current field |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1784 (goto-char (bibtex-end-of-field (bibtex-enclosing-field comma))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1785 (set-mark (point)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1786 (message "Mark set") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1787 (bibtex-make-field (funcall fun 'bibtex-field-kill-ring-yank-pointer |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1788 bibtex-field-kill-ring) t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1789 ;; insert past the current entry |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1790 (bibtex-skip-to-valid-entry) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1791 (set-mark (point)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1792 (message "Mark set") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1793 (insert (funcall fun 'bibtex-entry-kill-ring-yank-pointer |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1794 bibtex-entry-kill-ring))))) |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
1795 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1796 (defun bibtex-format-entry () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1797 "Helper function for `bibtex-clean-entry'. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1798 Formats current entry according to variable `bibtex-entry-format'." |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1799 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1800 (save-restriction |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1801 (bibtex-narrow-to-entry) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1802 (let ((case-fold-search t) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1803 (format (if (eq bibtex-entry-format t) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1804 '(realign opts-or-alts required-fields |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1805 numerical-fields |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1806 last-comma page-dashes delimiters |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1807 unify-case inherit-booktitle) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1808 bibtex-entry-format)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1809 crossref-key bounds alternatives-there non-empty-alternative |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1810 entry-list req-field-list field-list) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1811 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1812 ;; identify entry type |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1813 (goto-char (point-min)) |
70841
2a874a2efaf4
(bibtex-format-entry, bibtex-clean-entry):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70837
diff
changeset
|
1814 (or (re-search-forward bibtex-entry-type nil t) |
2a874a2efaf4
(bibtex-format-entry, bibtex-clean-entry):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70837
diff
changeset
|
1815 (error "Not inside a BibTeX entry")) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1816 (let ((beg-type (1+ (match-beginning 0))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1817 (end-type (match-end 0))) |
55730
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1818 (setq entry-list (assoc-string (buffer-substring-no-properties |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1819 beg-type end-type) |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1820 bibtex-entry-field-alist |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1821 t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1822 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1823 ;; unify case of entry name |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1824 (when (memq 'unify-case format) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1825 (delete-region beg-type end-type) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1826 (insert (car entry-list))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1827 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1828 ;; update left entry delimiter |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1829 (when (memq 'delimiters format) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1830 (goto-char end-type) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1831 (skip-chars-forward " \t\n") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1832 (delete-char 1) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1833 (insert (bibtex-entry-left-delimiter)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1834 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1835 ;; determine if entry has crossref field and if at least |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1836 ;; one alternative is non-empty |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1837 (goto-char (point-min)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1838 (let* ((fields-alist (bibtex-parse-entry t)) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1839 (field (assoc-string "crossref" fields-alist t))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1840 (setq crossref-key (and field |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1841 (not (equal "" (cdr field))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1842 (cdr field)) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1843 req-field-list (if crossref-key |
57815 | 1844 (nth 0 (nth 2 entry-list)) ; crossref part |
1845 (nth 0 (nth 1 entry-list)))) ; required part | |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1846 |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1847 (dolist (rfield req-field-list) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1848 (when (nth 3 rfield) ; we should have an alternative |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1849 (setq alternatives-there t |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1850 field (assoc-string (car rfield) fields-alist t)) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1851 (if (and field |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1852 (not (equal "" (cdr field)))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1853 (cond ((not non-empty-alternative) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1854 (setq non-empty-alternative t)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1855 ((memq 'required-fields format) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1856 (error "More than one non-empty alternative"))))))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1857 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
1858 (if (and alternatives-there |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1859 (not non-empty-alternative) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1860 (memq 'required-fields format)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1861 (error "All alternatives are empty")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1862 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1863 ;; process all fields |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1864 (bibtex-beginning-first-field (point-min)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
1865 (while (setq bounds (bibtex-parse-field)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1866 (let* ((beg-field (copy-marker (bibtex-start-of-field bounds))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1867 (end-field (copy-marker (bibtex-end-of-field bounds) t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1868 (beg-name (copy-marker (bibtex-start-of-name-in-field bounds))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1869 (end-name (copy-marker (bibtex-end-of-name-in-field bounds))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1870 (beg-text (copy-marker (bibtex-start-of-text-in-field bounds))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1871 (end-text (copy-marker (bibtex-end-of-text-in-field bounds) t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1872 (opt-alt (string-match "OPT\\|ALT" |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1873 (buffer-substring-no-properties |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1874 beg-name (+ beg-name 3)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1875 (field-name (buffer-substring-no-properties |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1876 (if opt-alt (+ beg-name 3) beg-name) end-name)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
1877 (empty-field (equal "" (bibtex-text-in-field-bounds bounds t))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1878 deleted) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1879 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1880 ;; We have more elegant high-level functions for several |
57815 | 1881 ;; tasks done by bibtex-format-entry. However, they contain |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1882 ;; quite some redundancy compared with what we need to do |
57815 | 1883 ;; anyway. So for speed-up we avoid using them. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1884 |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1885 (if (memq 'opts-or-alts format) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1886 (cond ((and empty-field |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1887 (or opt-alt |
55730
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1888 (let ((field (assoc-string |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1889 field-name req-field-list t))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1890 (or (not field) ; OPT field |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1891 (nth 3 field))))) ; ALT field |
57815 | 1892 ;; Either it is an empty ALT field. Then we have checked |
1893 ;; already that we have one non-empty alternative. Or it | |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1894 ;; is an empty OPT field that we do not miss anyway. |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1895 ;; So we can safely delete this field. |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1896 (delete-region beg-field end-field) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1897 (setq deleted t)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1898 ;; otherwise: not empty, delete "OPT" or "ALT" |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1899 (opt-alt |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1900 (goto-char beg-name) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1901 (delete-char 3)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1902 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1903 (unless deleted |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1904 (push field-name field-list) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1905 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1906 ;; remove delimiters from purely numerical fields |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1907 (when (and (memq 'numerical-fields format) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1908 (progn (goto-char beg-text) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1909 (looking-at "\\(\"[0-9]+\"\\)\\|\\({[0-9]+}\\)"))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1910 (goto-char end-text) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1911 (delete-char -1) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1912 (goto-char beg-text) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1913 (delete-char 1)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1914 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1915 ;; update delimiters |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1916 (when (memq 'delimiters format) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1917 (goto-char beg-text) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1918 (when (looking-at "[{\"]") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1919 (delete-char 1) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1920 (insert (bibtex-field-left-delimiter))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1921 (goto-char (1- (marker-position end-text))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1922 (when (looking-at "[}\"]") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1923 (delete-char 1) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1924 (insert (bibtex-field-right-delimiter)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1925 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1926 ;; update page dashes |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1927 (if (and (memq 'page-dashes format) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1928 (bibtex-string= field-name "pages") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1929 (progn (goto-char beg-text) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1930 (looking-at |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1931 "\\([\"{][0-9]+\\)[ \t\n]*--?[ \t\n]*\\([0-9]+[\"}]\\)"))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1932 (replace-match "\\1-\\2")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1933 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1934 ;; use book title of crossref'd entry |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1935 (if (and (memq 'inherit-booktitle format) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1936 empty-field |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1937 (bibtex-string= field-name "booktitle") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1938 crossref-key) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1939 (let ((title (save-excursion |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1940 (save-restriction |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1941 (widen) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1942 (if (bibtex-find-entry crossref-key t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
1943 (bibtex-text-in-field "title")))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1944 (when title |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1945 (setq empty-field nil) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1946 (goto-char (1+ beg-text)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1947 (insert title)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1948 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1949 ;; Use booktitle to set a missing title. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1950 (if (and empty-field |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
1951 (bibtex-string= field-name "title")) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1952 (let ((booktitle (bibtex-text-in-field "booktitle"))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1953 (when booktitle |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1954 (setq empty-field nil) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1955 (goto-char (1+ beg-text)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
1956 (insert booktitle)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1957 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1958 ;; if empty field, complain |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1959 (if (and empty-field |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1960 (memq 'required-fields format) |
55730
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1961 (assoc-string field-name req-field-list t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1962 (error "Mandatory field `%s' is empty" field-name)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1963 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1964 ;; unify case of field name |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1965 (if (memq 'unify-case format) |
55730
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1966 (let ((fname (car (assoc-string |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1967 field-name |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1968 (append (nth 0 (nth 1 entry-list)) |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1969 (nth 1 (nth 1 entry-list)) |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1970 bibtex-user-optional-fields) |
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
1971 t)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1972 (if fname |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1973 (progn |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1974 (delete-region beg-name end-name) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1975 (goto-char beg-name) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1976 (insert fname)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1977 ;; there are no rules we could follow |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1978 (downcase-region beg-name end-name)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1979 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1980 ;; update point |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1981 (goto-char end-field)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1982 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1983 ;; check whether all required fields are present |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1984 (if (memq 'required-fields format) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1985 (let ((found 0) altlist) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
1986 (dolist (fname req-field-list) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1987 (if (nth 3 fname) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1988 (push (car fname) altlist)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1989 (unless (or (member (car fname) field-list) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1990 (nth 3 fname)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1991 (error "Mandatory field `%s' is missing" (car fname)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1992 (when altlist |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1993 (dolist (fname altlist) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1994 (if (member fname field-list) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1995 (setq found (1+ found)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1996 (cond ((= found 0) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1997 (error "Alternative mandatory field `%s' is missing" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1998 altlist)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
1999 ((> found 1) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2000 (error "Alternative fields `%s' are defined %s times" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2001 altlist found)))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2002 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2003 ;; update comma after last field |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2004 (if (memq 'last-comma format) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2005 (cond ((and bibtex-comma-after-last-field |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2006 (not (looking-at ","))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2007 (insert ",")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2008 ((and (not bibtex-comma-after-last-field) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2009 (looking-at ",")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2010 (delete-char 1)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2011 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2012 ;; update right entry delimiter |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2013 (if (looking-at ",") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2014 (forward-char)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2015 (when (memq 'delimiters format) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2016 (skip-chars-forward " \t\n") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2017 (delete-char 1) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2018 (insert (bibtex-entry-right-delimiter))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2019 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2020 ;; fill entry |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2021 (if (memq 'realign format) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2022 (bibtex-fill-entry)))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2023 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2024 |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
2025 (defun bibtex-autokey-abbrev (string len) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2026 "Return an abbreviation of STRING with at least LEN characters. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2027 If LEN is positive the abbreviation is terminated only after a consonant |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2028 or at the word end. If LEN is negative the abbreviation is strictly |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2029 enforced using abs (LEN) characters. If LEN is not a number, STRING |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2030 is returned unchanged." |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2031 (cond ((or (not (numberp len)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2032 (<= (length string) (abs len))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2033 string) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2034 ((equal len 0) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2035 "") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2036 ((< len 0) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2037 (substring string 0 (abs len))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2038 (t (let* ((case-fold-search t) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2039 (abort-char (string-match "[^aeiou]" string (1- len)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2040 (if abort-char |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2041 (substring string 0 (1+ abort-char)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2042 string))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2043 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2044 (defun bibtex-autokey-get-field (field &optional change-list) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2045 "Get content of BibTeX field FIELD. Return empty string if not found. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2046 Optional arg CHANGE-LIST is a list of substitution patterns that is |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2047 applied to the content of FIELD. It is an alist with pairs |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2048 \(OLD-REGEXP . NEW-STRING\)." |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2049 (let* ((bibtex-expand-strings bibtex-autokey-expand-strings) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2050 (content (bibtex-text-in-field field bibtex-autokey-use-crossref)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2051 case-fold-search) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2052 (unless content (setq content "")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2053 (dolist (pattern change-list content) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2054 (setq content (replace-regexp-in-string (car pattern) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2055 (cdr pattern) |
57815 | 2056 content t))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2057 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2058 (defun bibtex-autokey-get-names () |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2059 "Get contents of the name field of the current entry. |
57815 | 2060 Do some modifications based on `bibtex-autokey-name-change-strings'. |
2061 Return the names as a concatenated string obeying `bibtex-autokey-names' | |
2062 and `bibtex-autokey-names-stretch'." | |
2063 (let ((names (bibtex-autokey-get-field "author\\|editor" | |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2064 bibtex-autokey-name-change-strings))) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2065 ;; Some entries do not have a name field. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2066 (if (string= "" names) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2067 names |
57815 | 2068 (let* ((case-fold-search t) |
2069 (name-list (mapcar 'bibtex-autokey-demangle-name | |
2070 (split-string names "[ \t\n]+and[ \t\n]+"))) | |
2071 additional-names) | |
2072 (unless (or (not (numberp bibtex-autokey-names)) | |
2073 (<= (length name-list) | |
2074 (+ bibtex-autokey-names | |
2075 bibtex-autokey-names-stretch))) | |
2076 ;; Take bibtex-autokey-names elements from beginning of name-list | |
2077 (setq name-list (nreverse (nthcdr (- (length name-list) | |
2078 bibtex-autokey-names) | |
2079 (nreverse name-list))) | |
2080 additional-names bibtex-autokey-additional-names)) | |
2081 (concat (mapconcat 'identity name-list | |
2082 bibtex-autokey-name-separator) | |
2083 additional-names))))) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2084 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2085 (defun bibtex-autokey-demangle-name (fullname) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2086 "Get the last part from a well-formed FULLNAME and perform abbreviations." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2087 (let* (case-fold-search |
61439
267229876c56
(bibtex-autokey-titleword-ignore, bibtex-reference-key)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61247
diff
changeset
|
2088 (name (cond ((string-match "\\([[:upper:]][^, ]*\\)[^,]*," fullname) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2089 ;; Name is of the form "von Last, First" or |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2090 ;; "von Last, Jr, First" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2091 ;; --> Take the first capital part before the comma |
51416
83476384bebd
(bibtex-member-of-regexp, bibtex-assoc-of-regexp, bibtex-format-entry)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51415
diff
changeset
|
2092 (match-string 1 fullname)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2093 ((string-match "\\([^, ]*\\)," fullname) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2094 ;; Strange name: we have a comma, but nothing capital |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2095 ;; So we accept even lowercase names |
51416
83476384bebd
(bibtex-member-of-regexp, bibtex-assoc-of-regexp, bibtex-format-entry)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51415
diff
changeset
|
2096 (match-string 1 fullname)) |
61439
267229876c56
(bibtex-autokey-titleword-ignore, bibtex-reference-key)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61247
diff
changeset
|
2097 ((string-match "\\(\\<[[:lower:]][^ ]* +\\)+\\([[:upper:]][^ ]*\\)" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2098 fullname) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2099 ;; name is of the form "First von Last", "von Last", |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2100 ;; "First von von Last", or "d'Last" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2101 ;; --> take the first capital part after the "von" parts |
51416
83476384bebd
(bibtex-member-of-regexp, bibtex-assoc-of-regexp, bibtex-format-entry)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51415
diff
changeset
|
2102 (match-string 2 fullname)) |
83476384bebd
(bibtex-member-of-regexp, bibtex-assoc-of-regexp, bibtex-format-entry)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51415
diff
changeset
|
2103 ((string-match "\\([^ ]+\\) *\\'" fullname) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2104 ;; name is of the form "First Middle Last" or "Last" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2105 ;; --> take the last token |
51416
83476384bebd
(bibtex-member-of-regexp, bibtex-assoc-of-regexp, bibtex-format-entry)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51415
diff
changeset
|
2106 (match-string 1 fullname)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2107 (t (error "Name `%s' is incorrectly formed" fullname))))) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
2108 (funcall bibtex-autokey-name-case-convert-function |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2109 (bibtex-autokey-abbrev name bibtex-autokey-name-length)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2110 |
57815 | 2111 (defun bibtex-autokey-get-year () |
2112 "Return year field contents as a string obeying `bibtex-autokey-year-length'." | |
2113 (let ((yearfield (bibtex-autokey-get-field "year"))) | |
2114 (substring yearfield (max 0 (- (length yearfield) | |
2115 bibtex-autokey-year-length))))) | |
2116 | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2117 (defun bibtex-autokey-get-title () |
57815 | 2118 "Get title field contents up to a terminator. |
2119 Return the result as a string" | |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2120 (let ((case-fold-search t) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2121 (titlestring |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2122 (bibtex-autokey-get-field "title" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2123 bibtex-autokey-titleword-change-strings))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2124 ;; ignore everything past a terminator |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2125 (if (string-match bibtex-autokey-title-terminators titlestring) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2126 (setq titlestring (substring titlestring 0 (match-beginning 0)))) |
57815 | 2127 ;; gather words from titlestring into a list. Ignore |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2128 ;; specific words and use only a specific amount of words. |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2129 (let ((counter 0) |
57815 | 2130 titlewords titlewords-extra word) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2131 (while (and (or (not (numberp bibtex-autokey-titlewords)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2132 (< counter (+ bibtex-autokey-titlewords |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2133 bibtex-autokey-titlewords-stretch))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2134 (string-match "\\b\\w+" titlestring)) |
57815 | 2135 (setq word (match-string 0 titlestring) |
2136 titlestring (substring titlestring (match-end 0))) | |
2137 ;; Ignore words matched by one of the elements of | |
2138 ;; bibtex-autokey-titleword-ignore | |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2139 (unless (let ((lst bibtex-autokey-titleword-ignore)) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2140 (while (and lst |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2141 (not (string-match (concat "\\`\\(?:" (car lst) |
57815 | 2142 "\\)\\'") word))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2143 (setq lst (cdr lst))) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2144 lst) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2145 (setq counter (1+ counter)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2146 (if (or (not (numberp bibtex-autokey-titlewords)) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
2147 (<= counter bibtex-autokey-titlewords)) |
57815 | 2148 (push word titlewords) |
2149 (push word titlewords-extra)))) | |
2150 ;; Obey bibtex-autokey-titlewords-stretch: | |
2151 ;; If by now we have processed all words in titlestring, we include | |
2152 ;; titlewords-extra in titlewords. Otherwise, we ignore titlewords-extra. | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2153 (unless (string-match "\\b\\w+" titlestring) |
57815 | 2154 (setq titlewords (append titlewords-extra titlewords))) |
2155 (mapconcat 'bibtex-autokey-demangle-title (nreverse titlewords) | |
2156 bibtex-autokey-titleword-separator)))) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2157 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2158 (defun bibtex-autokey-demangle-title (titleword) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2159 "Do some abbreviations on TITLEWORD. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2160 The rules are defined in `bibtex-autokey-titleword-abbrevs' |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2161 and `bibtex-autokey-titleword-length'." |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2162 (let ((case-fold-search t) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2163 (alist bibtex-autokey-titleword-abbrevs)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2164 (while (and alist |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2165 (not (string-match (concat "\\`\\(?:" (caar alist) "\\)\\'") |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2166 titleword))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2167 (setq alist (cdr alist))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2168 (if alist |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2169 (cdar alist) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
2170 (funcall bibtex-autokey-titleword-case-convert-function |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2171 (bibtex-autokey-abbrev titleword bibtex-autokey-titleword-length))))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
2172 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
2173 (defun bibtex-generate-autokey () |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2174 "Generate automatically a key for a BibTeX entry. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2175 Use the author/editor, the year and the title field. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2176 The algorithm works as follows. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2177 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2178 The name part: |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2179 1. Use the author or editor field to generate the name part of the key. |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2180 Expand BibTeX strings if `bibtex-autokey-expand-strings' is non-nil. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2181 2. Change the content of the name field according to |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2182 `bibtex-autokey-name-change-strings' (see there for further detail). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2183 3. Use the first `bibtex-autokey-names' names in the name field. If there |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2184 are up to `bibtex-autokey-names' + `bibtex-autokey-names-stretch' names, |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2185 use all names. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2186 4. Use only the last names to form the name part. From these last names, |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2187 take at least `bibtex-autokey-name-length' characters (truncate only |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2188 after a consonant or at a word end). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2189 5. Convert all last names using the function |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
2190 `bibtex-autokey-name-case-convert-function'. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2191 6. Build the name part of the key by concatenating all abbreviated last |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2192 names with the string `bibtex-autokey-name-separator' between any two. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2193 If there are more names in the name field than names used in the name |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2194 part, append the string `bibtex-autokey-additional-names'. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2195 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2196 The year part: |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2197 1. Build the year part of the key by truncating the content of the year |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2198 field to the rightmost `bibtex-autokey-year-length' digits (useful |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2199 values are 2 and 4). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2200 2. If the year field (or any other field required to generate the key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2201 is absent, but the entry has a valid crossref field and |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2202 `bibtex-autokey-use-crossref' is non-nil, use the field of the |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2203 crossreferenced entry instead. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2204 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2205 The title part |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2206 1. Change the content of the title field according to |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2207 `bibtex-autokey-titleword-change-strings' (see there for further detail). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2208 2. Truncate the title before the first match of |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2209 `bibtex-autokey-title-terminators' and delete those words which appear |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2210 in `bibtex-autokey-titleword-ignore'. Build the title part using the |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2211 first `bibtex-autokey-titlewords' words from this truncated title. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2212 If the truncated title ends after up to `bibtex-autokey-titlewords' + |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2213 `bibtex-autokey-titlewords-stretch' words, use all words from the |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2214 truncated title. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2215 3. For every title word that appears in `bibtex-autokey-titleword-abbrevs' |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2216 use the corresponding abbreviation (see documentation of this variable |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2217 for further detail). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2218 4. From every title word not generated by an abbreviation, take at least |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2219 `bibtex-autokey-titleword-length' characters (truncate only after |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2220 a consonant or at a word end). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2221 5. Convert all title words using the function |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
2222 `bibtex-autokey-titleword-case-convert-function'. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2223 6. Build the title part by concatenating all abbreviated title words with |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2224 the string `bibtex-autokey-titleword-separator' between any two. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2225 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2226 Concatenate the key: |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2227 1. Concatenate `bibtex-autokey-prefix-string', the name part, the year |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2228 part and the title part. If the name part and the year part are both |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2229 non-empty insert `bibtex-autokey-name-year-separator' between the two. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2230 If the title part and the year (or name) part are non-empty, insert |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2231 `bibtex-autokey-year-title-separator' between the two. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2232 2. If `bibtex-autokey-before-presentation-function' is non-nil, it must be |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2233 a function taking one argument. Call this function with the generated |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2234 key as the argument. Use the return value of this function (a string) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2235 as the key. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2236 3. If `bibtex-autokey-edit-before-use' is non-nil, present the key in the |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2237 minibuffer to the user for editing. Insert the key given by the user." |
57815 | 2238 (let* ((names (bibtex-autokey-get-names)) |
2239 (year (bibtex-autokey-get-year)) | |
2240 (title (bibtex-autokey-get-title)) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2241 (autokey (concat bibtex-autokey-prefix-string |
57815 | 2242 names |
2243 (unless (or (equal names "") | |
2244 (equal year "")) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2245 bibtex-autokey-name-year-separator) |
57815 | 2246 year |
2247 (unless (or (and (equal names "") | |
2248 (equal year "")) | |
2249 (equal title "")) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2250 bibtex-autokey-year-title-separator) |
57815 | 2251 title))) |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
2252 (if bibtex-autokey-before-presentation-function |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2253 (funcall bibtex-autokey-before-presentation-function autokey) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2254 autokey))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2255 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2256 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2257 (defun bibtex-global-key-alist () |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2258 "Return global key alist based on `bibtex-files'." |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2259 (if bibtex-files |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2260 (apply 'append |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2261 (mapcar (lambda (buf) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2262 (with-current-buffer buf bibtex-reference-keys)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2263 (bibtex-files-expand t))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2264 bibtex-reference-keys)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2265 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2266 (defun bibtex-read-key (prompt &optional key global) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2267 "Read BibTeX key from minibuffer using PROMPT and default KEY. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2268 If optional arg GLOBAL is non-nil, completion is based on the keys in |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2269 `bibtex-reference-keys' of `bibtex-files'," |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2270 (let (completion-ignore-case) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2271 (completing-read prompt (if global (bibtex-global-key-alist) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2272 bibtex-reference-keys) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2273 nil nil key 'bibtex-key-history))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2274 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2275 (defun bibtex-read-string-key (&optional key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2276 "Read BibTeX string key from minibuffer using default KEY." |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2277 (let ((completion-ignore-case t)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2278 (completing-read "String key: " bibtex-strings |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2279 nil nil key 'bibtex-key-history))) |
57815 | 2280 |
2281 (defun bibtex-parse-keys (&optional abortable verbose) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2282 "Set `bibtex-reference-keys' to the keys used in the whole buffer. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2283 Find both entry keys and crossref entries. If ABORTABLE is non-nil abort |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2284 on user input. If VERBOSE is non-nil give messages about progress. |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2285 Return alist of keys if parsing was completed, `aborted' otherwise. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2286 If `bibtex-parse-keys-fast' is non-nil, use fast but simplified algorithm |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2287 for parsing BibTeX keys. If parsing fails, try to set this variable to nil." |
57815 | 2288 (let (ref-keys crossref-keys) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2289 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2290 (save-match-data |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2291 (if verbose |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2292 (bibtex-progress-message |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2293 (concat (buffer-name) ": parsing reference keys"))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2294 (catch 'userkey |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2295 (goto-char (point-min)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2296 (if bibtex-parse-keys-fast |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2297 (let ((case-fold-search t) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2298 (re (concat bibtex-entry-head "\\|" |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2299 ",[ \t\n]*crossref[ \t\n]*=[ \t\n]*" |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2300 "\\(\"[^\"]*\"\\|{[^}]*}\\)[ \t\n]*[,})]"))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2301 (while (re-search-forward re nil t) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2302 (if (and abortable (input-pending-p)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2303 ;; user has aborted by typing a key --> return `aborted' |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2304 (throw 'userkey 'aborted)) |
57815 | 2305 (cond ((match-end 3) |
2306 ;; This is a crossref. | |
2307 (let ((key (buffer-substring-no-properties | |
2308 (1+ (match-beginning 3)) (1- (match-end 3))))) | |
2309 (unless (assoc key crossref-keys) | |
2310 (push (list key) crossref-keys)))) | |
2311 ;; only keys of known entries | |
2312 ((assoc-string (bibtex-type-in-head) | |
2313 bibtex-entry-field-alist t) | |
2314 ;; This is an entry. | |
2315 (let ((key (bibtex-key-in-head))) | |
2316 (unless (assoc key ref-keys) | |
2317 (push (cons key t) ref-keys))))))) | |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2318 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2319 (let (;; ignore @String entries because they are handled |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2320 ;; separately by bibtex-parse-strings |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2321 (bibtex-sort-ignore-string-entries t) |
57815 | 2322 bounds) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2323 (bibtex-map-entries |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2324 (lambda (key beg end) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2325 (if (and abortable |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2326 (input-pending-p)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2327 ;; user has aborted by typing a key --> return `aborted' |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2328 (throw 'userkey 'aborted)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2329 (if verbose (bibtex-progress-message)) |
57815 | 2330 (unless (assoc key ref-keys) |
2331 (push (cons key t) ref-keys)) | |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2332 (if (and (setq bounds (bibtex-search-forward-field "crossref" end)) |
57815 | 2333 (setq key (bibtex-text-in-field-bounds bounds t)) |
2334 (not (assoc key crossref-keys))) | |
2335 (push (list key) crossref-keys)))))) | |
2336 | |
2337 (dolist (key crossref-keys) | |
2338 (unless (assoc (car key) ref-keys) (push key ref-keys))) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2339 (if verbose |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2340 (bibtex-progress-message 'done)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2341 ;; successful operation --> return `bibtex-reference-keys' |
57815 | 2342 (setq bibtex-reference-keys ref-keys)))))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2343 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2344 (defun bibtex-parse-strings (&optional add abortable) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2345 "Set `bibtex-strings' to the string definitions in the whole buffer. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2346 If ADD is non-nil add the new strings to `bibtex-strings' instead of |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2347 simply resetting it. If ADD is an alist of strings, also add ADD to |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2348 `bibtex-strings'. If ABORTABLE is non-nil abort on user input. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2349 Return alist of strings if parsing was completed, `aborted' otherwise." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2350 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2351 (save-match-data |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2352 (goto-char (point-min)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2353 (let ((strings (if (and add |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2354 (listp bibtex-strings)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2355 bibtex-strings)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2356 bounds key) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2357 (if (listp add) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2358 (dolist (string add) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2359 (unless (assoc-string (car string) strings t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2360 (push string strings)))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2361 (catch 'userkey |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2362 (while (setq bounds (bibtex-search-forward-string)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2363 (if (and abortable |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2364 (input-pending-p)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2365 ;; user has aborted by typing a key --> return `aborted' |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2366 (throw 'userkey 'aborted)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2367 (setq key (bibtex-reference-key-in-string bounds)) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2368 (unless (assoc-string key strings t) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2369 (push (cons key (bibtex-text-in-string bounds t)) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2370 strings)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2371 (goto-char (bibtex-end-of-text-in-string bounds))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2372 ;; successful operation --> return `bibtex-strings' |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2373 (setq bibtex-strings strings)))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2374 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2375 (defun bibtex-strings () |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2376 "Return `bibtex-strings'. Initialize this variable if necessary." |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2377 (if (listp bibtex-strings) bibtex-strings |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2378 (bibtex-parse-strings (bibtex-string-files-init)))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2379 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2380 (defun bibtex-string-files-init () |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2381 "Return initialization for `bibtex-strings'. |
57815 | 2382 Use `bibtex-predefined-strings' and BibTeX files `bibtex-string-files'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2383 (save-match-data |
57815 | 2384 (let ((dirlist (split-string (or bibtex-string-file-path default-directory) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2385 ":+")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2386 (case-fold-search) |
57815 | 2387 string-files fullfilename compl bounds found) |
2388 ;; collect absolute file names of valid string files | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2389 (dolist (filename bibtex-string-files) |
51416
83476384bebd
(bibtex-member-of-regexp, bibtex-assoc-of-regexp, bibtex-format-entry)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51415
diff
changeset
|
2390 (unless (string-match "\\.bib\\'" filename) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2391 (setq filename (concat filename ".bib"))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2392 ;; test filenames |
57815 | 2393 (if (file-name-absolute-p filename) |
2394 (if (file-readable-p filename) | |
2395 (push filename string-files) | |
2396 (error "BibTeX strings file %s not found" filename)) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2397 (dolist (dir dirlist) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2398 (when (file-readable-p |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2399 (setq fullfilename (expand-file-name filename dir))) |
57815 | 2400 (push fullfilename string-files) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2401 (setq found t))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2402 (unless found |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2403 (error "File %s not in paths defined via bibtex-string-file-path" |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2404 filename)))) |
57815 | 2405 ;; parse string files |
2406 (dolist (filename string-files) | |
2407 (with-temp-buffer | |
2408 (insert-file-contents filename) | |
2409 (goto-char (point-min)) | |
2410 (while (setq bounds (bibtex-search-forward-string)) | |
2411 (push (cons (bibtex-reference-key-in-string bounds) | |
2412 (bibtex-text-in-string bounds t)) | |
2413 compl) | |
2414 (goto-char (bibtex-end-of-string bounds))))) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2415 (append bibtex-predefined-strings (nreverse compl))))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
2416 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2417 (defun bibtex-parse-buffers-stealthily () |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2418 "Parse buffer in the background during idle time. |
57815 | 2419 Called by `run-with-idle-timer'. Whenever Emacs has been idle |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2420 for `bibtex-parse-keys-timeout' seconds, parse all BibTeX buffers |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2421 which have been modified after last parsing. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2422 Parsing initializes `bibtex-reference-keys' and `bibtex-strings'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2423 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2424 (let ((buffers (buffer-list)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2425 (strings-init (bibtex-string-files-init))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2426 (while (and buffers (not (input-pending-p))) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2427 (set-buffer (car buffers)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2428 (if (and (eq major-mode 'bibtex-mode) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2429 (not (eq (buffer-modified-tick) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2430 bibtex-buffer-last-parsed-tick))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2431 (save-restriction |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2432 (widen) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2433 ;; Output no progress messages in bibtex-parse-keys |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2434 ;; because when in y-or-n-p that can hide the question. |
57815 | 2435 (if (and (listp (bibtex-parse-keys t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2436 ;; update bibtex-strings |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2437 (listp (bibtex-parse-strings strings-init t))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2438 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2439 ;; remember that parsing was successful |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2440 (setq bibtex-buffer-last-parsed-tick (buffer-modified-tick))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2441 (setq buffers (cdr buffers)))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2442 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2443 (defun bibtex-files-expand (&optional current force) |
57815 | 2444 "Return an expanded list of BibTeX buffers based on `bibtex-files'. |
2445 Initialize in these buffers `bibtex-reference-keys' if not yet set. | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2446 List of BibTeX buffers includes current buffer if CURRENT is non-nil. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2447 If FORCE is non-nil, (re)initialize `bibtex-reference-keys' even if |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2448 already set." |
57815 | 2449 (let ((file-path (split-string (or bibtex-file-path default-directory) ":+")) |
2450 file-list dir-list buffer-list) | |
2451 (dolist (file bibtex-files) | |
2452 (cond ((eq file 'bibtex-file-path) | |
2453 (setq dir-list (append dir-list file-path))) | |
2454 ((file-accessible-directory-p file) | |
2455 (push file dir-list)) | |
2456 ((progn (unless (string-match "\\.bib\\'" file) | |
2457 (setq file (concat file ".bib"))) | |
2458 (file-name-absolute-p file)) | |
2459 (push file file-list)) | |
2460 (t | |
2461 (let (fullfilename found) | |
2462 (dolist (dir file-path) | |
2463 (when (file-readable-p | |
2464 (setq fullfilename (expand-file-name file dir))) | |
2465 (push fullfilename file-list) | |
2466 (setq found t))) | |
2467 (unless found | |
2468 (error "File %s not in paths defined via bibtex-file-path" | |
2469 file)))))) | |
2470 (dolist (file file-list) | |
2471 (unless (file-readable-p file) | |
2472 (error "BibTeX file %s not found" file))) | |
2473 ;; expand dir-list | |
2474 (dolist (dir dir-list) | |
2475 (setq file-list | |
2476 (append file-list (directory-files dir t "\\.bib\\'" t)))) | |
2477 (delete-dups file-list) | |
2478 (dolist (file file-list) | |
2479 (when (file-readable-p file) | |
2480 (push (find-file-noselect file) buffer-list) | |
2481 (with-current-buffer (car buffer-list) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2482 (if (or force (not (listp bibtex-reference-keys))) |
57815 | 2483 (bibtex-parse-keys))))) |
2484 (cond ((and current (not (memq (current-buffer) buffer-list))) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2485 (push (current-buffer) buffer-list) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2486 (if force (bibtex-parse-keys))) |
57815 | 2487 ((and (not current) (memq (current-buffer) buffer-list)) |
2488 (setq buffer-list (delq (current-buffer) buffer-list)))) | |
2489 buffer-list)) | |
2490 | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2491 (defun bibtex-complete-internal (completions) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2492 "Complete word fragment before point to longest prefix of COMPLETIONS. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2493 COMPLETIONS is an alist of strings. If point is not after the part |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2494 of a word, all strings are listed. Return completion." |
67933
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
2495 ;; Return value is used by cleanup functions. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2496 (let* ((case-fold-search t) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2497 (beg (save-excursion |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2498 (re-search-backward "[ \t{\"]") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2499 (forward-char) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2500 (point))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2501 (end (point)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2502 (part-of-word (buffer-substring-no-properties beg end)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2503 (completion (try-completion part-of-word completions))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2504 (cond ((not completion) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2505 (error "Can't find completion for `%s'" part-of-word)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2506 ((eq completion t) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2507 part-of-word) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2508 ((not (string= part-of-word completion)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2509 (delete-region beg end) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2510 (insert completion) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2511 completion) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2512 (t |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2513 (message "Making completion list...") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2514 (with-output-to-temp-buffer "*Completions*" |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2515 (display-completion-list (all-completions part-of-word completions) |
66114
13abee3a9bc6
* message.el (message-expand-group): Pass the common
Masatake YAMATO <jet@gyve.org>
parents:
65776
diff
changeset
|
2516 part-of-word)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2517 (message "Making completion list...done") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2518 nil)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2519 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2520 (defun bibtex-complete-string-cleanup (str compl) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2521 "Cleanup after inserting string STR. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2522 Remove enclosing field delimiters for STR. Display message with |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2523 expansion of STR using expansion list COMPL." |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2524 ;; point is at position inside field where completion was requested |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2525 (save-excursion |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2526 (let ((abbr (cdr (if (stringp str) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2527 (assoc-string str compl t))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2528 (if abbr (message "Abbreviation for `%s'" abbr)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2529 (bibtex-remove-delimiters)))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2530 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2531 (defun bibtex-complete-crossref-cleanup (key) |
57815 | 2532 "Display summary message on entry KEY after completion of a crossref key. |
2533 Use `bibtex-summary-function' to generate summary." | |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2534 (save-excursion |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2535 (if (and (stringp key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2536 (bibtex-find-entry key t)) |
62077
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2537 (message "Ref: %s" (funcall bibtex-summary-function))))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2538 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2539 (defun bibtex-copy-summary-as-kill () |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2540 "Push summery of current BibTeX entry to kill ring. |
57815 | 2541 Use `bibtex-summary-function' to generate summary." |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2542 (interactive) |
62077
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2543 (save-excursion |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2544 (bibtex-beginning-of-entry) |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2545 (if (looking-at bibtex-entry-maybe-empty-head) |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2546 (kill-new (message "%s" (funcall bibtex-summary-function))) |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2547 (error "No entry found")))) |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2548 |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2549 (defun bibtex-summary () |
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2550 "Return summary of current BibTeX entry. |
57815 | 2551 Used as default value of `bibtex-summary-function'." |
2552 ;; It would be neat to customize this function. How? | |
65776
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2553 (if (looking-at bibtex-entry-maybe-empty-head) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
2554 (let* ((bibtex-autokey-name-case-convert-function 'identity) |
65776
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2555 (bibtex-autokey-name-length 'infty) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2556 (bibtex-autokey-names 1) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2557 (bibtex-autokey-names-stretch 0) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2558 (bibtex-autokey-name-separator " ") |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2559 (bibtex-autokey-additional-names " etal") |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2560 (names (bibtex-autokey-get-names)) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2561 (bibtex-autokey-year-length 4) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2562 (year (bibtex-autokey-get-year)) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2563 (bibtex-autokey-titlewords 5) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2564 (bibtex-autokey-titlewords-stretch 2) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
2565 (bibtex-autokey-titleword-case-convert-function 'identity) |
65776
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2566 (bibtex-autokey-titleword-length 5) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2567 (bibtex-autokey-titleword-separator " ") |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2568 (title (bibtex-autokey-get-title)) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2569 (journal (bibtex-autokey-get-field |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2570 "journal" bibtex-autokey-transcriptions)) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2571 (volume (bibtex-autokey-get-field "volume")) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2572 (pages (bibtex-autokey-get-field "pages" '(("-.*\\'" . ""))))) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2573 (mapconcat (lambda (arg) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2574 (if (not (string= "" (cdr arg))) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2575 (concat (car arg) (cdr arg)))) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2576 `((" " . ,names) (" " . ,year) (": " . ,title) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2577 (", " . ,journal) (" " . ,volume) (":" . ,pages)) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2578 "")) |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
2579 (error "Entry not found"))) |
257 | 2580 |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
2581 (defun bibtex-pop (arg direction) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2582 "Fill current field from the ARGth same field's text in DIRECTION. |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2583 Generic function used by `bibtex-pop-previous' and `bibtex-pop-next'." |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2584 ;; parse current field |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2585 (let* ((bounds (bibtex-enclosing-field t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2586 (start-old-field (bibtex-start-of-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2587 (start-old-text (bibtex-start-of-text-in-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2588 (end-old-text (bibtex-end-of-text-in-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2589 (field-name (bibtex-name-in-field bounds t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2590 failure) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2591 (save-excursion |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2592 ;; if executed several times in a row, start each search where |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2593 ;; the last one was finished |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2594 (cond ((eq last-command 'bibtex-pop) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2595 (goto-char (if (eq direction 'previous) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2596 bibtex-pop-previous-search-point |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2597 bibtex-pop-next-search-point))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2598 ((eq direction 'previous) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2599 (bibtex-beginning-of-entry)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2600 (t (bibtex-end-of-entry))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2601 ;; Search for arg'th previous/next similar field |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2602 (while (and (not failure) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2603 (>= (setq arg (1- arg)) 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2604 ;; The search of BibTeX fields is not bounded by entry boundaries |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2605 (if (eq direction 'previous) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2606 (if (setq bounds (bibtex-search-backward-field field-name)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2607 (goto-char (bibtex-start-of-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2608 (setq failure t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2609 (if (setq bounds (bibtex-search-forward-field field-name)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2610 (goto-char (bibtex-end-of-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2611 (setq failure t)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2612 (if failure |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2613 (error "No %s matching BibTeX field" |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2614 (if (eq direction 'previous) "previous" "next")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2615 ;; Found a matching field. Remember boundaries. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2616 (let ((new-text (bibtex-text-in-field-bounds bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2617 (nbeg (copy-marker (bibtex-start-of-field bounds))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2618 (nend (copy-marker (bibtex-end-of-field bounds)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2619 (bibtex-flash-head "From: ") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2620 ;; Go back to where we started, delete old text, and pop new. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2621 (goto-char end-old-text) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2622 (delete-region start-old-text end-old-text) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2623 (if (= nbeg start-old-field) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2624 (insert (bibtex-field-left-delimiter) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2625 (bibtex-field-right-delimiter)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2626 (insert new-text)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2627 (setq bibtex-pop-previous-search-point (marker-position nbeg) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2628 bibtex-pop-next-search-point (marker-position nend)))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2629 (bibtex-find-text nil nil nil t) |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
2630 (setq this-command 'bibtex-pop)) |
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
2631 |
57815 | 2632 (defun bibtex-beginning-of-field () |
2633 "Move point backward to beginning of field. | |
2634 This function uses a simple, fast algorithm assuming that the field | |
2635 begins at the beginning of a line. We use this function for font-locking." | |
2636 (let ((field-reg (concat "^[ \t]*" bibtex-field-name "[ \t]*="))) | |
2637 (beginning-of-line) | |
2638 (unless (looking-at field-reg) | |
2639 (re-search-backward field-reg nil t)))) | |
2640 | |
2641 (defun bibtex-font-lock-url (bound) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2642 "Font-lock for URLs. BOUND limits the search." |
57815 | 2643 (let ((case-fold-search t) |
2644 (pnt (point)) | |
2645 field bounds start end found) | |
2646 (bibtex-beginning-of-field) | |
2647 (while (and (not found) | |
66116
cff7c706ba17
(bibtex-font-lock-url): Catch when point past bound of search.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66114
diff
changeset
|
2648 (<= (point) bound) |
57815 | 2649 (prog1 (re-search-forward bibtex-font-lock-url-regexp bound t) |
2650 (setq field (match-string-no-properties 1))) | |
2651 (setq bounds (bibtex-parse-field-text)) | |
2652 (progn | |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2653 (setq start (car bounds) end (nth 1 bounds)) |
57815 | 2654 ;; Always ignore field delimiters |
2655 (if (memq (char-before end) '(?\} ?\")) | |
2656 (setq end (1- end))) | |
2657 (if (memq (char-after start) '(?\{ ?\")) | |
2658 (setq start (1+ start))) | |
2659 (>= bound start))) | |
2660 (let ((lst bibtex-generate-url-list) url) | |
2661 (goto-char start) | |
2662 (while (and (not found) | |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
2663 (setq url (car (pop lst)))) |
57815 | 2664 (setq found (and (bibtex-string= field (car url)) |
2665 (re-search-forward (cdr url) end t) | |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
2666 (>= (match-beginning 0) pnt))))) |
57815 | 2667 (goto-char end)) |
2668 (if found (bibtex-button (match-beginning 0) (match-end 0) | |
2669 'bibtex-url (match-beginning 0))) | |
2670 found)) | |
2671 | |
2672 (defun bibtex-font-lock-crossref (bound) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2673 "Font-lock for crossref fields. BOUND limits the search." |
57815 | 2674 (let ((case-fold-search t) |
2675 (pnt (point)) | |
2676 (crossref-reg (concat "^[ \t]*crossref[ \t]*=[ \t\n]*" | |
2677 "\\(\"[^\"]*\"\\|{[^}]*}\\)[ \t\n]*[,})]")) | |
2678 start end found) | |
2679 (bibtex-beginning-of-field) | |
2680 (while (and (not found) | |
2681 (re-search-forward crossref-reg bound t)) | |
2682 (setq start (1+ (match-beginning 1)) | |
2683 end (1- (match-end 1)) | |
2684 found (>= start pnt))) | |
2685 (if found (bibtex-button start end 'bibtex-find-crossref | |
2686 (buffer-substring-no-properties start end) | |
2687 start t)) | |
2688 found)) | |
2689 | |
2690 (defun bibtex-button-action (button) | |
2691 "Call BUTTON's BibTeX function." | |
2692 (apply (button-get button 'bibtex-function) | |
2693 (button-get button 'bibtex-args))) | |
2694 | |
2695 (define-button-type 'bibtex-url | |
2696 'action 'bibtex-button-action | |
2697 'bibtex-function 'bibtex-url | |
2698 'help-echo (purecopy "mouse-2, RET: follow URL")) | |
2699 | |
2700 (define-button-type 'bibtex-find-crossref | |
2701 'action 'bibtex-button-action | |
2702 'bibtex-function 'bibtex-find-crossref | |
2703 'help-echo (purecopy "mouse-2, RET: follow crossref")) | |
2704 | |
2705 (defun bibtex-button (beg end type &rest args) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2706 "Make a BibTeX button from BEG to END of type TYPE in the current buffer." |
57815 | 2707 (make-text-button beg end 'type type 'bibtex-args args)) |
2708 | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2709 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2710 ;; Interactive Functions: |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2711 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2712 ;;;###autoload |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2713 (defun bibtex-mode () |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2714 "Major mode for editing BibTeX files. |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2715 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2716 General information on working with BibTeX mode: |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2717 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2718 Use commands such as \\[bibtex-Book] to get a template for a specific entry. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2719 Then fill in all desired fields using \\[bibtex-next-field] to jump from field |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2720 to field. After having filled in all desired fields in the entry, clean the |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2721 new entry with the command \\[bibtex-clean-entry]. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2722 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2723 Some features of BibTeX mode are available only by setting the variable |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
2724 `bibtex-maintain-sorted-entries' to non-nil. However, then BibTeX mode |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
2725 works only with buffers containing valid (syntactical correct) and sorted |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
2726 entries. This is usually the case, if you have created a buffer completely |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
2727 with BibTeX mode and finished every new entry with \\[bibtex-clean-entry]. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2728 |
62077
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
2729 For third party BibTeX files, call the command \\[bibtex-convert-alien] |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2730 to fully take advantage of all features of BibTeX mode. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2731 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2732 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2733 Special information: |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2734 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
2735 A command such as \\[bibtex-Book] outlines the fields for a BibTeX book entry. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2736 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2737 The names of optional fields start with the string OPT, and are thus ignored |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2738 by BibTeX. The names of alternative fields from which only one is required |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2739 start with the string ALT. The OPT or ALT string may be removed from |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2740 the name of a field with \\[bibtex-remove-OPT-or-ALT]. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2741 \\[bibtex-make-field] inserts a new field after the current one. |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2742 \\[bibtex-kill-field] kills the current field entirely. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2743 \\[bibtex-yank] yanks the last recently killed field after the current field. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2744 \\[bibtex-remove-delimiters] removes the double-quotes or braces around the text of the current field. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2745 \\[bibtex-empty-field] replaces the text of the current field with the default \"\" or {}. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2746 \\[bibtex-find-text] moves point to the end of the current field. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2747 \\[bibtex-complete] completes word fragment before point according to context. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2748 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2749 The command \\[bibtex-clean-entry] cleans the current entry, i.e. it removes OPT/ALT |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2750 from the names of all non-empty optional or alternative fields, checks that |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2751 no required fields are empty, and does some formatting dependent on the value |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2752 of `bibtex-entry-format'. Furthermore, it can automatically generate a key |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2753 for the BibTeX entry, see `bibtex-generate-autokey'. |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
2754 Note: some functions in BibTeX mode depend on entries being in a special |
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
2755 format (all fields beginning on separate lines), so it is usually a bad |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2756 idea to remove `realign' from `bibtex-entry-format'. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2757 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2758 BibTeX mode supports Imenu and hideshow minor mode (`hs-minor-mode'). |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2759 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2760 ---------------------------------------------------------- |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2761 Entry to BibTeX mode calls the value of `bibtex-mode-hook' |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2762 if that value is non-nil. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2763 |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
2764 \\{bibtex-mode-map}" |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2765 (interactive) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2766 (kill-all-local-variables) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2767 (use-local-map bibtex-mode-map) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2768 (setq major-mode 'bibtex-mode) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2769 (setq mode-name "BibTeX") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2770 (set-syntax-table bibtex-mode-syntax-table) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2771 (make-local-variable 'bibtex-buffer-last-parsed-tick) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2772 ;; Install stealthy parse function if not already installed |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2773 (unless bibtex-parse-idle-timer |
57815 | 2774 (setq bibtex-parse-idle-timer (run-with-idle-timer |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2775 bibtex-parse-keys-timeout t |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2776 'bibtex-parse-buffers-stealthily))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2777 (set (make-local-variable 'paragraph-start) "[ \f\n\t]*$") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2778 (set (make-local-variable 'comment-start) bibtex-comment-start) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2779 (set (make-local-variable 'comment-start-skip) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2780 (concat (regexp-quote bibtex-comment-start) "\\>[ \t]*")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2781 (set (make-local-variable 'comment-column) 0) |
61439
267229876c56
(bibtex-autokey-titleword-ignore, bibtex-reference-key)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61247
diff
changeset
|
2782 (set (make-local-variable 'defun-prompt-regexp) "^[ \t]*@[[:alnum:]]+[ \t]*") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2783 (set (make-local-variable 'outline-regexp) "[ \t]*@") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2784 (set (make-local-variable 'fill-paragraph-function) 'bibtex-fill-field) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2785 (set (make-local-variable 'fill-prefix) (make-string (+ bibtex-entry-offset |
57815 | 2786 bibtex-contline-indentation) |
64054
23a07b9b6687
(bibtex, bibtex-autokey): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents:
63470
diff
changeset
|
2787 ?\s)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2788 (set (make-local-variable 'font-lock-defaults) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2789 '(bibtex-font-lock-keywords |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2790 nil t ((?$ . "\"") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2791 ;; Mathematical expressions should be fontified as strings |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2792 (?\" . ".") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2793 ;; Quotes are field delimiters and quote-delimited |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2794 ;; entries should be fontified in the same way as |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2795 ;; brace-delimited ones |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2796 ) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2797 nil |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2798 (font-lock-syntactic-keywords . bibtex-font-lock-syntactic-keywords) |
57815 | 2799 (font-lock-extra-managed-props . (category)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2800 (font-lock-mark-block-function |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2801 . (lambda () |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2802 (set-mark (bibtex-end-of-entry)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2803 (bibtex-beginning-of-entry))))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2804 (setq imenu-generic-expression |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2805 (list (list nil bibtex-entry-head bibtex-key-in-head)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2806 imenu-case-fold-search t) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2807 (make-local-variable 'choose-completion-string-functions) |
20907
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
2808 ;; XEmacs needs easy-menu-add, Emacs does not care |
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
2809 (easy-menu-add bibtex-edit-menu) |
9a55a557cb5a
(bibtex-autokey-names): Change number tag to integer.
Richard M. Stallman <rms@gnu.org>
parents:
20866
diff
changeset
|
2810 (easy-menu-add bibtex-entry-menu) |
61439
267229876c56
(bibtex-autokey-titleword-ignore, bibtex-reference-key)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61247
diff
changeset
|
2811 (run-mode-hooks 'bibtex-mode-hook)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2812 |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2813 (defun bibtex-field-list (entry-type) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2814 "Return list of allowed fields for entry ENTRY-TYPE. |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2815 More specifically, the return value is a cons pair (REQUIRED . OPTIONAL), |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2816 where REQUIRED and OPTIONAL are lists of the required and optional field |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2817 names for ENTRY-TYPE according to `bibtex-entry-field-alist', |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2818 `bibtex-include-OPTkey', `bibtex-include-OPTcrossref', |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2819 and `bibtex-user-optional-fields'." |
55730
b4eeb441c089
Use assoc-string, not assoc-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents:
55348
diff
changeset
|
2820 (let ((e (assoc-string entry-type bibtex-entry-field-alist t)) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2821 required optional) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2822 (unless e |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2823 (error "Fields for BibTeX entry type %s not defined" entry-type)) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2824 (if (and (member-ignore-case entry-type bibtex-include-OPTcrossref) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2825 (nth 2 e)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2826 (setq required (nth 0 (nth 2 e)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2827 optional (nth 1 (nth 2 e))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2828 (setq required (nth 0 (nth 1 e)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2829 optional (nth 1 (nth 1 e)))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2830 (if bibtex-include-OPTkey |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2831 (push (list "key" |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2832 "Used for reference key creation if author and editor fields are missing" |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2833 (if (or (stringp bibtex-include-OPTkey) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2834 (fboundp bibtex-include-OPTkey)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2835 bibtex-include-OPTkey)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2836 optional)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2837 (if (member-ignore-case entry-type bibtex-include-OPTcrossref) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2838 (push '("crossref" "Reference key of the cross-referenced entry") |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2839 optional)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2840 (setq optional (append optional bibtex-user-optional-fields)) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2841 (cons required optional))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2842 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2843 (defun bibtex-entry (entry-type) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2844 "Insert a new BibTeX entry of type ENTRY-TYPE. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2845 After insertion call the value of `bibtex-add-entry-hook' if that value |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2846 is non-nil." |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2847 (interactive |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2848 (let ((completion-ignore-case t)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2849 (list (completing-read "Entry Type: " bibtex-entry-field-alist |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2850 nil t nil 'bibtex-entry-type-history)))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2851 (let ((key (if bibtex-maintain-sorted-entries |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2852 (bibtex-read-key (format "%s key: " entry-type)))) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2853 (field-list (bibtex-field-list entry-type))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2854 (unless (bibtex-prepare-new-entry (list key nil entry-type)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
2855 (error "Entry with key `%s' already exists" key)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2856 (indent-to-column bibtex-entry-offset) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2857 (insert "@" entry-type (bibtex-entry-left-delimiter)) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2858 (if key (insert key)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2859 (save-excursion |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2860 (mapc 'bibtex-make-field (car field-list)) |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
2861 (mapc 'bibtex-make-optional-field (cdr field-list)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2862 (if bibtex-comma-after-last-field |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2863 (insert ",")) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2864 (insert "\n") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2865 (indent-to-column bibtex-entry-offset) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2866 (insert (bibtex-entry-right-delimiter) "\n\n")) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2867 (bibtex-next-field t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2868 (if (member-ignore-case entry-type bibtex-autofill-types) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2869 (bibtex-autofill-entry)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2870 (run-hooks 'bibtex-add-entry-hook))) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
2871 |
69887
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2872 (defun bibtex-entry-update (&optional entry-type) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2873 "Update an existing BibTeX entry. |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2874 In the BibTeX entry at point, make new fields for those items that may occur |
69887
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2875 according to `bibtex-field-list', but are not yet present. |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2876 Also, add field delimiters to numerical fields if they are not present. |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2877 If ENTRY-TYPE is non-nil, change first the entry type to ENTRY-TYPE. |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2878 When called interactively with a prefix arg, query for a value of ENTRY-TYPE." |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2879 (interactive |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2880 (list (if current-prefix-arg |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2881 (let ((completion-ignore-case t)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2882 (completing-read "New entry type: " bibtex-entry-field-alist |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2883 nil t nil 'bibtex-entry-type-history))))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2884 (save-excursion |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2885 (bibtex-beginning-of-entry) |
69887
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2886 (when (looking-at bibtex-entry-maybe-empty-head) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2887 (goto-char (match-end 0)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2888 (if entry-type |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2889 (save-excursion |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2890 (replace-match (concat "@" entry-type) nil nil nil 1)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2891 (setq entry-type (bibtex-type-in-head))) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2892 (let* ((field-list (bibtex-field-list entry-type)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2893 (required (copy-tree (car field-list))) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2894 (optional (copy-tree (cdr field-list))) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2895 bounds) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2896 (while (setq bounds (bibtex-parse-field)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2897 (let ((fname (bibtex-name-in-field bounds t)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2898 (end (copy-marker (bibtex-end-of-field bounds) t))) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2899 (setq required (delete (assoc-string fname required t) required) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2900 optional (delete (assoc-string fname optional t) optional)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2901 (when (string-match "\\`[0-9]+\\'" |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2902 (bibtex-text-in-field-bounds bounds)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2903 (goto-char (bibtex-end-of-text-in-field bounds)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2904 (insert (bibtex-field-right-delimiter)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2905 (goto-char (bibtex-start-of-text-in-field bounds)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2906 (insert (bibtex-field-left-delimiter))) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2907 (goto-char end))) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2908 (skip-chars-backward " \t\n") |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2909 (dolist (field required) (bibtex-make-field field)) |
14e2e318d372
(bibtex-entry-update): New optional arg entry-type. Add field
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69886
diff
changeset
|
2910 (dolist (field optional) (bibtex-make-optional-field field)))))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
2911 |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2912 (defun bibtex-parse-entry (&optional content) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2913 "Parse entry at point, return an alist. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2914 The alist elements have the form (FIELD . TEXT), where FIELD can also be |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2915 the special strings \"=type=\" and \"=key=\". For the FIELD \"=key=\" |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2916 TEXT may be nil. Remove \"OPT\" and \"ALT\" from FIELD. |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2917 Move point to the end of the last field. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2918 If optional arg CONTENT is non-nil extract content of text fields." |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2919 (let (alist bounds) |
55880
1b2cb608f18e
(bibtex-format-entry): Fix regexps.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55730
diff
changeset
|
2920 (when (looking-at bibtex-entry-maybe-empty-head) |
57815 | 2921 (push (cons "=type=" (bibtex-type-in-head)) alist) |
2922 (push (cons "=key=" (bibtex-key-in-head)) alist) | |
55880
1b2cb608f18e
(bibtex-format-entry): Fix regexps.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55730
diff
changeset
|
2923 (goto-char (match-end 0)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2924 (while (setq bounds (bibtex-parse-field)) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2925 (push (cons (bibtex-name-in-field bounds t) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2926 (bibtex-text-in-field-bounds bounds content)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2927 alist) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2928 (goto-char (bibtex-end-of-field bounds)))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2929 alist)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2930 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2931 (defun bibtex-autofill-entry () |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2932 "Try to fill fields of current BibTeX entry based on neighboring entries. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2933 The current entry must have a key. Determine the neighboring entry |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2934 \(previouse or next\) whose key is more similar to the key of the current |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2935 entry. For all empty fields of the current entry insert the corresponding |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2936 field contents of the neighboring entry. Finally try to update the text |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2937 based on the difference between the keys of the neighboring and the current |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2938 entry (for example, the year parts of the keys)." |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2939 (interactive) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2940 (undo-boundary) ;So you can easily undo it, if it didn't work right. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2941 (bibtex-beginning-of-entry) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2942 (when (looking-at bibtex-entry-head) |
57815 | 2943 (let ((type (bibtex-type-in-head)) |
2944 (key (bibtex-key-in-head)) | |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2945 (key-end (match-end bibtex-key-in-head)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2946 (case-fold-search t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
2947 (bibtex-sort-ignore-string-entries t) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2948 tmp other-key other bounds) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2949 ;; The fields we want to change start right after the key. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2950 (goto-char key-end) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2951 ;; First see whether to use the previous or the next entry |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2952 ;; for "inspiration". |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2953 (save-excursion |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2954 (goto-char (1- (match-beginning 0))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2955 (bibtex-beginning-of-entry) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2956 (if (and (looking-at bibtex-entry-head) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2957 (bibtex-string= type (bibtex-type-in-head)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2958 ;; In case we found ourselves :-( |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2959 (not (equal key (setq tmp (bibtex-key-in-head))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2960 (setq other-key tmp |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2961 other (point)))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2962 (save-excursion |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2963 (bibtex-end-of-entry) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2964 (bibtex-skip-to-valid-entry) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2965 (if (and (looking-at bibtex-entry-head) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2966 (bibtex-string= type (bibtex-type-in-head)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2967 ;; In case we found ourselves :-( |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2968 (not (equal key (setq tmp (bibtex-key-in-head)))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2969 (or (not other-key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2970 ;; Check which is the best match. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2971 (< (length (try-completion "" (list key other-key))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2972 (length (try-completion "" (list key tmp)))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2973 (setq other-key tmp |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
2974 other (point)))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2975 ;; Then fill the new entry's fields with the chosen other entry. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2976 (when other |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2977 (setq other (save-excursion (goto-char other) (bibtex-parse-entry))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2978 (setq key-end (point)) ;In case parse-entry changed the buffer. |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2979 (while (setq bounds (bibtex-parse-field)) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2980 (let ((text (assoc-string (bibtex-name-in-field bounds t) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
2981 other t))) |
59733
96d73eb02751
(bibtex-format-entry): Use `bibtex-empty-field-re' only on the text of
Lute Kamstra <lute@gnu.org>
parents:
58772
diff
changeset
|
2982 (if (not (and text |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
2983 (equal "" (bibtex-text-in-field-bounds bounds t)))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2984 (goto-char (bibtex-end-of-field bounds)) |
59733
96d73eb02751
(bibtex-format-entry): Use `bibtex-empty-field-re' only on the text of
Lute Kamstra <lute@gnu.org>
parents:
58772
diff
changeset
|
2985 (goto-char (bibtex-start-of-text-in-field bounds)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2986 (delete-region (point) (bibtex-end-of-text-in-field bounds)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2987 (insert (cdr text))))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2988 ;; Finally try to update the text based on the difference between |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2989 ;; the two keys. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2990 (let* ((prefix (try-completion "" (list key other-key))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2991 ;; If the keys are foo91 and foo92, don't replace 1 for 2 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2992 ;; but 91 for 92 instead. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2993 (_ (if (string-match "[0-9]+\\'" prefix) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2994 (setq prefix (substring prefix 0 (match-beginning 0))))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2995 (suffix (substring key (length prefix))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2996 (other-suffix (substring other-key (length prefix)))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2997 (while (re-search-backward (regexp-quote other-suffix) key-end 'move) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2998 (replace-match suffix))))))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
2999 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3000 (defun bibtex-print-help-message (&optional field comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3001 "Print helpful information about current FIELD in current BibTeX entry. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3002 Optional arg COMMA is as in `bibtex-enclosing-field'. It is t for |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3003 interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3004 (interactive (list nil t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3005 (unless field (setq field (car (bibtex-find-text-internal nil nil comma)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3006 (if (string-match "@" field) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3007 (cond ((bibtex-string= field "@string") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3008 (message "String definition")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3009 ((bibtex-string= field "@preamble") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3010 (message "Preamble definition")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3011 (t (message "Entry key"))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3012 (let* ((case-fold-search t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3013 (type (save-excursion |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3014 (bibtex-beginning-of-entry) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3015 (looking-at bibtex-entry-maybe-empty-head) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3016 (bibtex-type-in-head))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3017 (field-list (bibtex-field-list type)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3018 (comment (assoc-string field (append (car field-list) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3019 (cdr field-list)) t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3020 (if comment (message "%s" (nth 1 comment)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3021 (message "No comment available"))))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3022 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3023 (defun bibtex-make-field (field &optional move interactive) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3024 "Make a field named FIELD in current BibTeX entry. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3025 FIELD is either a string or a list of the form |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3026 \(FIELD-NAME COMMENT-STRING INIT ALTERNATIVE-FLAG) as in |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
3027 `bibtex-entry-field-alist'. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3028 If MOVE is non-nil, move point past the present field before making |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3029 the new field. If INTERACTIVE is non-nil, move point to the end of |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3030 the new field. Otherwise move point past the new field. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3031 MOVE and INTERACTIVE are t when called interactively." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3032 (interactive |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
3033 (list (let ((completion-ignore-case t) |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
3034 (field-list (bibtex-field-list |
57815 | 3035 (save-excursion |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3036 (bibtex-beginning-of-entry) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3037 (looking-at bibtex-any-entry-maybe-empty-head) |
57815 | 3038 (bibtex-type-in-head))))) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
3039 (completing-read "BibTeX field name: " |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
3040 (append (car field-list) (cdr field-list)) |
57819
cc6cd5062afb
(bibtex-make-field): Don't use interactive-p.
Richard M. Stallman <rms@gnu.org>
parents:
57815
diff
changeset
|
3041 nil nil nil bibtex-field-history)) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3042 t t)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3043 (unless (consp field) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3044 (setq field (list field))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3045 (when move |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3046 (bibtex-find-text) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3047 (if (looking-at "[}\"]") |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3048 (forward-char))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3049 (insert ",\n") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3050 (indent-to-column (+ bibtex-entry-offset bibtex-field-indentation)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3051 (if (nth 3 field) (insert "ALT")) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3052 (insert (car field) " ") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3053 (if bibtex-align-at-equal-sign |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3054 (indent-to-column (+ bibtex-entry-offset |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3055 (- bibtex-text-indentation 2)))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3056 (insert "= ") |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3057 (unless bibtex-align-at-equal-sign |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3058 (indent-to-column (+ bibtex-entry-offset |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3059 bibtex-text-indentation))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3060 (let ((init (nth 2 field))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3061 (insert (cond ((stringp init) init) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3062 ((fboundp init) (funcall init)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3063 (t (concat (bibtex-field-left-delimiter) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3064 (bibtex-field-right-delimiter)))))) |
57833
1a602333ec1d
(bibtex-make-field): Fix typo.
John Paul Wallington <jpw@pobox.com>
parents:
57819
diff
changeset
|
3065 (when interactive |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3066 ;; (bibtex-find-text nil nil bibtex-help-message) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3067 (if (memq (preceding-char) '(?} ?\")) (forward-char -1)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3068 (if bibtex-help-message (bibtex-print-help-message (car field))))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3069 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3070 (defun bibtex-beginning-of-entry () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3071 "Move to beginning of BibTeX entry (beginning of line). |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3072 If inside an entry, move to the beginning of it, otherwise move to the |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
3073 beginning of the previous entry. If point is ahead of all BibTeX entries |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
3074 move point to the beginning of buffer. Return the new location of point." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3075 (interactive) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3076 (skip-chars-forward " \t") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3077 (if (looking-at "@") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3078 (forward-char)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3079 (re-search-backward "^[ \t]*@" nil 'move) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3080 (point)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3081 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3082 (defun bibtex-end-of-entry () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3083 "Move to end of BibTeX entry (past the closing brace). |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3084 If inside an entry, move to the end of it, otherwise move to the end |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
3085 of the previous entry. Do not move if ahead of first entry. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3086 Return the new location of point." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3087 (interactive) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3088 (let ((case-fold-search t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3089 (pnt (point)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3090 (_ (bibtex-beginning-of-entry)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3091 (bounds (bibtex-valid-entry t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3092 (cond (bounds (goto-char (cdr bounds))) ; regular entry |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3093 ;; @String or @Preamble |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3094 ((setq bounds (or (bibtex-parse-string t) (bibtex-parse-preamble))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3095 (goto-char (bibtex-end-of-string bounds))) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3096 ((looking-at bibtex-any-valid-entry-type) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3097 ;; Parsing of entry failed |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3098 (error "Syntactically incorrect BibTeX entry starts here.")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3099 (t (if (interactive-p) (message "Not on a known BibTeX entry.")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3100 (goto-char pnt))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3101 (point))) |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
3102 |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3103 (defun bibtex-goto-line (arg) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3104 "Goto line ARG, counting from beginning of (narrowed) buffer." |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3105 ;; code adapted from `goto-line' |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3106 (goto-char (point-min)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3107 (if (eq selective-display t) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3108 (re-search-forward "[\n\C-m]" nil 'end (1- arg)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3109 (forward-line (1- arg)))) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3110 |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3111 (defun bibtex-reposition-window () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3112 "Make the current BibTeX entry visible. |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3113 If entry is smaller than `window-body-height', entry is centered in window. |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3114 Otherwise display the beginning of entry." |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3115 (interactive) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3116 (let ((pnt (point)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3117 (beg (line-number-at-pos (bibtex-beginning-of-entry))) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3118 (end (line-number-at-pos (bibtex-end-of-entry)))) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3119 (if (> (window-body-height) (- end beg)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3120 ;; entry fits in current window |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3121 (progn |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3122 (bibtex-goto-line (/ (+ 1 beg end) 2)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3123 (recenter) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3124 (goto-char pnt)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3125 ;; entry too large for current window |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3126 (bibtex-goto-line beg) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3127 (recenter 0) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3128 (if (> (1+ (- (line-number-at-pos pnt) beg)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3129 (window-body-height)) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3130 (bibtex-goto-line beg) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3131 (goto-char pnt))))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3132 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3133 (defun bibtex-mark-entry () |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3134 "Put mark at beginning, point at end of current BibTeX entry." |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3135 (interactive) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3136 (set-mark (bibtex-beginning-of-entry)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3137 (bibtex-end-of-entry)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3138 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3139 (defun bibtex-count-entries (&optional count-string-entries) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3140 "Count number of entries in current buffer or region. |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3141 With prefix argument COUNT-STRING-ENTRIES count all entries, |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3142 otherwise count all entries except @String entries. |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3143 If mark is active count entries in region, if not in whole buffer." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3144 (interactive "P") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3145 (let ((number 0) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3146 (bibtex-sort-ignore-string-entries (not count-string-entries))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3147 (save-restriction |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3148 (if mark-active (narrow-to-region (region-beginning) (region-end))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3149 (bibtex-map-entries (lambda (key beg end) (setq number (1+ number))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3150 (message "%s contains %d entries." |
57815 | 3151 (if mark-active "Region" "Buffer") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3152 number))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3153 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3154 (defun bibtex-ispell-entry () |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3155 "Check BibTeX entry for spelling errors." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3156 (interactive) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3157 (ispell-region (save-excursion (bibtex-beginning-of-entry)) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3158 (save-excursion (bibtex-end-of-entry)))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3159 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3160 (defun bibtex-ispell-abstract () |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3161 "Check abstract of BibTeX entry for spelling errors." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3162 (interactive) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3163 (let ((bounds (save-excursion |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3164 (bibtex-beginning-of-entry) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3165 (bibtex-search-forward-field "abstract" t)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3166 (if bounds |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3167 (ispell-region (bibtex-start-of-text-in-field bounds) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3168 (bibtex-end-of-text-in-field bounds)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3169 (error "No abstract in entry")))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3170 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3171 (defun bibtex-narrow-to-entry () |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3172 "Narrow buffer to current BibTeX entry." |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3173 (interactive) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3174 (save-excursion |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3175 (widen) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3176 (narrow-to-region (bibtex-beginning-of-entry) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3177 (bibtex-end-of-entry)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3178 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3179 (defun bibtex-entry-index () |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3180 "Return index of BibTeX entry head at or past position of point. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3181 The index is a list (KEY CROSSREF-KEY ENTRY-NAME) that is used for sorting |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3182 the entries of the BibTeX buffer. CROSSREF-KEY is nil unless the value |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3183 of `bibtex-maintain-sorted-entries' is `crossref'. Move point to the end |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3184 of the head of the entry found. Return nil if no entry found." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3185 (let ((case-fold-search t)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3186 (if (re-search-forward bibtex-entry-maybe-empty-head nil t) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3187 (let ((key (bibtex-key-in-head)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3188 ;; all entry names should be downcase (for ease of comparison) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3189 (entry-name (downcase (bibtex-type-in-head)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3190 ;; Don't search CROSSREF-KEY if we don't need it. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3191 (if (eq bibtex-maintain-sorted-entries 'crossref) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3192 (let ((bounds (bibtex-search-forward-field |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3193 "\\(OPT\\)?crossref" t))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3194 (list key |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3195 (if bounds (bibtex-text-in-field-bounds bounds t)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3196 entry-name)) |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
3197 (list key nil entry-name)))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3198 |
71044
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3199 (defun bibtex-init-sort-entry-class-alist () |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3200 (unless (local-variable-p 'bibtex-sort-entry-class-alist) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3201 (set (make-local-variable 'bibtex-sort-entry-class-alist) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3202 (let ((i -1) alist) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3203 (dolist (class bibtex-sort-entry-class alist) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3204 (setq i (1+ i)) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3205 (dolist (entry class) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3206 ;; All entry names should be downcase (for ease of comparison). |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3207 (push (cons (if (stringp entry) (downcase entry) entry) i) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3208 alist))))))) |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3209 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3210 (defun bibtex-lessp (index1 index2) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3211 "Predicate for sorting BibTeX entries with indices INDEX1 and INDEX2. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3212 Each index is a list (KEY CROSSREF-KEY ENTRY-NAME). |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
3213 The predicate depends on the variable `bibtex-maintain-sorted-entries'. |
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
3214 If its value is nil use plain sorting." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3215 (cond ((not index1) (not index2)) ; indices can be nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3216 ((not index2) nil) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3217 ((eq bibtex-maintain-sorted-entries 'crossref) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3218 (if (nth 1 index1) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3219 (if (nth 1 index2) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3220 (or (string-lessp (nth 1 index1) (nth 1 index2)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3221 (and (string-equal (nth 1 index1) (nth 1 index2)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3222 (string-lessp (nth 0 index1) (nth 0 index2)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3223 (not (string-lessp (nth 0 index2) (nth 1 index1)))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3224 (if (nth 1 index2) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3225 (string-lessp (nth 0 index1) (nth 1 index2)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3226 (string-lessp (nth 0 index1) (nth 0 index2))))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3227 ((eq bibtex-maintain-sorted-entries 'entry-class) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3228 (let ((n1 (cdr (or (assoc (nth 2 index1) bibtex-sort-entry-class-alist) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3229 (assoc 'catch-all bibtex-sort-entry-class-alist) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3230 '(nil . 1000)))) ; if there is nothing else |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3231 (n2 (cdr (or (assoc (nth 2 index2) bibtex-sort-entry-class-alist) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3232 (assoc 'catch-all bibtex-sort-entry-class-alist) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3233 '(nil . 1000))))) ; if there is nothing else |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3234 (or (< n1 n2) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3235 (and (= n1 n2) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3236 (string-lessp (car index1) (car index2)))))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3237 (t ; (eq bibtex-maintain-sorted-entries 'plain) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3238 (string-lessp (car index1) (car index2))))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3239 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3240 (defun bibtex-sort-buffer () |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3241 "Sort BibTeX buffer alphabetically by key. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3242 The predicate for sorting is defined via `bibtex-maintain-sorted-entries'. |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
3243 If its value is nil use plain sorting. Text outside of BibTeX entries is not |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
3244 affected. If `bibtex-sort-ignore-string-entries' is non-nil, @String entries |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3245 are ignored." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3246 (interactive) |
71044
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3247 (bibtex-beginning-of-first-entry) ; Needed by `sort-subr' |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3248 (bibtex-init-sort-entry-class-alist) ; Needed by `bibtex-lessp'. |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3249 (sort-subr nil |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3250 'bibtex-skip-to-valid-entry ; NEXTREC function |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3251 'bibtex-end-of-entry ; ENDREC function |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3252 'bibtex-entry-index ; STARTKEY function |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3253 nil ; ENDKEY function |
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3254 'bibtex-lessp)) ; PREDICATE |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3255 |
57815 | 3256 (defun bibtex-find-crossref (crossref-key &optional pnt split) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3257 "Move point to the beginning of BibTeX entry CROSSREF-KEY. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3258 If `bibtex-files' is non-nil, search all these files. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3259 Otherwise the search is limited to the current buffer. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3260 Return position of entry if CROSSREF-KEY is found or nil otherwise. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3261 If CROSSREF-KEY is in the same buffer like current entry but before it |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3262 an error is signaled. Optional arg PNT is the position of the referencing |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3263 entry. It defaults to position of point. If optional arg SPLIT is non-nil, |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3264 split window so that both the referencing and the crossrefed entry are |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3265 displayed. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3266 If called interactively, CROSSREF-KEY defaults to crossref key of current |
57815 | 3267 entry and SPLIT is t." |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3268 (interactive |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3269 (let ((crossref-key |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3270 (save-excursion |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3271 (bibtex-beginning-of-entry) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3272 (let ((bounds (bibtex-search-forward-field "crossref" t))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3273 (if bounds |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3274 (bibtex-text-in-field-bounds bounds t)))))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3275 (list (bibtex-read-key "Find crossref key: " crossref-key t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3276 (point) t))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3277 (let (buffer pos eqb) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3278 (save-excursion |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3279 (setq pos (bibtex-find-entry crossref-key t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3280 buffer (current-buffer))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3281 (setq eqb (eq buffer (current-buffer))) |
57815 | 3282 (cond ((not pos) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3283 (if split (message "Crossref key `%s' not found" crossref-key))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3284 (split ; called (quasi) interactively |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3285 (unless pnt (setq pnt (point))) |
57815 | 3286 (goto-char pnt) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3287 (if eqb (select-window (split-window)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3288 (pop-to-buffer buffer)) |
57815 | 3289 (goto-char pos) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3290 (bibtex-reposition-window) |
57815 | 3291 (beginning-of-line) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3292 (if (and eqb (> pnt pos)) |
59733
96d73eb02751
(bibtex-format-entry): Use `bibtex-empty-field-re' only on the text of
Lute Kamstra <lute@gnu.org>
parents:
58772
diff
changeset
|
3293 (error "The referencing entry must precede the crossrefed entry!"))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3294 ;; `bibtex-find-crossref' is called noninteractively during |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3295 ;; clean-up of an entry. Then it is not possible to check |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3296 ;; whether the current entry and the crossrefed entry have |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3297 ;; the correct sorting order. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3298 (eqb (goto-char pos)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3299 (t (set-buffer buffer) (goto-char pos))) |
57815 | 3300 pos)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3301 |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3302 (defun bibtex-find-entry (key &optional global start display) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3303 "Move point to the beginning of BibTeX entry named KEY. |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3304 Return position of entry if KEY is found or nil if not found. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3305 With prefix arg GLOBAL non-nil, search KEY in `bibtex-files'. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3306 Otherwise the search is limited to the current buffer. |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3307 Optional arg START is buffer position where the search starts. |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3308 If it is nil, start search at beginning of buffer. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3309 If DISPLAY is non-nil, display the buffer containing KEY. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3310 Otherwise, use `set-buffer'. DISPLAY is t when called interactively." |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3311 (interactive (list (bibtex-read-key "Find key: " nil current-prefix-arg) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3312 current-prefix-arg nil t)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3313 (if (and global bibtex-files) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3314 (let ((buffer-list (bibtex-files-expand t)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3315 buffer found) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3316 (while (and (not found) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3317 (setq buffer (pop buffer-list))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3318 (with-current-buffer buffer |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3319 (if (cdr (assoc-string key bibtex-reference-keys)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3320 ;; `bibtex-find-entry' moves point if key found |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3321 (setq found (bibtex-find-entry key))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3322 (cond ((and found display) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3323 (let ((same-window-buffer-names |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3324 (cons (buffer-name buffer) same-window-buffer-names))) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3325 (pop-to-buffer buffer) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3326 (bibtex-reposition-window))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3327 (found (set-buffer buffer)) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3328 (display (message "Key `%s' not found" key))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3329 found) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3330 |
70210
83aa98a17215
(bibtex-find-entry): Don't demand matching case for @Article, etc.
J.D. Smith <jdsmith@as.arizona.edu>
parents:
69887
diff
changeset
|
3331 (let* ((case-fold-search t) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3332 (pnt (save-excursion |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3333 (goto-char (or start (point-min))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3334 (if (re-search-forward (concat "^[ \t]*\\(" |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3335 bibtex-entry-type |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3336 "\\)[ \t]*[({][ \t\n]*\\(" |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3337 (regexp-quote key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3338 "\\)[ \t\n]*[,=]") |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3339 nil t) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3340 (match-beginning 0))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3341 (cond (pnt |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3342 (goto-char pnt) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3343 (if display (bibtex-reposition-window))) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3344 (display (message "Key `%s' not found" key))) |
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3345 pnt))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3346 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3347 (defun bibtex-prepare-new-entry (index) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3348 "Prepare a new BibTeX entry with index INDEX. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3349 INDEX is a list (KEY CROSSREF-KEY ENTRY-NAME). |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3350 Move point where the entry KEY should be placed. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3351 If `bibtex-maintain-sorted-entries' is non-nil, perform a binary |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3352 search to look for place for KEY. This requires that buffer is sorted, |
62077
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
3353 see `bibtex-validate'. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3354 Return t if preparation was successful or nil if entry KEY already exists." |
71044
da5fa425123d
(bibtex-autokey-name-case-convert-function)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70841
diff
changeset
|
3355 (bibtex-init-sort-entry-class-alist) ; Needed by `bibtex-lessp'. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3356 (let ((key (nth 0 index)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3357 key-exist) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3358 (cond ((or (null key) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3359 (and (stringp key) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3360 (string-equal key "")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3361 (and (not (setq key-exist (bibtex-find-entry key))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3362 (not bibtex-maintain-sorted-entries))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3363 (bibtex-move-outside-of-entry)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3364 ;; if key-exist is non-nil due to the previous cond clause |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3365 ;; then point will be at beginning of entry named key. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3366 (key-exist) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3367 (t ; bibtex-maintain-sorted-entries is non-nil |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3368 (let* ((case-fold-search t) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3369 (left (save-excursion (bibtex-beginning-of-first-entry))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3370 (bounds (save-excursion (goto-char (point-max)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3371 (bibtex-skip-to-valid-entry t))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3372 (right (if bounds (cdr bounds) (point-min))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3373 (found (if (>= left right) left)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3374 actual-index new) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3375 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3376 ;; Binary search |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3377 (while (not found) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3378 (goto-char (/ (+ left right) 2)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3379 (bibtex-skip-to-valid-entry t) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3380 (setq actual-index (bibtex-entry-index)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3381 (cond ((bibtex-lessp index actual-index) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3382 (setq new (bibtex-beginning-of-entry)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3383 (if (equal right new) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3384 (setq found right) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3385 (setq right new))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3386 (t |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3387 (bibtex-end-of-entry) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3388 (bibtex-skip-to-valid-entry) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3389 (setq new (point)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3390 (if (equal left new) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3391 (setq found right) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3392 (setq left new)))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3393 (goto-char found) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3394 (bibtex-beginning-of-entry) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3395 (setq actual-index (save-excursion (bibtex-entry-index))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3396 (when (or (not actual-index) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3397 (bibtex-lessp actual-index index)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3398 ;; buffer contains no valid entries or |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3399 ;; greater than last entry --> append |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3400 (bibtex-end-of-entry) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3401 (unless (bobp) (newline (forward-line 2))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3402 (beginning-of-line))))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3403 (unless key-exist t))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3404 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3405 (defun bibtex-validate (&optional test-thoroughly) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3406 "Validate if buffer or region is syntactically correct. |
57815 | 3407 Check also for duplicate keys and correct sort order provided |
3408 `bibtex-maintain-sorted-entries' is non-nil. | |
3409 With optional argument TEST-THOROUGHLY non-nil check also for | |
3410 the absence of required fields and for questionable month fields. | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3411 If mark is active, validate current region, if not the whole buffer. |
57815 | 3412 Only check known entry types, so you can put comments outside of entries. |
3413 Return t if test was successful, nil otherwise." | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3414 (interactive "P") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3415 (let* ((case-fold-search t) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3416 error-list syntax-error) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3417 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3418 (save-restriction |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3419 (if mark-active (narrow-to-region (region-beginning) (region-end))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3420 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3421 ;; Check syntactical structure of entries |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3422 (goto-char (point-min)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3423 (bibtex-progress-message "Checking syntactical structure") |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3424 (let (bounds end) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3425 (while (setq end (re-search-forward "^[ \t]*@" nil t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3426 (bibtex-progress-message) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3427 (goto-char (match-beginning 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3428 (cond ((setq bounds (bibtex-valid-entry)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3429 (goto-char (cdr bounds))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3430 ((setq bounds (or (bibtex-parse-string) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3431 (bibtex-parse-preamble))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3432 (goto-char (bibtex-end-of-string bounds))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3433 ((looking-at bibtex-any-valid-entry-type) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3434 (push (cons (bibtex-current-line) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3435 "Syntax error (check esp. commas, braces, and quotes)") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3436 error-list) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3437 (goto-char (match-end 0))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3438 (t (goto-char end))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3439 (bibtex-progress-message 'done) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3440 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3441 (if error-list |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3442 ;; Continue only if there were no syntax errors. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3443 (setq syntax-error t) |
57815 | 3444 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3445 ;; Check for duplicate keys and correct sort order |
57815 | 3446 (let (previous current key-list) |
3447 (bibtex-progress-message "Checking for duplicate keys") | |
3448 (bibtex-map-entries | |
3449 (lambda (key beg end) | |
3450 (bibtex-progress-message) | |
3451 (setq current (bibtex-entry-index)) | |
3452 (cond ((not previous)) | |
3453 ((member key key-list) | |
3454 (push (cons (bibtex-current-line) | |
3455 (format "Duplicate key `%s'" key)) | |
3456 error-list)) | |
3457 ((and bibtex-maintain-sorted-entries | |
3458 (not (bibtex-lessp previous current))) | |
3459 (push (cons (bibtex-current-line) | |
3460 "Entries out of order") | |
3461 error-list))) | |
3462 (push key key-list) | |
3463 (setq previous current))) | |
3464 (bibtex-progress-message 'done)) | |
3465 | |
3466 ;; Check for duplicate keys in `bibtex-files'. | |
3467 (bibtex-parse-keys) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3468 ;; We don't want to be fooled by outdated `bibtex-reference-keys'. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3469 (dolist (buffer (bibtex-files-expand nil t)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3470 (dolist (key (with-current-buffer buffer bibtex-reference-keys)) |
57815 | 3471 (when (and (cdr key) |
3472 (cdr (assoc-string (car key) bibtex-reference-keys))) | |
3473 (bibtex-find-entry (car key)) | |
3474 (push (cons (bibtex-current-line) | |
3475 (format "Duplicate key `%s' in %s" (car key) | |
3476 (abbreviate-file-name (buffer-file-name buffer)))) | |
3477 error-list)))) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3478 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3479 (when test-thoroughly |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3480 (bibtex-progress-message |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3481 "Checking required fields and month fields") |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3482 (let ((bibtex-sort-ignore-string-entries t)) |
18247
ae094c1a4334
(bibtex-delete-whitespace, bibtex-current-line)
Richard M. Stallman <rms@gnu.org>
parents:
18212
diff
changeset
|
3483 (bibtex-map-entries |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3484 (lambda (key beg end) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3485 (bibtex-progress-message) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3486 (let* ((entry-list (assoc-string (bibtex-type-in-head) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3487 bibtex-entry-field-alist t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3488 (req (copy-sequence (elt (elt entry-list 1) 0))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3489 (creq (copy-sequence (elt (elt entry-list 2) 0))) |
57815 | 3490 crossref-there bounds alt-there field) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3491 (bibtex-beginning-first-field beg) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3492 (while (setq bounds (bibtex-parse-field)) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3493 (let ((field-name (bibtex-name-in-field bounds))) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3494 (if (and (bibtex-string= field-name "month") |
57815 | 3495 ;; Check only abbreviated month fields. |
3496 (let ((month (bibtex-text-in-field-bounds bounds))) | |
3497 (not (or (string-match "\\`[\"{].+[\"}]\\'" month) | |
3498 (assoc-string | |
3499 month | |
3500 bibtex-predefined-month-strings t))))) | |
3501 (push (cons (bibtex-current-line) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3502 "Questionable month field") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3503 error-list)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3504 (setq field (assoc-string field-name req t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3505 req (delete field req) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3506 creq (delete (assoc-string field-name creq t) creq)) |
57815 | 3507 (if (nth 3 field) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3508 (if alt-there |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3509 (push (cons (bibtex-current-line) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3510 "More than one non-empty alternative") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3511 error-list) |
57815 | 3512 (setq alt-there t))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3513 (if (bibtex-string= field-name "crossref") |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3514 (setq crossref-there t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3515 (goto-char (bibtex-end-of-field bounds))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3516 (if crossref-there (setq req creq)) |
57815 | 3517 (let (alt) |
3518 (dolist (field req) | |
3519 (if (nth 3 field) | |
3520 (push (car field) alt) | |
3521 (push (cons (save-excursion (goto-char beg) | |
3522 (bibtex-current-line)) | |
3523 (format "Required field `%s' missing" | |
3524 (car field))) | |
3525 error-list))) | |
3526 ;; The following fails if there are more than two | |
3527 ;; alternatives in a BibTeX entry, which isn't | |
3528 ;; the case momentarily. | |
3529 (if (cdr alt) | |
3530 (push (cons (save-excursion (goto-char beg) | |
3531 (bibtex-current-line)) | |
3532 (format "Alternative fields `%s'/`%s' missing" | |
3533 (car alt) (cadr alt))) | |
3534 error-list))))))) | |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3535 (bibtex-progress-message 'done))))) |
57815 | 3536 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3537 (if error-list |
57815 | 3538 (let ((file (file-name-nondirectory (buffer-file-name))) |
3539 (dir default-directory) | |
3540 (err-buf "*BibTeX validation errors*")) | |
3541 (setq error-list (sort error-list 'car-less-than-car)) | |
3542 (with-current-buffer (get-buffer-create err-buf) | |
3543 (setq default-directory dir) | |
3544 (unless (eq major-mode 'compilation-mode) (compilation-mode)) | |
3545 (toggle-read-only -1) | |
3546 (delete-region (point-min) (point-max)) | |
3547 (insert "BibTeX mode command `bibtex-validate'\n" | |
3548 (if syntax-error | |
3549 "Maybe undetected errors due to syntax errors. Correct and validate again.\n" | |
3550 "\n")) | |
3551 (dolist (err error-list) | |
3552 (insert (format "%s:%d: %s\n" file (car err) (cdr err)))) | |
3553 (set-buffer-modified-p nil) | |
3554 (toggle-read-only 1) | |
3555 (goto-line 3)) ; first error message | |
3556 (display-buffer err-buf) | |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3557 nil) ; return `nil' (i.e., buffer is invalid) |
57815 | 3558 (message "%s is syntactically correct" |
3559 (if mark-active "Region" "Buffer")) | |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3560 t))) ; return `t' (i.e., buffer is valid) |
57815 | 3561 |
3562 (defun bibtex-validate-globally (&optional strings) | |
3563 "Check for duplicate keys in `bibtex-files'. | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3564 With optional prefix arg STRINGS, check for duplicate strings, too. |
57815 | 3565 Return t if test was successful, nil otherwise." |
3566 (interactive "P") | |
3567 (let ((buffer-list (bibtex-files-expand t)) | |
3568 buffer-key-list current-buf current-keys error-list) | |
3569 ;; Check for duplicate keys within BibTeX buffer | |
3570 (dolist (buffer buffer-list) | |
3571 (save-excursion | |
3572 (set-buffer buffer) | |
3573 (let (entry-type key key-list) | |
3574 (goto-char (point-min)) | |
3575 (while (re-search-forward bibtex-entry-head nil t) | |
3576 (setq entry-type (bibtex-type-in-head) | |
3577 key (bibtex-key-in-head)) | |
3578 (if (or (and strings (bibtex-string= entry-type "string")) | |
3579 (assoc-string entry-type bibtex-entry-field-alist t)) | |
3580 (if (member key key-list) | |
3581 (push (format "%s:%d: Duplicate key `%s'\n" | |
3582 (buffer-file-name) | |
3583 (bibtex-current-line) key) | |
3584 error-list) | |
3585 (push key key-list)))) | |
3586 (push (cons buffer key-list) buffer-key-list)))) | |
3587 | |
3588 ;; Check for duplicate keys among BibTeX buffers | |
3589 (while (setq current-buf (pop buffer-list)) | |
3590 (setq current-keys (cdr (assq current-buf buffer-key-list))) | |
3591 (with-current-buffer current-buf | |
3592 (dolist (buffer buffer-list) | |
3593 (dolist (key (cdr (assq buffer buffer-key-list))) | |
3594 (when (assoc-string key current-keys) | |
3595 (bibtex-find-entry key) | |
68065
0624a54493b5
(bibtex-validate-globally): Fix typo in a message text:
Eli Zaretskii <eliz@gnu.org>
parents:
67933
diff
changeset
|
3596 (push (format "%s:%d: Duplicate key `%s' in %s\n" |
57815 | 3597 (buffer-file-name) (bibtex-current-line) key |
3598 (abbreviate-file-name (buffer-file-name buffer))) | |
3599 error-list)))))) | |
3600 | |
3601 ;; Process error list | |
3602 (if error-list | |
3603 (let ((err-buf "*BibTeX validation errors*")) | |
3604 (with-current-buffer (get-buffer-create err-buf) | |
3605 (unless (eq major-mode 'compilation-mode) (compilation-mode)) | |
3606 (toggle-read-only -1) | |
3607 (delete-region (point-min) (point-max)) | |
3608 (insert "BibTeX mode command `bibtex-validate-globally'\n\n") | |
3609 (dolist (err (sort error-list 'string-lessp)) (insert err)) | |
3610 (set-buffer-modified-p nil) | |
3611 (toggle-read-only 1) | |
3612 (goto-line 3)) ; first error message | |
3613 (display-buffer err-buf) | |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3614 nil) ; return `nil' (i.e., buffer is invalid) |
57815 | 3615 (message "No duplicate keys.") |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3616 t))) ; return `t' (i.e., buffer is valid) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3617 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3618 (defun bibtex-next-field (begin &optional comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3619 "Move point to end of text of next BibTeX field or entry head. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3620 With prefix BEGIN non-nil, move point to its beginning. Optional arg COMMA |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3621 is as in `bibtex-enclosing-field'. It is t for interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3622 (interactive (list current-prefix-arg t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3623 (let ((bounds (bibtex-find-text-internal t nil comma)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3624 end-of-entry) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3625 (if (not bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3626 (setq end-of-entry t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3627 (goto-char (nth 3 bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3628 (if (assoc-string (car bounds) '("@String" "@Preamble") t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3629 (setq end-of-entry t) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3630 ;; BibTeX key or field |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3631 (if (looking-at ",[ \t\n]*") (goto-char (match-end 0))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3632 ;; end of entry |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3633 (if (looking-at "[)}][ \t\n]*") (setq end-of-entry t)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3634 (if (and end-of-entry |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3635 (re-search-forward bibtex-any-entry-maybe-empty-head nil t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3636 (goto-char (match-beginning 0))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3637 (bibtex-find-text begin nil bibtex-help-message))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3638 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3639 (defun bibtex-find-text (&optional begin noerror help comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3640 "Move point to end of text of current BibTeX field or entry head. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3641 With optional prefix BEGIN non-nil, move point to its beginning. |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3642 Unless NOERROR is non-nil, an error is signaled if point is not |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3643 on a BibTeX field. If optional arg HELP is non-nil print help message. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3644 When called interactively, the value of HELP is `bibtex-help-message'. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3645 Optional arg COMMA is as in `bibtex-enclosing-field'. It is t for |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3646 interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3647 (interactive (list current-prefix-arg nil bibtex-help-message t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3648 (let ((bounds (bibtex-find-text-internal t nil comma))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3649 (cond (bounds |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3650 (if begin |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3651 (progn (goto-char (nth 1 bounds)) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3652 (if (looking-at "[{\"]") |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3653 (forward-char))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3654 (goto-char (nth 2 bounds)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3655 (if (memq (preceding-char) '(?} ?\")) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3656 (forward-char -1))) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3657 (if help (bibtex-print-help-message (car bounds)))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3658 ((not noerror) (error "Not on BibTeX field"))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3659 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3660 (defun bibtex-find-text-internal (&optional noerror subfield comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3661 "Find text part of current BibTeX field or entry head. |
69886
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3662 Return list (NAME START-TEXT END-TEXT END STRING-CONST) with field |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3663 or entry name, start and end of text, and end of field or entry head. |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3664 STRING-CONST is a flag which is non-nil if current subfield delimited by # |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3665 is a BibTeX string constant. Return value is nil if field or entry head |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3666 are not found. |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3667 If optional arg NOERROR is non-nil, an error message is suppressed |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3668 if text is not found. If optional arg SUBFIELD is non-nil START-TEXT |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3669 and END-TEXT correspond to the current subfield delimited by #. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3670 Optional arg COMMA is as in `bibtex-enclosing-field'." |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3671 (save-excursion |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3672 (let ((pnt (point)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3673 (bounds (bibtex-enclosing-field comma t)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3674 (case-fold-search t) |
69886
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3675 name start-text end-text end failure done no-sub string-const) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3676 (bibtex-beginning-of-entry) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3677 (cond (bounds |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3678 (setq name (bibtex-name-in-field bounds t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3679 start-text (bibtex-start-of-text-in-field bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3680 end-text (bibtex-end-of-text-in-field bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3681 end (bibtex-end-of-field bounds))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3682 ;; @String |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3683 ((setq bounds (bibtex-parse-string t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3684 (if (<= pnt (bibtex-end-of-string bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3685 (setq name "@String" ;; not a field name! |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3686 start-text (bibtex-start-of-text-in-string bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3687 end-text (bibtex-end-of-text-in-string bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3688 end (bibtex-end-of-string bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3689 (setq failure t))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3690 ;; @Preamble |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3691 ((setq bounds (bibtex-parse-preamble)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3692 (if (<= pnt (bibtex-end-of-string bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3693 (setq name "@Preamble" ;; not a field name! |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3694 start-text (bibtex-start-of-text-in-string bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3695 end-text (bibtex-end-of-text-in-string bounds) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3696 end (bibtex-end-of-string bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3697 (setq failure t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3698 ;; BibTeX head |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3699 ((looking-at bibtex-entry-maybe-empty-head) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3700 (goto-char (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3701 (if comma (save-match-data |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3702 (re-search-forward "\\=[ \t\n]*," nil t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3703 (if (<= pnt (point)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3704 (setq name (match-string-no-properties bibtex-type-in-head) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3705 start-text (or (match-beginning bibtex-key-in-head) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3706 (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3707 end-text (or (match-end bibtex-key-in-head) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3708 (match-end 0)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3709 end end-text |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3710 no-sub t) ;; subfields do not make sense |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3711 (setq failure t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3712 (t (setq failure t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3713 (when (and subfield (not failure)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3714 (setq failure no-sub) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3715 (unless failure |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3716 (goto-char start-text) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3717 (while (not done) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3718 (if (or (prog1 (looking-at bibtex-field-const) |
69886
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3719 (setq end-text (match-end 0) |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3720 string-const t)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3721 (prog1 (setq bounds (bibtex-parse-field-string)) |
69886
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3722 (setq end-text (cdr bounds) |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3723 string-const nil))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3724 (progn |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3725 (if (and (<= start-text pnt) (<= pnt end-text)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3726 (setq done t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3727 (goto-char end-text)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3728 (if (looking-at "[ \t\n]*#[ \t\n]*") |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3729 (setq start-text (goto-char (match-end 0))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3730 (setq done t failure t))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3731 (cond ((not failure) |
69886
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3732 (list name start-text end-text end string-const)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3733 ((and no-sub (not noerror)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3734 (error "Not on text part of BibTeX field")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3735 ((not noerror) (error "Not on BibTeX field")))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3736 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3737 (defun bibtex-remove-OPT-or-ALT (&optional comma) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3738 "Remove the string starting optional/alternative fields. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3739 Align text and go thereafter to end of text. Optional arg COMMA |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3740 is as in `bibtex-enclosing-field'. It is t for interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3741 (interactive (list t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3742 (let ((case-fold-search t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3743 (bounds (bibtex-enclosing-field comma))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3744 (save-excursion |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
3745 (goto-char (bibtex-start-of-name-in-field bounds)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3746 (when (looking-at "OPT\\|ALT") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3747 (delete-region (match-beginning 0) (match-end 0)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3748 ;; make field non-OPT |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3749 (search-forward "=") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3750 (forward-char -1) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3751 (delete-horizontal-space) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3752 (if bibtex-align-at-equal-sign |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3753 (indent-to-column (- bibtex-text-indentation 2)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3754 (insert " ")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3755 (search-forward "=") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3756 (delete-horizontal-space) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3757 (if bibtex-align-at-equal-sign |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3758 (insert " ") |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3759 (indent-to-column bibtex-text-indentation)))))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3760 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3761 (defun bibtex-remove-delimiters (&optional comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3762 "Remove \"\" or {} around current BibTeX field text. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3763 Optional arg COMMA is as in `bibtex-enclosing-field'. It is t for |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3764 interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3765 (interactive (list t)) |
69886
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3766 (let ((bounds (bibtex-find-text-internal nil t comma))) |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3767 (unless (nth 4 bounds) |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3768 (delete-region (1- (nth 2 bounds)) (nth 2 bounds)) |
0da18bcb2c37
(bibtex-find-text-internal): Add new element string-const to return value.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
69581
diff
changeset
|
3769 (delete-region (nth 1 bounds) (1+ (nth 1 bounds)))))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3770 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3771 (defun bibtex-kill-field (&optional copy-only comma) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3772 "Kill the entire enclosing BibTeX field. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3773 With prefix arg COPY-ONLY, copy the current field to `bibtex-field-kill-ring', |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3774 but do not actually kill it. Optional arg COMMA is as in |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3775 `bibtex-enclosing-field'. It is t for interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3776 (interactive (list current-prefix-arg t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3777 (save-excursion |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
3778 (let* ((case-fold-search t) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3779 (bounds (bibtex-enclosing-field comma)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3780 (end (bibtex-end-of-field bounds)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3781 (beg (bibtex-start-of-field bounds))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3782 (goto-char end) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3783 (skip-chars-forward ",") |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3784 (push (list (bibtex-name-in-field bounds) nil |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3785 (bibtex-text-in-field-bounds bounds)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3786 bibtex-field-kill-ring) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3787 (if (> (length bibtex-field-kill-ring) bibtex-field-kill-ring-max) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3788 (setcdr (nthcdr (1- bibtex-field-kill-ring-max) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3789 bibtex-field-kill-ring) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3790 nil)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3791 (setq bibtex-field-kill-ring-yank-pointer bibtex-field-kill-ring) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3792 (unless copy-only |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3793 (delete-region beg end)))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3794 (setq bibtex-last-kill-command 'field)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3795 |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3796 (defun bibtex-copy-field-as-kill (&optional comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3797 "Copy the BibTeX field at point to the kill ring. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3798 Optional arg COMMA is as in `bibtex-enclosing-field'. It is t for |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3799 interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3800 (interactive (list t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3801 (bibtex-kill-field t comma)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3802 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3803 (defun bibtex-kill-entry (&optional copy-only) |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
3804 "Kill the entire enclosing BibTeX entry. |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3805 With prefix arg COPY-ONLY, copy the current entry to `bibtex-entry-kill-ring', |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3806 but do not actually kill it." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3807 (interactive "P") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3808 (save-excursion |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3809 (let* ((case-fold-search t) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3810 (beg (bibtex-beginning-of-entry)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3811 (end (progn (bibtex-end-of-entry) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3812 (if (re-search-forward |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3813 bibtex-any-entry-maybe-empty-head nil 'move) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3814 (goto-char (match-beginning 0))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3815 (point)))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3816 (push (buffer-substring-no-properties beg end) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3817 bibtex-entry-kill-ring) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3818 (if (> (length bibtex-entry-kill-ring) bibtex-entry-kill-ring-max) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3819 (setcdr (nthcdr (1- bibtex-entry-kill-ring-max) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3820 bibtex-entry-kill-ring) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3821 nil)) |
57815 | 3822 (setq bibtex-entry-kill-ring-yank-pointer bibtex-entry-kill-ring) |
3823 (unless copy-only | |
3824 (delete-region beg end)))) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3825 (setq bibtex-last-kill-command 'entry)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3826 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3827 (defun bibtex-copy-entry-as-kill () |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3828 "Copy the entire enclosing BibTeX entry to `bibtex-entry-kill-ring'." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3829 (interactive) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3830 (bibtex-kill-entry t)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3831 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3832 (defun bibtex-yank (&optional n) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3833 "Reinsert the last BibTeX item. |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3834 More precisely, reinsert the field or entry killed or yanked most recently. |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3835 With argument N, reinsert the Nth most recently killed BibTeX item. |
62077
e233a73cbf79
(bibtex-summary): Use current BibTeX entry to avoid calling
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
61439
diff
changeset
|
3836 See also the command \\[bibtex-yank-pop]." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3837 (interactive "*p") |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3838 (bibtex-insert-kill (1- n) t) |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
3839 (setq this-command 'bibtex-yank)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3840 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3841 (defun bibtex-yank-pop (n) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3842 "Replace just-yanked killed BibTeX item with a different item. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3843 This command is allowed only immediately after a `bibtex-yank' or a |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3844 `bibtex-yank-pop'. In this case, the region contains a reinserted |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3845 previously killed BibTeX item. `bibtex-yank-pop' deletes that item |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3846 and inserts in its place a different killed BibTeX item. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3847 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3848 With no argument, the previous kill is inserted. |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3849 With argument N, insert the Nth previous kill. |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3850 If N is negative, this is a more recent kill. |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3851 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3852 The sequence of kills wraps around, so that after the oldest one |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3853 comes the newest one." |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3854 (interactive "*p") |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3855 (unless (eq last-command 'bibtex-yank) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3856 (error "Previous command was not a BibTeX yank")) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3857 (setq this-command 'bibtex-yank) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3858 (let ((inhibit-read-only t)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3859 (delete-region (point) (mark t)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3860 (bibtex-insert-kill n t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3861 |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3862 (defun bibtex-empty-field (&optional comma) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3863 "Delete the text part of the current field, replace with empty text. |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3864 Optional arg COMMA is as in `bibtex-enclosing-field'. It is t for |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3865 interactive calls." |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3866 (interactive (list t)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3867 (let ((bounds (bibtex-enclosing-field comma))) |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
3868 (goto-char (bibtex-start-of-text-in-field bounds)) |
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
3869 (delete-region (point) (bibtex-end-of-text-in-field bounds)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3870 (insert (bibtex-field-left-delimiter) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3871 (bibtex-field-right-delimiter)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
3872 (bibtex-find-text t nil bibtex-help-message))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3873 |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
3874 (defun bibtex-pop-previous (arg) |
19461 | 3875 "Replace text of current field with the similar field in previous entry. |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
3876 With arg, goes up ARG entries. Repeated, goes up so many times. May be |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
3877 intermixed with \\[bibtex-pop-next] (bibtex-pop-next)." |
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
3878 (interactive "p") |
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
3879 (bibtex-pop arg 'previous)) |
257 | 3880 |
3881 (defun bibtex-pop-next (arg) | |
3882 "Replace text of current field with the text of similar field in next entry. | |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
3883 With arg, goes down ARG entries. Repeated, goes down so many times. May be |
257 | 3884 intermixed with \\[bibtex-pop-previous] (bibtex-pop-previous)." |
3885 (interactive "p") | |
14789
d68b71228abd
(bibtex-pop): New generic function which unifies the
Richard M. Stallman <rms@gnu.org>
parents:
14410
diff
changeset
|
3886 (bibtex-pop arg 'next)) |
257 | 3887 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3888 (defun bibtex-clean-entry (&optional new-key called-by-reformat) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
3889 "Finish editing the current BibTeX entry and clean it up. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3890 Check that no required fields are empty and formats entry dependent |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3891 on the value of `bibtex-entry-format'. |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
3892 If the reference key of the entry is empty or a prefix argument is given, |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
3893 calculate a new reference key. (Note: this works only if fields in entry |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3894 begin on separate lines prior to calling `bibtex-clean-entry' or if |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3895 'realign is contained in `bibtex-entry-format'.) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3896 Don't call `bibtex-clean-entry' on @Preamble entries. |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3897 At end of the cleaning process, the functions in |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3898 `bibtex-clean-entry-hook' are called with region narrowed to entry." |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3899 ;; Opt. arg called-by-reformat is t if bibtex-clean-entry |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3900 ;; is called by bibtex-reformat |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
3901 (interactive "P") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3902 (let ((case-fold-search t) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3903 (start (bibtex-beginning-of-entry)) |
70841
2a874a2efaf4
(bibtex-format-entry, bibtex-clean-entry):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70837
diff
changeset
|
3904 (_ (or (looking-at bibtex-any-entry-maybe-empty-head) |
2a874a2efaf4
(bibtex-format-entry, bibtex-clean-entry):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
70837
diff
changeset
|
3905 (error "Not inside a BibTeX entry"))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3906 (entry-type (bibtex-type-in-head)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3907 (key (bibtex-key-in-head))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3908 ;; formatting |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3909 (cond ((bibtex-string= entry-type "preamble") |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3910 ;; (bibtex-format-preamble) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3911 (error "No clean up of @Preamble entries")) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3912 ((bibtex-string= entry-type "string") |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3913 (setq entry-type 'string)) |
57815 | 3914 ;; (bibtex-format-string) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3915 (t (bibtex-format-entry))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3916 ;; set key |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
3917 (when (or new-key (not key)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3918 (setq key (bibtex-generate-autokey)) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3919 ;; Sometimes bibtex-generate-autokey returns an empty string |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3920 (if (or bibtex-autokey-edit-before-use (string= "" key)) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3921 (setq key (if (eq entry-type 'string) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3922 (bibtex-read-string-key key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3923 (bibtex-read-key "Key to use: " key)))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3924 (save-excursion |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3925 (re-search-forward (if (eq entry-type 'string) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3926 bibtex-string-maybe-empty-head |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3927 bibtex-entry-maybe-empty-head)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3928 (if (match-beginning bibtex-key-in-head) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3929 (delete-region (match-beginning bibtex-key-in-head) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3930 (match-end bibtex-key-in-head))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3931 (insert key))) |
57815 | 3932 |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
3933 (unless called-by-reformat |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3934 (let* ((end (save-excursion |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3935 (bibtex-end-of-entry) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3936 (if (re-search-forward |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3937 bibtex-entry-maybe-empty-head nil 'move) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3938 (goto-char (match-beginning 0))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3939 (point))) |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
3940 (entry (buffer-substring start end)) |
57815 | 3941 ;; include the crossref key in index |
3942 (index (let ((bibtex-maintain-sorted-entries 'crossref)) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3943 (bibtex-entry-index))) ; moves point to end of head |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3944 error) |
57815 | 3945 ;; sorting |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
3946 (if (and bibtex-maintain-sorted-entries |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
3947 (not (and bibtex-sort-ignore-string-entries |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3948 (eq entry-type 'string)))) |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
3949 (progn |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
3950 (delete-region start end) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3951 (setq error (not (bibtex-prepare-new-entry index)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3952 start (point)) ; update start |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3953 (save-excursion (insert entry))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3954 (bibtex-find-entry key) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3955 (setq error (or (/= (point) start) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3956 (bibtex-find-entry key nil end)))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
3957 (if error |
57815 | 3958 (error "New inserted entry yields duplicate key")) |
3959 (dolist (buffer (bibtex-files-expand)) | |
3960 (with-current-buffer buffer | |
3961 (if (cdr (assoc-string key bibtex-reference-keys)) | |
3962 (error "Duplicate key in %s" (buffer-file-name))))) | |
3963 | |
3964 ;; Only update the list of keys if it has been built already. | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3965 (cond ((eq entry-type 'string) |
57815 | 3966 (if (and (listp bibtex-strings) |
3967 (not (assoc key bibtex-strings))) | |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3968 (push (cons key (bibtex-text-in-string |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3969 (bibtex-parse-string) t)) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
3970 bibtex-strings))) |
57815 | 3971 ;; We have a normal entry. |
3972 ((listp bibtex-reference-keys) | |
3973 (cond ((not (assoc key bibtex-reference-keys)) | |
3974 (push (cons key t) bibtex-reference-keys)) | |
3975 ((not (cdr (assoc key bibtex-reference-keys))) | |
3976 ;; Turn a crossref key into a header key | |
3977 (setq bibtex-reference-keys | |
3978 (cons (cons key t) | |
3979 (delete (list key) bibtex-reference-keys))))) | |
3980 ;; Handle crossref key. | |
3981 (if (and (nth 1 index) | |
3982 (not (assoc (nth 1 index) bibtex-reference-keys))) | |
3983 (push (list (nth 1 index)) bibtex-reference-keys))))) | |
3984 | |
3985 ;; final clean up | |
3986 (if bibtex-clean-entry-hook | |
3987 (save-excursion | |
3988 (save-restriction | |
3989 (bibtex-narrow-to-entry) | |
3990 (run-hooks 'bibtex-clean-entry-hook))))))) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
3991 |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3992 (defun bibtex-fill-field-bounds (bounds justify &optional move) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3993 "Fill BibTeX field delimited by BOUNDS. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3994 If JUSTIFY is non-nil justify as well. |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3995 If optional arg MOVE is non-nil move point to end of field." |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
3996 (let ((end-field (copy-marker (bibtex-end-of-field bounds)))) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3997 (if (not justify) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3998 (goto-char (bibtex-start-of-text-in-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
3999 (goto-char (bibtex-start-of-field bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4000 (forward-char) ;; leading comma |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4001 (bibtex-delete-whitespace) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4002 (open-line 1) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4003 (forward-char) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4004 (indent-to-column (+ bibtex-entry-offset |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4005 bibtex-field-indentation)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4006 (re-search-forward "[ \t\n]*=" end-field) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4007 (replace-match "=") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4008 (forward-char -1) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4009 (if bibtex-align-at-equal-sign |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4010 (indent-to-column |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4011 (+ bibtex-entry-offset (- bibtex-text-indentation 2))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4012 (insert " ")) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4013 (forward-char) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4014 (bibtex-delete-whitespace) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4015 (if bibtex-align-at-equal-sign |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4016 (insert " ") |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4017 (indent-to-column bibtex-text-indentation))) |
65776
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
4018 ;; Paragraphs within fields are not preserved. Bother? |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
4019 (fill-region-as-paragraph (line-beginning-position) end-field |
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
4020 default-justification nil (point)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4021 (if move (goto-char end-field)))) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4022 |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4023 (defun bibtex-fill-field (&optional justify) |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4024 "Like \\[fill-paragraph], but fill current BibTeX field. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4025 If optional prefix JUSTIFY is non-nil justify as well. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4026 In BibTeX mode this function is bound to `fill-paragraph-function'." |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4027 (interactive "*P") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4028 (let ((pnt (copy-marker (point))) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4029 (bounds (bibtex-enclosing-field t))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4030 (bibtex-fill-field-bounds bounds justify) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4031 (goto-char pnt))) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4032 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4033 (defun bibtex-fill-entry () |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4034 "Fill current BibTeX entry. |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4035 Realign entry, so that every field starts on a separate line. Field |
19461 | 4036 names appear in column `bibtex-field-indentation', field text starts in |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4037 column `bibtex-text-indentation' and continuation lines start here, too. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4038 If `bibtex-align-at-equal-sign' is non-nil, align equal signs, too." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4039 (interactive "*") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4040 (let ((pnt (copy-marker (point))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4041 (end (copy-marker (bibtex-end-of-entry))) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4042 (beg (bibtex-beginning-of-entry)) ; move point |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4043 bounds) |
18247
ae094c1a4334
(bibtex-delete-whitespace, bibtex-current-line)
Richard M. Stallman <rms@gnu.org>
parents:
18212
diff
changeset
|
4044 (bibtex-delete-whitespace) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4045 (indent-to-column bibtex-entry-offset) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4046 (bibtex-beginning-first-field beg) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4047 (while (setq bounds (bibtex-parse-field)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4048 (bibtex-fill-field-bounds bounds t t)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4049 (if (looking-at ",") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4050 (forward-char)) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4051 (skip-chars-backward " \t\n") |
18247
ae094c1a4334
(bibtex-delete-whitespace, bibtex-current-line)
Richard M. Stallman <rms@gnu.org>
parents:
18212
diff
changeset
|
4052 (bibtex-delete-whitespace) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4053 (open-line 1) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4054 (forward-char) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4055 (indent-to-column bibtex-entry-offset) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4056 (goto-char pnt))) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4057 |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4058 (defun bibtex-realign () |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4059 "Realign BibTeX entries such that they are separated by one blank line." |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4060 (goto-char (point-min)) |
65776
a2bc28552d90
2005-10-01 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Romain Francoise <romain@orebokech.com>
parents:
65583
diff
changeset
|
4061 (let ((case-fold-search t) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4062 (entry-type (concat "[ \t\n]*\\(" bibtex-entry-type "\\)"))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4063 ;; No blank lines prior to the first entry if there no |
57815 | 4064 ;; non-white characters in front of it. |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4065 (when (looking-at entry-type) |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4066 (replace-match "\\1")) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4067 ;; Entries are separated by one blank line. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4068 (while (re-search-forward entry-type nil t) |
57815 | 4069 (replace-match "\n\n\\1")) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4070 ;; One blank line past the last entry if it is followed by |
57815 | 4071 ;; non-white characters, no blank line otherwise. |
4072 (beginning-of-line) | |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4073 (when (re-search-forward bibtex-entry-type nil t) |
57815 | 4074 (bibtex-end-of-entry) |
4075 (bibtex-delete-whitespace) | |
4076 (open-line (if (eobp) 1 2))))) | |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4077 |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4078 (defun bibtex-reformat (&optional read-options) |
19461 | 4079 "Reformat all BibTeX entries in buffer or region. |
57815 | 4080 Without prefix argument, reformatting is based on `bibtex-entry-format'. |
19461 | 4081 With prefix argument, read options for reformatting from minibuffer. |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4082 With \\[universal-argument] \\[universal-argument] prefix argument, reuse previous answers (if any) again. |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4083 If mark is active reformat entries in region, if not in whole buffer." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4084 (interactive "*P") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4085 (let* ((pnt (point)) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4086 (use-previous-options |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4087 (and (equal (prefix-numeric-value read-options) 16) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4088 (or bibtex-reformat-previous-options |
27701
5e135f0faf1d
(bibtex-mode): Replaced manual splitting of path
Gerd Moellmann <gerd@gnu.org>
parents:
26711
diff
changeset
|
4089 bibtex-reformat-previous-reference-keys))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4090 (bibtex-entry-format |
57815 | 4091 (cond (read-options |
4092 (if use-previous-options | |
4093 bibtex-reformat-previous-options | |
4094 (setq bibtex-reformat-previous-options | |
4095 (mapcar (lambda (option) | |
4096 (if (y-or-n-p (car option)) (cdr option))) | |
4097 `(("Realign entries (recommended)? " . 'realign) | |
4098 ("Remove empty optional and alternative fields? " . 'opts-or-alts) | |
4099 ("Remove delimiters around pure numerical fields? " . 'numerical-fields) | |
4100 (,(concat (if bibtex-comma-after-last-field "Insert" "Remove") | |
4101 " comma at end of entry? ") . 'last-comma) | |
4102 ("Replace double page dashes by single ones? " . 'page-dashes) | |
4103 ("Inherit booktitle? " . 'inherit-booktitle) | |
4104 ("Force delimiters? " . 'delimiters) | |
4105 ("Unify case of entry types and field names? " . 'unify-case)))))) | |
4106 ;; Do not include required-fields because `bibtex-reformat' | |
4107 ;; cannot handle the error messages of `bibtex-format-entry'. | |
4108 ;; Use `bibtex-validate' to check for required fields. | |
4109 ((eq t bibtex-entry-format) | |
4110 '(realign opts-or-alts numerical-fields delimiters | |
4111 last-comma page-dashes unify-case inherit-booktitle)) | |
4112 (t | |
4113 (remove 'required-fields (push 'realign bibtex-entry-format))))) | |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4114 (reformat-reference-keys |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4115 (if read-options |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4116 (if use-previous-options |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4117 bibtex-reformat-previous-reference-keys |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4118 (setq bibtex-reformat-previous-reference-keys |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4119 (y-or-n-p "Generate new reference keys automatically? "))))) |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4120 (bibtex-sort-ignore-string-entries t) |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4121 bibtex-autokey-edit-before-use) |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4122 |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4123 (save-restriction |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4124 (if mark-active (narrow-to-region (region-beginning) (region-end))) |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4125 (if (memq 'realign bibtex-entry-format) |
57815 | 4126 (bibtex-realign)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4127 (bibtex-progress-message "Formatting" 1) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4128 (bibtex-map-entries (lambda (key beg end) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4129 (bibtex-progress-message) |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4130 (bibtex-clean-entry reformat-reference-keys t))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4131 (bibtex-progress-message 'done)) |
57815 | 4132 (when reformat-reference-keys |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4133 (kill-local-variable 'bibtex-reference-keys) |
57815 | 4134 (when bibtex-maintain-sorted-entries |
4135 (bibtex-progress-message "Sorting" 1) | |
4136 (bibtex-sort-buffer) | |
4137 (bibtex-progress-message 'done))) | |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4138 (goto-char pnt))) |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4139 |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4140 (defun bibtex-convert-alien (&optional read-options) |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
4141 "Make an alien BibTeX buffer fully usable by BibTeX mode. |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4142 If a file does not conform with all standards used by BibTeX mode, |
58772
4de7ab2c086e
(bibtex-font-lock-url-regexp):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58556
diff
changeset
|
4143 some of the high-level features of BibTeX mode are not available. |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4144 This function tries to convert current buffer to conform with these standards. |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4145 With prefix argument READ-OPTIONS non-nil, read options for reformatting |
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4146 entries from minibuffer." |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4147 (interactive "*P") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4148 (message "Starting to validate buffer...") |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4149 (sit-for 1 nil t) |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4150 (bibtex-realign) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4151 (deactivate-mark) ; So bibtex-validate works on the whole buffer. |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4152 (if (not (let (bibtex-maintain-sorted-entries) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4153 (bibtex-validate))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4154 (message "Correct errors and call `bibtex-convert-alien' again") |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4155 (message "Starting to reformat entries...") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4156 (sit-for 2 nil t) |
55312
3b7a4fa9b2d8
(bibtex-sort-buffer): Remove error message.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52891
diff
changeset
|
4157 (bibtex-reformat read-options) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4158 (goto-char (point-max)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4159 (message "Buffer is now parsable. Please save it."))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4160 |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4161 (defun bibtex-complete () |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4162 "Complete word fragment before point according to context. |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4163 If point is inside key or crossref field perform key completion based on |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4164 `bibtex-reference-keys'. Inside a month field perform key completion |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4165 based on `bibtex-predefined-month-strings'. Inside any other field |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4166 \(including a String or Preamble definition) perform string completion |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4167 based on `bibtex-strings'. |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4168 An error is signaled if point is outside key or BibTeX field." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4169 (interactive) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4170 (let ((pnt (point)) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4171 (case-fold-search t) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4172 bounds name compl) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4173 (save-excursion |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4174 (if (and (setq bounds (bibtex-enclosing-field nil t)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4175 (>= pnt (bibtex-start-of-text-in-field bounds)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4176 (<= pnt (bibtex-end-of-text-in-field bounds))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4177 (setq name (bibtex-name-in-field bounds t) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4178 compl (cond ((bibtex-string= name "crossref") |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4179 ;; point is in crossref field |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4180 'crossref-key) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4181 ((bibtex-string= name "month") |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4182 ;; point is in month field |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4183 bibtex-predefined-month-strings) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4184 ;; point is in other field |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4185 (t (bibtex-strings)))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4186 (bibtex-beginning-of-entry) |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4187 (cond ((setq bounds (bibtex-parse-string t)) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4188 ;; point is inside a @String key |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4189 (cond ((and (>= pnt (nth 1 (car bounds))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4190 (<= pnt (nth 2 (car bounds)))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4191 (setq compl 'string)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4192 ;; point is inside a @String field |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4193 ((and (>= pnt (bibtex-start-of-text-in-string bounds)) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4194 (<= pnt (bibtex-end-of-text-in-string bounds))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4195 (setq compl (bibtex-strings))))) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4196 ;; point is inside a @Preamble field |
67894
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4197 ((setq bounds (bibtex-parse-preamble)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4198 (if (and (>= pnt (bibtex-start-of-text-in-string bounds)) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4199 (<= pnt (bibtex-end-of-text-in-string bounds))) |
d742983a2136
(bibtex-entry-type-whitespace)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67816
diff
changeset
|
4200 (setq compl (bibtex-strings)))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4201 ((and (looking-at bibtex-entry-maybe-empty-head) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4202 ;; point is inside a key |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4203 (or (and (match-beginning bibtex-key-in-head) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4204 (>= pnt (match-beginning bibtex-key-in-head)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4205 (<= pnt (match-end bibtex-key-in-head))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4206 ;; or point is on empty key |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4207 (and (not (match-beginning bibtex-key-in-head)) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4208 (= pnt (match-end 0))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4209 (setq compl 'key))))) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4210 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4211 (cond ((eq compl 'key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4212 ;; key completion: no cleanup needed |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4213 (setq choose-completion-string-functions nil) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4214 (let (completion-ignore-case) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4215 (bibtex-complete-internal (bibtex-global-key-alist)))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4216 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4217 ((eq compl 'crossref-key) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4218 ;; crossref key completion |
67933
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
4219 ;; |
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
4220 ;; If we quit the *Completions* buffer without requesting |
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
4221 ;; a completion, `choose-completion-string-functions' is still |
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
4222 ;; non-nil. Therefore, `choose-completion-string-functions' is |
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
4223 ;; always set (either to non-nil or nil) when a new completion |
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
4224 ;; is requested. |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4225 (let (completion-ignore-case) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4226 (setq choose-completion-string-functions |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4227 (lambda (choice buffer mini-p base-size) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4228 (setq choose-completion-string-functions nil) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4229 (choose-completion-string choice buffer base-size) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4230 (bibtex-complete-crossref-cleanup choice) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4231 t)) ; needed by choose-completion-string-functions |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4232 (bibtex-complete-crossref-cleanup |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4233 (bibtex-complete-internal (bibtex-global-key-alist))))) |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4234 |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4235 ((eq compl 'string) |
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4236 ;; string key completion: no cleanup needed |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4237 (setq choose-completion-string-functions nil) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4238 (let ((completion-ignore-case t)) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4239 (bibtex-complete-internal bibtex-strings))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4240 |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4241 (compl |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4242 ;; string completion |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4243 (let ((completion-ignore-case t)) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4244 (setq choose-completion-string-functions |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4245 `(lambda (choice buffer mini-p base-size) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4246 (setq choose-completion-string-functions nil) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4247 (choose-completion-string choice buffer base-size) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4248 (bibtex-complete-string-cleanup choice ',compl) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4249 t)) ; needed by choose-completion-string-functions |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4250 (bibtex-complete-string-cleanup (bibtex-complete-internal compl) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4251 compl))) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4252 |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4253 (t (setq choose-completion-string-functions nil) |
67933
679e4542aaa9
(bibtex-mode): Make completion-ignore-case
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
67897
diff
changeset
|
4254 (error "Point outside key or BibTeX field"))))) |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4255 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4256 (defun bibtex-Article () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4257 "Insert a new BibTeX @Article entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4258 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4259 (bibtex-entry "Article")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4260 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4261 (defun bibtex-Book () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4262 "Insert a new BibTeX @Book entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4263 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4264 (bibtex-entry "Book")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4265 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4266 (defun bibtex-Booklet () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4267 "Insert a new BibTeX @Booklet entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4268 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4269 (bibtex-entry "Booklet")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4270 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4271 (defun bibtex-InBook () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4272 "Insert a new BibTeX @InBook entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4273 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4274 (bibtex-entry "InBook")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4275 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4276 (defun bibtex-InCollection () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4277 "Insert a new BibTeX @InCollection entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4278 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4279 (bibtex-entry "InCollection")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4280 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4281 (defun bibtex-InProceedings () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4282 "Insert a new BibTeX @InProceedings entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4283 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4284 (bibtex-entry "InProceedings")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4285 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4286 (defun bibtex-Manual () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4287 "Insert a new BibTeX @Manual entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4288 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4289 (bibtex-entry "Manual")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4290 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4291 (defun bibtex-MastersThesis () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4292 "Insert a new BibTeX @MastersThesis entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4293 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4294 (bibtex-entry "MastersThesis")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4295 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4296 (defun bibtex-Misc () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4297 "Insert a new BibTeX @Misc entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4298 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4299 (bibtex-entry "Misc")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4300 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4301 (defun bibtex-PhdThesis () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4302 "Insert a new BibTeX @PhdThesis entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4303 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4304 (bibtex-entry "PhdThesis")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4305 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4306 (defun bibtex-Proceedings () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4307 "Insert a new BibTeX @Proceedings entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4308 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4309 (bibtex-entry "Proceedings")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4310 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4311 (defun bibtex-TechReport () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4312 "Insert a new BibTeX @TechReport entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4313 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4314 (bibtex-entry "TechReport")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4315 |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4316 (defun bibtex-Unpublished () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4317 "Insert a new BibTeX @Unpublished entry; see also `bibtex-entry'." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4318 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4319 (bibtex-entry "Unpublished")) |
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4320 |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4321 (defun bibtex-String (&optional key) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4322 "Insert a new BibTeX @String entry with key KEY." |
58556
8ff63943e93e
(bibtex-sort-entry-class)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57833
diff
changeset
|
4323 (interactive (list (bibtex-read-string-key))) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4324 (let ((bibtex-maintain-sorted-entries |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4325 (unless bibtex-sort-ignore-string-entries |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4326 bibtex-maintain-sorted-entries)) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4327 endpos) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4328 (unless (bibtex-prepare-new-entry (list key nil "String")) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4329 (error "Entry with key `%s' already exists" key)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4330 (if (zerop (length key)) (setq key nil)) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4331 (indent-to-column bibtex-entry-offset) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4332 (insert "@String" |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4333 (bibtex-entry-left-delimiter)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4334 (if key |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4335 (insert key) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4336 (setq endpos (point))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4337 (insert " = " |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4338 (bibtex-field-left-delimiter)) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4339 (if key |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4340 (setq endpos (point))) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4341 (insert (bibtex-field-right-delimiter) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4342 (bibtex-entry-right-delimiter) |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4343 "\n") |
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4344 (goto-char endpos))) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4345 |
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4346 (defun bibtex-Preamble () |
22563
2e2a71dfec63
Numerous documentation fixups.
Richard M. Stallman <rms@gnu.org>
parents:
21169
diff
changeset
|
4347 "Insert a new BibTeX @Preamble entry." |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4348 (interactive "*") |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4349 (bibtex-move-outside-of-entry) |
18212
3864648e9b4f
(bibtex-mode-map): Changed the binding of the C-TAB
Richard M. Stallman <rms@gnu.org>
parents:
17700
diff
changeset
|
4350 (indent-to-column bibtex-entry-offset) |
51415
762217a72cae
Long overdue merge.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49599
diff
changeset
|
4351 (insert "@Preamble" |
63470
c318ec40e95f
(bibtex-Preamble): Enclose BibTeX preamble by field delimiters.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
62077
diff
changeset
|
4352 (bibtex-entry-left-delimiter) |
c318ec40e95f
(bibtex-Preamble): Enclose BibTeX preamble by field delimiters.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
62077
diff
changeset
|
4353 (bibtex-field-left-delimiter)) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4354 (let ((endpos (point))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4355 (insert (bibtex-field-right-delimiter) |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4356 (bibtex-entry-right-delimiter) |
51743
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4357 "\n") |
f63c242330b2
2003-06-30 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51416
diff
changeset
|
4358 (goto-char endpos))) |
257 | 4359 |
70250
5d4423d8a6f5
(bibtex-url): New optional arg no-browse. Return the URL or nil if
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70249
diff
changeset
|
4360 (defun bibtex-url (&optional pos no-browse) |
57815 | 4361 "Browse a URL for the BibTeX entry at point. |
4362 Optional POS is the location of the BibTeX entry. | |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4363 The URL is generated using the schemes defined in `bibtex-generate-url-list' |
70250
5d4423d8a6f5
(bibtex-url): New optional arg no-browse. Return the URL or nil if
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70249
diff
changeset
|
4364 \(see there\). Then the URL is passed to `browse-url' unless NO-BROWSE is nil. |
5d4423d8a6f5
(bibtex-url): New optional arg no-browse. Return the URL or nil if
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70249
diff
changeset
|
4365 Return the URL or nil if none can be generated." |
57815 | 4366 (interactive) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4367 (save-excursion |
57815 | 4368 (if pos (goto-char pos)) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4369 (bibtex-beginning-of-entry) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4370 ;; Always remove field delimiters |
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4371 (let ((fields-alist (bibtex-parse-entry t)) |
57815 | 4372 ;; Always ignore case, |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4373 (case-fold-search t) |
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4374 (lst bibtex-generate-url-list) |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4375 field url scheme obj fmt) |
57815 | 4376 (while (setq scheme (pop lst)) |
57070
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
4377 (when (and (setq field (cdr (assoc-string (caar scheme) |
3d9707888790
(bibtex-generate-url-list): Change format. Provide a sample complex default.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
57054
diff
changeset
|
4378 fields-alist t))) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4379 (string-match (cdar scheme) field)) |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4380 (setq lst nil |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4381 scheme (cdr scheme) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4382 url (if (null scheme) (match-string 0 field) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4383 (if (stringp (car scheme)) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4384 (setq fmt (pop scheme))) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4385 (dolist (step scheme) |
67575
d0f7b15488df
(bibtex-expand-strings)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66116
diff
changeset
|
4386 (setq field (cdr (assoc-string (car step) fields-alist t))) |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4387 (if (string-match (nth 1 step) field) |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4388 (push (cond ((functionp (nth 2 step)) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4389 (funcall (nth 2 step) field)) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4390 ((numberp (nth 2 step)) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4391 (match-string (nth 2 step) field)) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4392 (t |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4393 (replace-match (nth 2 step) t nil field))) |
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4394 obj) |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4395 ;; If the scheme is set up correctly, |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4396 ;; we should never reach this point |
69581
98eee222dceb
* textmodes/bibtex.el (bibtex-include-OPTkey)
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
68648
diff
changeset
|
4397 (error "Match failed: %s" field))) |
61247
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4398 (if fmt (apply 'format fmt (nreverse obj)) |
d11749d2bcff
(bibtex-url): Use format to generate the url.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
59733
diff
changeset
|
4399 (apply 'concat (nreverse obj))))) |
70250
5d4423d8a6f5
(bibtex-url): New optional arg no-browse. Return the URL or nil if
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70249
diff
changeset
|
4400 (if (interactive-p) (message "%s" url)) |
5d4423d8a6f5
(bibtex-url): New optional arg no-browse. Return the URL or nil if
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70249
diff
changeset
|
4401 (unless no-browse (browse-url url)))) |
5d4423d8a6f5
(bibtex-url): New optional arg no-browse. Return the URL or nil if
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70249
diff
changeset
|
4402 (if (and (not url) (interactive-p)) (message "No URL known.")) |
5d4423d8a6f5
(bibtex-url): New optional arg no-browse. Return the URL or nil if
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
70249
diff
changeset
|
4403 url))) |
57054
0b058857c704
(bibtex-mark-active, bibtex-run-with-idle-timer): Move `if' inside the defun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55880
diff
changeset
|
4404 |
257 | 4405 |
12700
b3a8ee2da96a
Add keywords and comments as per conventions.
Richard M. Stallman <rms@gnu.org>
parents:
12028
diff
changeset
|
4406 ;; Make BibTeX a Feature |
257 | 4407 |
10219
d97313bb6f39
(bibtex-string, bibtex-preamble): Use forward-line.
Richard M. Stallman <rms@gnu.org>
parents:
10106
diff
changeset
|
4408 (provide 'bibtex) |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
4409 |
55348
c1f70dc19ce5
(bibtex-progress-message): Fix docstring.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55312
diff
changeset
|
4410 ;; arch-tag: ee2be3af-caad-427f-b42a-d20fad630d04 |
2602
2465861025cd
Installed Aaron Larson's new bibtex.el. See the header comment for
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2307
diff
changeset
|
4411 ;;; bibtex.el ends here |