1 | % BibTeX styles for various physics journals (27-Feb-1990).
|
---|
2 | % This file, physics.btx, is based on the file btxbst.doc.
|
---|
3 | % Please notify Charles Karney (Karney@Princeton.EDU)
|
---|
4 | % of any bugs, improvements, etc.
|
---|
5 | % Run this file through cpp to get specific versions. I have written
|
---|
6 | % a version of cpp within Emacs. To access it put
|
---|
7 | % (autoload 'cpp "tex$bibtex:cpp" ; Use cpp for BibTeX styles
|
---|
8 | % "C preprocessor"
|
---|
9 | % t)
|
---|
10 | % into your .emacs file. Read in this file with
|
---|
11 | % emacs tex$bibtex:physics.btx
|
---|
12 | % and run cpp with e.g.,
|
---|
13 | % M-x cpp <ret> aip <ret>
|
---|
14 | % Save the resulting file to tex$latex:aip.bst.
|
---|
15 | % To accomodate the variations we need (in addition to the definitions below)
|
---|
16 | % ATIT_SUPPRESS: do not include the titles of journal articles
|
---|
17 | % NAME_INVERT: put the initials last
|
---|
18 | % NAME_UPPER: convert names to all caps.
|
---|
19 | % MONTH_SUPPRESS: do not include months in journal articles
|
---|
20 | % PAREN_DATE: dates go in parens in journal articles
|
---|
21 | % DATE_FIRST: dates go before page numbers
|
---|
22 | % VOLUME_SPACE: volume set off with space (not colon)
|
---|
23 | % NUM_SUPPRESS: do not include numbers in journal articles
|
---|
24 | % BOLD_VOL: volume numbers in bold face in journal articles
|
---|
25 | % BRACKET_NOTE: notes in brackets
|
---|
26 | % PAGE_START_J: include only starting page for journal articles
|
---|
27 | % PAGE_START_O: include only starting page for other entries
|
---|
28 | % PAGE_ABBREV: abbreviate page to p. and pages to pp.
|
---|
29 | % PHYSICS_JOUR: include abbreviations for Physics journals
|
---|
30 | % COMMA_DELIMIT: use comma (instead of period) to divide a citation
|
---|
31 | % NOTE_SUPPRESS: suppress the note
|
---|
32 | % MAX_NAMES: max number of authors before using et al (0 = infinity)
|
---|
33 | % MIN_NAMES: number of authors to list with et al.
|
---|
34 | % EDIT_VAR: use "edited by ..." instead of "..., editors"
|
---|
35 | % RMP_LABELS: create RMP-style labels
|
---|
36 | % KEY_CITE: use key as label
|
---|
37 | % NAMED_REFS: use (Smith, 1988) style of citations
|
---|
38 | % CSC_NAMES: names set in caps and small caps
|
---|
39 | % JOUR_DEEMPH: don't emphasize journal name
|
---|
40 | % ETAL_EMPH: emphasize et al.
|
---|
41 | % ALT_INCOLL alternate ordering of fields in incollections
|
---|
42 | % These are all boolean (0 or 1) except for MAX_NAMES and MIN_NAMES.
|
---|
43 | % These need to satisfy 0 <= MIN_NAMES <= MAX_NAMES.
|
---|
44 | % The rule here is that if all these are defined to be zero, we revert to
|
---|
45 | % the standard styles. For that reason we initialize them all to 0.
|
---|
46 | % These are the original macros
|
---|
47 | % Progress in Particle and Nuclear Physics
|
---|
48 | % This is the start of btxbst.doc
|
---|
49 | % BibTeX `plain' family
|
---|
50 | % version 0.99b for BibTeX versions 0.99a or later, LaTeX version 2.09.
|
---|
51 | % Copyright (C) 1985, all rights reserved.
|
---|
52 | % Copying of this file is authorized only if either
|
---|
53 | % (1) you make absolutely no changes to your copy, including name, or
|
---|
54 | % (2) if you do make changes, you name it something other than
|
---|
55 | % btxbst.doc, plain.bst, unsrt.bst, alpha.bst, and abbrv.bst.
|
---|
56 | % This restriction helps ensure that all standard styles are identical.
|
---|
57 | % The file btxbst.doc has the documentation for this style.
|
---|
58 | % Please notify Oren Patashnik (PATASHNIK@SCORE.STANFORD.EDU) of any bugs in
|
---|
59 | % these standard styles or in this documentation file.
|
---|
60 | %
|
---|
61 | % This is file btxbxt.doc; it helps document bibliography styles,
|
---|
62 | % and is also a template file that you can use to make
|
---|
63 | % several different style files, if you have access to a C preprocessor.
|
---|
64 | % For example, the standard styles were made by doing something like
|
---|
65 | % cpp -P -DPLAIN btxbst.doc plain.txt
|
---|
66 | % cpp -P -DUNSRT btxbst.doc unsrt.txt
|
---|
67 | % cpp -P -DALPHA btxbst.doc alpha.txt
|
---|
68 | % cpp -P -DABBRV btxbst.doc abbrv.txt
|
---|
69 | % and then renaming after removing unwanted comments and blank lines.
|
---|
70 | % If you don't have access,
|
---|
71 | % you can edit this file by hand to imitate the preprocessor,
|
---|
72 | % with the following explanation of the C preprocessor constructs used here.
|
---|
73 | %
|
---|
74 | % The output of the preprocessor is the same as the input, except that certain
|
---|
75 | % lines will be excluded (and some blank lines will be added). The sequence
|
---|
76 | % #if VAR
|
---|
77 | % lines to be included when VAR is not zero
|
---|
78 | % #else
|
---|
79 | % lines to be included when VAR is zero
|
---|
80 | % #endif
|
---|
81 | % (with the #-signs appearing in column 1) means that one set or the other of
|
---|
82 | % the lines are to be included depending on the value of VAR.
|
---|
83 | % The #else part is optional. Comments can be added after #else and #endif.
|
---|
84 | % Variables can be set by
|
---|
85 | % #define VAR value
|
---|
86 | % and one can also use #ifdef VAR to see if VAR has any value, and #ifndef
|
---|
87 | % to see if it has none.
|
---|
88 | % Another #if form used in this file is #if !VAR, which includes the lines
|
---|
89 | % after the #if only if VAR is zero.
|
---|
90 | %
|
---|
91 | % Convention: Use all uppercase identifiers for these preprocessor variables
|
---|
92 | % so you can spot them easily
|
---|
93 | %
|
---|
94 | % The command line to the preprocessor should define one of PLAIN, UNSRT, ALPHA
|
---|
95 | % or ABBRV (though PLAIN will be used by default if none is given),
|
---|
96 | % and the following lines will set various boolean variables to control the
|
---|
97 | % various lines that are chosen from the rest of the file.
|
---|
98 | % Each boolean variable should be set true (1) or false (0) in each style.
|
---|
99 | % Here are the current variables, and their meanings:
|
---|
100 | % 0 : an alphabetic label is used (if false then a numeric
|
---|
101 | % label is used)
|
---|
102 | % 0 : the entries should be sorted by label (if nonnumeric)
|
---|
103 | % and other info, like authors (if false, then
|
---|
104 | % entries remain in order of occurrence)
|
---|
105 | % 0 : the authors, editors, etc., get the full names as
|
---|
106 | % given in the bibliography file (if false, the first
|
---|
107 | % names become initials)
|
---|
108 | % 1 : titles of non-"books" (e.g., articles) should be
|
---|
109 | % converted to lower-case, except the first letter or
|
---|
110 | % first letter after a colon
|
---|
111 | % (if false then they appear as in the database)
|
---|
112 | % 0 : months are spelled out in full (if false, then
|
---|
113 | % they're abbreviated)
|
---|
114 | % 0 : macro journal names are spelled out in full
|
---|
115 | % (if false then they are abbreviated, currently
|
---|
116 | % as they appear in ACM publications)
|
---|
117 | %# define PLAIN 1
|
---|
118 | %
|
---|
119 | % Entry formatting: Similar to that recommended by Mary-Claire van Leunen
|
---|
120 | % in "A Handbook for Scholars". Book-like titles are italicized
|
---|
121 | % (emphasized) and non-book titles are converted to sentence
|
---|
122 | % capitilization (and not enclosed in quotes).
|
---|
123 | % This file outputs a \newblock between major blocks of an entry
|
---|
124 | % (the name \newblock is analogous to the names \newline and \newpage)
|
---|
125 | % so that the user can obtain an "open" format, which has a line break
|
---|
126 | % before each block and lines after the first are indented within blocks,
|
---|
127 | % by giving the optional \documentstyle argument `openbib';
|
---|
128 | % The default is the "closed" format---blocks runs together.
|
---|
129 | %
|
---|
130 | % Citation alphabetic label format:
|
---|
131 | % [Knu73] for single author (or editor or key)
|
---|
132 | % [AHU83] (first letters of last names) for multiple authors
|
---|
133 | %
|
---|
134 | % Citation label numberic format:
|
---|
135 | % [number]
|
---|
136 | %
|
---|
137 | % Reference list ordering for sorted, alphabetic lables:
|
---|
138 | % alphabetical by citation label, then by author(s) or whatever
|
---|
139 | % passes for author in the absence of one, then by year,
|
---|
140 | % then title
|
---|
141 | %
|
---|
142 | % Reference list ordering for sorted, numeric lables:
|
---|
143 | % alphabetical by author(s) or whatever passes
|
---|
144 | % for author in the absence of one, then by year, then title
|
---|
145 | %
|
---|
146 | % Reference list ordering for unsorted:
|
---|
147 | % by the order cited in the text
|
---|
148 | %
|
---|
149 | % History
|
---|
150 | % 12/16/84 (HWT) Original `plain' version, by Howard Trickey.
|
---|
151 | % 12/23/84 (LL) Some comments made by Leslie Lamport.
|
---|
152 | % 2/16/85 (OP) Changes based on LL's comments, Oren Patashnik.
|
---|
153 | % 2/17/85 (HWT) Template file and other standard styles made.
|
---|
154 | % 3/28/85 (OP) First release, version 0.98b for BibTeX 0.98f.
|
---|
155 | % 5/ 9/85 (OP) Version 0.98c for BibTeX 0.98i:
|
---|
156 | % fixed Theoretical Computer Science macro name;
|
---|
157 | % fixed the format.vol.num.pages function.
|
---|
158 | % 1/24/88 (OP) Version 0.99a for BibTeX 0.99a, main changes:
|
---|
159 | % assignment operator (:=) arguments reversed;
|
---|
160 | % the preamble$ function outputs the database PREAMBLE;
|
---|
161 | % entry.max$ and global.max$ (built-in) variables replace
|
---|
162 | % entry.string.max and global.string.max functions;
|
---|
163 | % alphabetizing by year then title, not just title;
|
---|
164 | % many unnecessary ties removed; \it ==> \em;
|
---|
165 | % the `alpha' style uses a superscripted `+' instead of a
|
---|
166 | % `*' for unnamed names in constructing the label;
|
---|
167 | % the `abbrv' style now uses "Mar." and "Sept.";
|
---|
168 | % the functions calc.label and presort now look at just
|
---|
169 | % the fields they're supposed to;
|
---|
170 | % BOOKLET, MASTERSTHESIS, TECHREPORT use nonbook titles;
|
---|
171 | % INBOOK and INCOLLECTION take an optional type (e.g.
|
---|
172 | % type = "Section"), overriding the default "chapter";
|
---|
173 | % BOOK, INBOOK, INCOLLECTION, and PROCEEDINGS now allow
|
---|
174 | % either volume or number, not just volume;
|
---|
175 | % INCOLLECTION now allows an edition and series field;
|
---|
176 | % PROCEEDINGS and INPROCEEDINGS now use the address field
|
---|
177 | % to tell where a conference was held;
|
---|
178 | % INPROCEEDINGS and PROCEEDINGS now allow either volume
|
---|
179 | % or number, and also a series field;
|
---|
180 | % MASTERSTHESIS and PHDTHESIS accept types other than
|
---|
181 | % "Master's thesis" and "PhD thesis";
|
---|
182 | % UNPUBLISHED now outputs, in one block, note then date;
|
---|
183 | % MANUAL now prints out the organization in
|
---|
184 | % the first block if the author field is empty;
|
---|
185 | % MISC can't be empty---it requires some optional field.
|
---|
186 | % 3/23/88 (OP) Version 0.99b for BibTeX 0.99c---changed the three
|
---|
187 | % erroneous occurrences of `cite ' to `cite$ '; this
|
---|
188 | % change didn't affect the four standard styles, so the
|
---|
189 | % 0.99a versions of those styles are still current.
|
---|
190 | %
|
---|
191 | % The ENTRY declaration
|
---|
192 | % Like Scribe's (according to pages 231-2 of the April '84 edition),
|
---|
193 | % but no fullauthor or editors fields because BibTeX does name handling.
|
---|
194 | % The annote field is commented out here because this family doesn't
|
---|
195 | % include an annotated bibliography style. And in addition to the fields
|
---|
196 | % listed here, BibTeX has a built-in crossref field, explained later.
|
---|
197 | ENTRY
|
---|
198 | % Fields:
|
---|
199 | { address
|
---|
200 | % Usually the address of a publisher or other type of organization.
|
---|
201 | % Put information in this field only if it helps the reader find the
|
---|
202 | % thing---for example you should omit the address of a major
|
---|
203 | % publisher entirely. For a PROCEEDINGS or an INPROCEEDINGS,
|
---|
204 | % however, it's the address of the conference; for those two entry
|
---|
205 | % types, include the publisher's or organization's address, if
|
---|
206 | % necessary, in the publisher or organization field.
|
---|
207 | % annote
|
---|
208 | % Long annotation---for annotated bibliographies (begins sentence).
|
---|
209 | author
|
---|
210 | % Name(s) of author(s), in BibTeX name format.
|
---|
211 | booktitle
|
---|
212 | % Book title when the thing being referenced isn't the whole book.
|
---|
213 | % For book entries, the title field should be used instead.
|
---|
214 | chapter
|
---|
215 | % Chapter (or section or whatever) number.
|
---|
216 | collaboration
|
---|
217 | edition
|
---|
218 | % Edition of a book---should be an ordinal (e.g., "Second").
|
---|
219 | editor
|
---|
220 | % Name(s) of editor(s), in BibTeX name format.
|
---|
221 | % If there is also an author field, then the editor field should be
|
---|
222 | % for the book or collection that the work appears in.
|
---|
223 | howpublished
|
---|
224 | % How something strange has been published (begins sentence).
|
---|
225 | institution
|
---|
226 | % Sponsoring institution of a technical report.
|
---|
227 | journal
|
---|
228 | % Journal name (macros are provided for many).
|
---|
229 | key
|
---|
230 | % Alphabetizing, labeling, and cross-referencing key
|
---|
231 | % (needed when an entry has no author or editor).
|
---|
232 | month
|
---|
233 | % Month (macros are provided).
|
---|
234 | note
|
---|
235 | % To help the reader find a reference (begins sentence).
|
---|
236 | eprint
|
---|
237 | % ArXiv identifier
|
---|
238 | number
|
---|
239 | % Number of a journal or technical report, or of a work in a series.
|
---|
240 | organization
|
---|
241 | % Organization sponsoring a conference (or publishing a manual); if
|
---|
242 | % the editor (or author) is empty, and if the organization produces
|
---|
243 | % an awkward label or cross reference, you should put appropriately
|
---|
244 | % condensed organization information in the key field as well.
|
---|
245 | pages
|
---|
246 | % Page number or numbers (use `--' to separate a range, use `+'
|
---|
247 | % to indicate pages following that don't form a simple range).
|
---|
248 | publisher
|
---|
249 | % Publisher name.
|
---|
250 | school
|
---|
251 | % School name (for theses).
|
---|
252 | series
|
---|
253 | % The name of a series or set of books.
|
---|
254 | % An individual book will will also have it's own title.
|
---|
255 | title
|
---|
256 | % The title of the thing you're referred to.
|
---|
257 | type
|
---|
258 | % Type of a Techreport (e.g., "Research Note") to be used instead of
|
---|
259 | % the default "Technical Report"; or, similarly, the type of a
|
---|
260 | % thesis; or of a part of a book.
|
---|
261 | volume
|
---|
262 | % The volume number of a journal or multivolume work.
|
---|
263 | year
|
---|
264 | % The year should contain only numerals (technically, it should end
|
---|
265 | % with four numerals, after purification; doesn't a begin sentence).
|
---|
266 | url
|
---|
267 | }
|
---|
268 | % There are no integer entry variables
|
---|
269 | {}
|
---|
270 | % These string entry variables are used to form the citation label.
|
---|
271 | % In a storage pinch, sort.label can be easily computed on the fly.
|
---|
272 | { label }
|
---|
273 | % Each entry function starts by calling output.bibitem, to write the
|
---|
274 | % \bibitem and its arguments to the .BBL file. Then the various fields
|
---|
275 | % are formatted and printed by output or output.check. Those functions
|
---|
276 | % handle the writing of separators (commas, periods, \newblock's),
|
---|
277 | % taking care not to do so when they are passed a null string.
|
---|
278 | % Finally, fin.entry is called to add the final period and finish the
|
---|
279 | % entry.
|
---|
280 | %
|
---|
281 | % A bibliographic reference is formatted into a number of `blocks':
|
---|
282 | % in the open format, a block begins on a new line and subsequent
|
---|
283 | % lines of the block are indented. A block may contain more than
|
---|
284 | % one sentence (well, not a grammatical sentence, but something to
|
---|
285 | % be ended with a sentence ending period). The entry functions should
|
---|
286 | % call new.block whenever a block other than the first is about to be
|
---|
287 | % started. They should call new.sentence whenever a new sentence is
|
---|
288 | % to be started. The output functions will ensure that if two
|
---|
289 | % new.sentence's occur without any non-null string being output between
|
---|
290 | % them then there won't be two periods output. Similarly for two
|
---|
291 | % successive new.block's.
|
---|
292 | %
|
---|
293 | % The output routines don't write their argument immediately.
|
---|
294 | % Instead, by convention, that argument is saved on the stack to be
|
---|
295 | % output next time (when we'll know what separator needs to come
|
---|
296 | % after it). Meanwhile, the output routine has to pop the pending
|
---|
297 | % output off the stack, append any needed separator, and write it.
|
---|
298 | %
|
---|
299 | % To tell which separator is needed, we maintain an output.state.
|
---|
300 | % It will be one of these values:
|
---|
301 | % before.all just after the \bibitem
|
---|
302 | % mid.sentence in the middle of a sentence: comma needed
|
---|
303 | % if more sentence is output
|
---|
304 | % after.sentence just after a sentence: period needed
|
---|
305 | % after.block just after a block (and sentence):
|
---|
306 | % period and \newblock needed.
|
---|
307 | % Note: These styles don't use after.sentence
|
---|
308 | %
|
---|
309 | % VAR: output.state : INTEGER -- state variable for output
|
---|
310 | %
|
---|
311 | % The output.nonnull function saves its argument (assumed to be nonnull)
|
---|
312 | % on the stack, and writes the old saved value followed by any needed
|
---|
313 | % separator. The ordering of the tests is decreasing frequency of
|
---|
314 | % occurrence.
|
---|
315 | %
|
---|
316 | % output.nonnull(s) ==
|
---|
317 | % BEGIN
|
---|
318 | % s := argument on stack
|
---|
319 | % if output.state = mid.sentence then
|
---|
320 | % write$(pop() * ", ")
|
---|
321 | % -- "pop" isn't a function: just use stack top
|
---|
322 | % else
|
---|
323 | % if output.state = after.block then
|
---|
324 | % write$(add.period$(pop()))
|
---|
325 | % newline$
|
---|
326 | % write$("\newblock ")
|
---|
327 | % else
|
---|
328 | % if output.state = before.all then
|
---|
329 | % write$(pop())
|
---|
330 | % else -- output.state should be after.sentence
|
---|
331 | % write$(add.period$(pop()) * " ")
|
---|
332 | % fi
|
---|
333 | % fi
|
---|
334 | % output.state := mid.sentence
|
---|
335 | % fi
|
---|
336 | % push s on stack
|
---|
337 | % END
|
---|
338 | %
|
---|
339 | % The output function calls output.nonnull if its argument is non-empty;
|
---|
340 | % its argument may be a missing field (thus, not necessarily a string)
|
---|
341 | %
|
---|
342 | % output(s) ==
|
---|
343 | % BEGIN
|
---|
344 | % if not empty$(s) then output.nonnull(s)
|
---|
345 | % fi
|
---|
346 | % END
|
---|
347 | %
|
---|
348 | % The output.check function is the same as the output function except that, if
|
---|
349 | % necessary, output.check warns the user that the t field shouldn't be empty
|
---|
350 | % (this is because it probably won't be a good reference without the field;
|
---|
351 | % the entry functions try to make the formatting look reasonable even when
|
---|
352 | % such fields are empty).
|
---|
353 | %
|
---|
354 | % output.check(s,t) ==
|
---|
355 | % BEGIN
|
---|
356 | % if empty$(s) then
|
---|
357 | % warning$("empty " * t * " in " * cite$)
|
---|
358 | % else output.nonnull(s)
|
---|
359 | % fi
|
---|
360 | % END
|
---|
361 | %
|
---|
362 | % The output.bibitem function writes the \bibitem for the current entry
|
---|
363 | % (the label should already have been set up), and sets up the separator
|
---|
364 | % state for the output functions. And, it leaves a string on the stack
|
---|
365 | % as per the output convention.
|
---|
366 | %
|
---|
367 | % output.bibitem ==
|
---|
368 | % BEGIN
|
---|
369 | % newline$
|
---|
370 | % write$("\bibitem[") % for alphabetic labels,
|
---|
371 | % write$(label) % these three lines
|
---|
372 | % write$("]{") % are used
|
---|
373 | % write$("\bibitem{") % this line for numeric labels
|
---|
374 | % write$(cite$)
|
---|
375 | % write$("}")
|
---|
376 | % push "" on stack
|
---|
377 | % output.state := before.all
|
---|
378 | % END
|
---|
379 | %
|
---|
380 | % The fin.entry function finishes off an entry by adding a period to the
|
---|
381 | % string remaining on the stack. If the state is still before.all
|
---|
382 | % then nothing was produced for this entry, so the result will look bad,
|
---|
383 | % but the user deserves it. (We don't omit the whole entry because the
|
---|
384 | % entry was cited, and a bibitem is needed to define the citation label.)
|
---|
385 | %
|
---|
386 | % fin.entry ==
|
---|
387 | % BEGIN
|
---|
388 | % write$(add.period$(pop()))
|
---|
389 | % newline$
|
---|
390 | % END
|
---|
391 | %
|
---|
392 | % The new.block function prepares for a new block to be output, and
|
---|
393 | % new.sentence prepares for a new sentence.
|
---|
394 | %
|
---|
395 | % new.block ==
|
---|
396 | % BEGIN
|
---|
397 | % if output.state <> before.all then
|
---|
398 | % output.state := after.block
|
---|
399 | % fi
|
---|
400 | % END
|
---|
401 | %
|
---|
402 | % new.sentence ==
|
---|
403 | % BEGIN
|
---|
404 | % if output.state <> after.block then
|
---|
405 | % if output.state <> before.all then
|
---|
406 | % output.state := after.sentence
|
---|
407 | % fi
|
---|
408 | % fi
|
---|
409 | % END
|
---|
410 | %
|
---|
411 | INTEGERS { output.state before.all mid.sentence after.sentence after.block }
|
---|
412 | FUNCTION {init.state.consts}
|
---|
413 | { #0 'before.all :=
|
---|
414 | #1 'mid.sentence :=
|
---|
415 | #2 'after.sentence :=
|
---|
416 | #3 'after.block :=
|
---|
417 | }
|
---|
418 | % the variables s and t are temporary string holders
|
---|
419 | STRINGS { s t }
|
---|
420 | FUNCTION {output.nonnull}
|
---|
421 | { 's :=
|
---|
422 | output.state mid.sentence =
|
---|
423 | { ", " * write$ }
|
---|
424 | { output.state after.block =
|
---|
425 | { "," * write$
|
---|
426 | newline$
|
---|
427 | "\newblock " write$
|
---|
428 | }
|
---|
429 | { output.state before.all =
|
---|
430 | 'write$
|
---|
431 | { add.period$ " " * write$ }
|
---|
432 | if$
|
---|
433 | }
|
---|
434 | if$
|
---|
435 | mid.sentence 'output.state :=
|
---|
436 | }
|
---|
437 | if$
|
---|
438 | s
|
---|
439 | }
|
---|
440 | FUNCTION {output}
|
---|
441 | { duplicate$ empty$
|
---|
442 | 'pop$
|
---|
443 | 'output.nonnull
|
---|
444 | if$
|
---|
445 | }
|
---|
446 | FUNCTION {output.check}
|
---|
447 | { 't :=
|
---|
448 | duplicate$ empty$
|
---|
449 | { pop$ "empty " t * " in " * cite$ * warning$ }
|
---|
450 | 'output.nonnull
|
---|
451 | if$
|
---|
452 | }
|
---|
453 | FUNCTION {output.bibitem}
|
---|
454 | { newline$
|
---|
455 | "\bibitem{" write$
|
---|
456 | cite$ write$
|
---|
457 | "}" write$
|
---|
458 | newline$
|
---|
459 | ""
|
---|
460 | before.all 'output.state :=
|
---|
461 | }
|
---|
462 | % This function finishes all entries.
|
---|
463 | FUNCTION {fin.entry}
|
---|
464 | { add.period$
|
---|
465 | write$
|
---|
466 | newline$
|
---|
467 | }
|
---|
468 | FUNCTION {new.block}
|
---|
469 | { output.state before.all =
|
---|
470 | 'skip$
|
---|
471 | { after.block 'output.state := }
|
---|
472 | if$
|
---|
473 | }
|
---|
474 | FUNCTION {new.sentence}
|
---|
475 | { skip$
|
---|
476 | }
|
---|
477 | % These three functions pop one or two (integer) arguments from the stack
|
---|
478 | % and push a single one, either 0 or 1.
|
---|
479 | % The 'skip$ in the `and' and `or' functions are used because
|
---|
480 | % the corresponding if$ would be idempotent
|
---|
481 | FUNCTION {not}
|
---|
482 | { { #0 }
|
---|
483 | { #1 }
|
---|
484 | if$
|
---|
485 | }
|
---|
486 | FUNCTION {and}
|
---|
487 | { 'skip$
|
---|
488 | { pop$ #0 }
|
---|
489 | if$
|
---|
490 | }
|
---|
491 | FUNCTION {or}
|
---|
492 | { { pop$ #1 }
|
---|
493 | 'skip$
|
---|
494 | if$
|
---|
495 | }
|
---|
496 | % Sometimes we begin a new block only if the block will be big enough. The
|
---|
497 | % new.block.checka function issues a new.block if its argument is nonempty;
|
---|
498 | % new.block.checkb does the same if either of its TWO arguments is nonempty.
|
---|
499 | FUNCTION {new.block.checka}
|
---|
500 | { empty$
|
---|
501 | 'skip$
|
---|
502 | 'new.block
|
---|
503 | if$
|
---|
504 | }
|
---|
505 | FUNCTION {new.block.checkb}
|
---|
506 | { empty$
|
---|
507 | swap$ empty$
|
---|
508 | and
|
---|
509 | 'skip$
|
---|
510 | 'new.block
|
---|
511 | if$
|
---|
512 | }
|
---|
513 | % The new.sentence.check functions are analogous.
|
---|
514 | FUNCTION {new.sentence.checka}
|
---|
515 | { empty$
|
---|
516 | 'skip$
|
---|
517 | 'new.sentence
|
---|
518 | if$
|
---|
519 | }
|
---|
520 | FUNCTION {new.sentence.checkb}
|
---|
521 | { empty$
|
---|
522 | swap$ empty$
|
---|
523 | and
|
---|
524 | 'skip$
|
---|
525 | 'new.sentence
|
---|
526 | if$
|
---|
527 | }
|
---|
528 | % Here are some functions for formatting chunks of an entry.
|
---|
529 | % By convention they either produce a string that can be followed by
|
---|
530 | % a comma or period (using add.period$, so it is OK to end in a period),
|
---|
531 | % or they produce the null string.
|
---|
532 | %
|
---|
533 | % A useful utility is the field.or.null function, which checks if the
|
---|
534 | % argument is the result of pushing a `missing' field (one for which no
|
---|
535 | % assignment was made when the current entry was read in from the database)
|
---|
536 | % or the result of pushing a string having no non-white-space characters.
|
---|
537 | % It returns the null string if so, otherwise it returns the field string.
|
---|
538 | % Its main (but not only) purpose is to guarantee that what's left on the
|
---|
539 | % stack is a string rather than a missing field.
|
---|
540 | %
|
---|
541 | % field.or.null(s) ==
|
---|
542 | % BEGIN
|
---|
543 | % if empty$(s) then return ""
|
---|
544 | % else return s
|
---|
545 | % END
|
---|
546 | %
|
---|
547 | % Another helper function is emphasize, which returns the argument emphazised,
|
---|
548 | % if that is non-empty, otherwise it returns the null string. Italic
|
---|
549 | % corrections aren't used, so this function should be used when punctation
|
---|
550 | % will follow the result.
|
---|
551 | %
|
---|
552 | % emphasize(s) ==
|
---|
553 | % BEGIN
|
---|
554 | % if empty$(s) then return ""
|
---|
555 | % else return "{\em " * s * "}"
|
---|
556 | %
|
---|
557 | % The format.names function formats the argument (which should be in
|
---|
558 | % BibTeX name format) into "First Von Last, Junior", separated by commas
|
---|
559 | % and with an "and" before the last (but ending with "et~al." if the last
|
---|
560 | % of multiple authors is "others"). This function's argument should always
|
---|
561 | % contain at least one name.
|
---|
562 | %
|
---|
563 | % VAR: nameptr, namesleft, numnames: INTEGER
|
---|
564 | % pseudoVAR: nameresult: STRING (it's what's accumulated on the stack)
|
---|
565 | %
|
---|
566 | % format.names(s) ==
|
---|
567 | % BEGIN
|
---|
568 | % nameptr := 1
|
---|
569 | % numnames := num.names$(s)
|
---|
570 | % namesleft := numnames
|
---|
571 | % while namesleft > 0
|
---|
572 | % do
|
---|
573 | % % for full names:
|
---|
574 | % t := format.name$(s, nameptr, "{ff~}{vv~}{ll}{, jj}")
|
---|
575 | % % for abbreviated first names:
|
---|
576 | % t := format.name$(s, nameptr, "{f.~}{vv~}{ll}{, jj}")
|
---|
577 | % if nameptr > 1 then
|
---|
578 | % if namesleft > 1 then nameresult := nameresult * ", " * t
|
---|
579 | % else if numnames > 2
|
---|
580 | % then nameresult := nameresult * ","
|
---|
581 | % fi
|
---|
582 | % if t = "others"
|
---|
583 | % then nameresult := nameresult * " et~al."
|
---|
584 | % else nameresult := nameresult * " and " * t
|
---|
585 | % fi
|
---|
586 | % fi
|
---|
587 | % else nameresult := t
|
---|
588 | % fi
|
---|
589 | % nameptr := nameptr + 1
|
---|
590 | % namesleft := namesleft - 1
|
---|
591 | % od
|
---|
592 | % return nameresult
|
---|
593 | % END
|
---|
594 | %
|
---|
595 | % The format.authors function returns the result of format.names(author)
|
---|
596 | % if the author is present, or else it returns the null string
|
---|
597 | %
|
---|
598 | % format.authors ==
|
---|
599 | % BEGIN
|
---|
600 | % if empty$(author) then return ""
|
---|
601 | % else return format.names(author)
|
---|
602 | % fi
|
---|
603 | % END
|
---|
604 | %
|
---|
605 | % Format.editors is like format.authors, but it uses the editor field,
|
---|
606 | % and appends ", editor" or ", editors"
|
---|
607 | %
|
---|
608 | % format.editors ==
|
---|
609 | % BEGIN
|
---|
610 | % if empty$(editor) then return ""
|
---|
611 | % else
|
---|
612 | % if num.names$(editor) > 1 then
|
---|
613 | % return format.names(editor) * ", editors"
|
---|
614 | % else
|
---|
615 | % return format.names(editor) * ", editor"
|
---|
616 | % fi
|
---|
617 | % fi
|
---|
618 | % END
|
---|
619 | %
|
---|
620 | % Other formatting functions are similar, so no "comment version" will be
|
---|
621 | % given for them.
|
---|
622 | %
|
---|
623 | % The `pop$' in this function gets rid of the duplicate `empty' value and
|
---|
624 | % the `skip$' returns the duplicate field value
|
---|
625 | FUNCTION {field.or.null}
|
---|
626 | { duplicate$ empty$
|
---|
627 | { pop$ "" }
|
---|
628 | 'skip$
|
---|
629 | if$
|
---|
630 | }
|
---|
631 | FUNCTION {emphasize}
|
---|
632 | { duplicate$ empty$
|
---|
633 | { pop$ "" }
|
---|
634 | { "{\em " swap$ * "}" * }
|
---|
635 | if$
|
---|
636 | }
|
---|
637 | FUNCTION {embolden}
|
---|
638 | { duplicate$ empty$
|
---|
639 | { pop$ "" }
|
---|
640 | { "{\bf " swap$ * "}" * }
|
---|
641 | if$
|
---|
642 | }
|
---|
643 | FUNCTION {bracket}
|
---|
644 | { duplicate$ empty$
|
---|
645 | { pop$ "" }
|
---|
646 | { "[" swap$ * "]" * }
|
---|
647 | if$
|
---|
648 | }
|
---|
649 | FUNCTION {paren}
|
---|
650 | { duplicate$ empty$
|
---|
651 | { pop$ "" }
|
---|
652 | { "(" swap$ * ")" * }
|
---|
653 | if$
|
---|
654 | }
|
---|
655 | INTEGERS { nameptr namesleft numnames }
|
---|
656 | INTEGERS { etal }
|
---|
657 | FUNCTION {format.names}
|
---|
658 | { 's :=
|
---|
659 | #1 'nameptr :=
|
---|
660 | s num.names$ 'numnames :=
|
---|
661 | numnames #3 >
|
---|
662 | s numnames "{ll}" format.name$ "others" = numnames #1 > and
|
---|
663 | or 'etal :=
|
---|
664 | etal
|
---|
665 | { #1 #1 + 'namesleft := }
|
---|
666 | { numnames 'namesleft := }
|
---|
667 | if$
|
---|
668 | { namesleft #0 > }
|
---|
669 | { s nameptr "{f.~}{vv~}{ll}{, jj}" format.name$ 't :=
|
---|
670 | nameptr #1 >
|
---|
671 | { namesleft #1 >
|
---|
672 | { ", " * t * }
|
---|
673 | { nameptr #2 >
|
---|
674 | { "," * }
|
---|
675 | 'skip$
|
---|
676 | if$
|
---|
677 | t "others" =
|
---|
678 | etal or
|
---|
679 | { " et~al." * }
|
---|
680 | { " and " * t * }
|
---|
681 | if$
|
---|
682 | }
|
---|
683 | if$
|
---|
684 | }
|
---|
685 | 't
|
---|
686 | if$
|
---|
687 | nameptr #1 + 'nameptr :=
|
---|
688 | namesleft #1 - 'namesleft :=
|
---|
689 | }
|
---|
690 | while$
|
---|
691 | }
|
---|
692 | FUNCTION {format.authors}
|
---|
693 | { author empty$
|
---|
694 | { "" }
|
---|
695 | { author format.names }
|
---|
696 | if$
|
---|
697 | }
|
---|
698 | FUNCTION {format.editors}
|
---|
699 | { editor empty$
|
---|
700 | { "" }
|
---|
701 | { editor format.names
|
---|
702 | editor num.names$ #1 >
|
---|
703 | { ", editors" * }
|
---|
704 | { ", editor" * }
|
---|
705 | if$
|
---|
706 | }
|
---|
707 | if$
|
---|
708 | }
|
---|
709 | % The format.title function is used for non-book-like titles.
|
---|
710 | % For most styles we convert to lowercase (except for the very first letter,
|
---|
711 | % and except for the first one after a colon (followed by whitespace)),
|
---|
712 | % and hope the user has brace-surrounded words that need to stay capitilized;
|
---|
713 | % for some styles, however, we leave it as it is in the database.
|
---|
714 | FUNCTION {format.title}
|
---|
715 | { title empty$
|
---|
716 | { "" }
|
---|
717 | { title "t" change.case$ }
|
---|
718 | if$
|
---|
719 | }
|
---|
720 | % By default, BibTeX sets the global integer variable global.max$ to the BibTeX
|
---|
721 | % constant glob_str_size, the maximum length of a global string variable.
|
---|
722 | % Analogously, BibTeX sets the global integer variable entry.max$ to
|
---|
723 | % ent_str_size, the maximum length of an entry string variable.
|
---|
724 | % The style designer may change these if necessary (but this is unlikely)
|
---|
725 | % The n.dashify function makes each single `-' in a string a double `--'
|
---|
726 | % if it's not already
|
---|
727 | %
|
---|
728 | % pseudoVAR: pageresult: STRING (it's what's accumulated on the stack)
|
---|
729 | %
|
---|
730 | % n.dashify(s) ==
|
---|
731 | % BEGIN
|
---|
732 | % t := s
|
---|
733 | % pageresult := ""
|
---|
734 | % while (not empty$(t))
|
---|
735 | % do
|
---|
736 | % if (first character of t = "-")
|
---|
737 | % then
|
---|
738 | % if (next character isn't)
|
---|
739 | % then
|
---|
740 | % pageresult := pageresult * "--"
|
---|
741 | % t := t with the "-" removed
|
---|
742 | % else
|
---|
743 | % while (first character of t = "-")
|
---|
744 | % do
|
---|
745 | % pageresult := pageresult * "-"
|
---|
746 | % t := t with the "-" removed
|
---|
747 | % od
|
---|
748 | % fi
|
---|
749 | % else
|
---|
750 | % pageresult := pageresult * the first character
|
---|
751 | % t := t with the first character removed
|
---|
752 | % fi
|
---|
753 | % od
|
---|
754 | % return pageresult
|
---|
755 | % END
|
---|
756 | FUNCTION {n.dashify}
|
---|
757 | { 't :=
|
---|
758 | ""
|
---|
759 | { t empty$ not }
|
---|
760 | { t #1 #1 substring$ "-" =
|
---|
761 | { t #1 #2 substring$ "--" = not
|
---|
762 | { "--" *
|
---|
763 | t #2 global.max$ substring$ 't :=
|
---|
764 | }
|
---|
765 | { { t #1 #1 substring$ "-" = }
|
---|
766 | { "-" *
|
---|
767 | t #2 global.max$ substring$ 't :=
|
---|
768 | }
|
---|
769 | while$
|
---|
770 | }
|
---|
771 | if$
|
---|
772 | }
|
---|
773 | { t #1 #1 substring$ *
|
---|
774 | t #2 global.max$ substring$ 't :=
|
---|
775 | }
|
---|
776 | if$
|
---|
777 | }
|
---|
778 | while$
|
---|
779 | }
|
---|
780 | FUNCTION {first.page}
|
---|
781 | { 't :=
|
---|
782 | ""
|
---|
783 | { t empty$ not t #1 #1 substring$ "-" = not and }
|
---|
784 | { t #1 #1 substring$ *
|
---|
785 | t #2 global.max$ substring$ 't :=
|
---|
786 | }
|
---|
787 | while$
|
---|
788 | }
|
---|
789 | % The format.date function is for the month and year, but we give a warning if
|
---|
790 | % there's an empty year but the month is there, and we return the empty string
|
---|
791 | % if they're both empty.
|
---|
792 | FUNCTION {format.collaboration}
|
---|
793 | { collaboration empty$
|
---|
794 | { "" * }
|
---|
795 | { " (" * collaboration * " Collab.)" }
|
---|
796 | if$
|
---|
797 | }
|
---|
798 | FUNCTION {format.collabbook}
|
---|
799 | { collaboration empty$
|
---|
800 | { "" * }
|
---|
801 | { "The " * collaboration * " Collaboration" }
|
---|
802 | if$
|
---|
803 | }
|
---|
804 |
|
---|
805 |
|
---|
806 | FUNCTION {format.url}
|
---|
807 | { url empty$
|
---|
808 | { "" }
|
---|
809 | { new.block "\url{" url * "}" * }
|
---|
810 | if$
|
---|
811 | }
|
---|
812 |
|
---|
813 |
|
---|
814 |
|
---|
815 | FUNCTION {format.date}
|
---|
816 | { year empty$
|
---|
817 | { "" }
|
---|
818 | 'year
|
---|
819 | if$
|
---|
820 | }
|
---|
821 | % The format.btitle is for formatting the title field when it is a book-like
|
---|
822 | % entry---the style used here keeps it in uppers-and-lowers and emphasizes it.
|
---|
823 | FUNCTION {format.btitle}
|
---|
824 | { title emphasize
|
---|
825 | }
|
---|
826 | % For several functions we'll need to connect two strings with a
|
---|
827 | % tie (~) if the second one isn't very long (fewer than 3 characters).
|
---|
828 | % The tie.or.space.connect function does that. It concatenates the two
|
---|
829 | % strings on top of the stack, along with either a tie or space between
|
---|
830 | % them, and puts this concatenation back onto the stack:
|
---|
831 | %
|
---|
832 | % tie.or.space.connect(str1,str2) ==
|
---|
833 | % BEGIN
|
---|
834 | % if text.length$(str2) < 3
|
---|
835 | % then return the concatenation of str1, "~", and str2
|
---|
836 | % else return the concatenation of str1, " ", and str2
|
---|
837 | % END
|
---|
838 | FUNCTION {tie.or.space.connect}
|
---|
839 | { duplicate$ text.length$ #3 <
|
---|
840 | { "~" }
|
---|
841 | { " " }
|
---|
842 | if$
|
---|
843 | swap$ * *
|
---|
844 | }
|
---|
845 | % The either.or.check function complains if both fields or an either-or pair
|
---|
846 | % are nonempty.
|
---|
847 | %
|
---|
848 | % either.or.check(t,s) ==
|
---|
849 | % BEGIN
|
---|
850 | % if empty$(s) then
|
---|
851 | % warning$(can't use both " * t * " fields in " * cite$)
|
---|
852 | % fi
|
---|
853 | % END
|
---|
854 | FUNCTION {either.or.check}
|
---|
855 | { empty$
|
---|
856 | 'pop$
|
---|
857 | { "can't use both " swap$ * " fields in " * cite$ * warning$ }
|
---|
858 | if$
|
---|
859 | }
|
---|
860 | % The format.bvolume function is for formatting the volume and perhaps
|
---|
861 | % series name of a multivolume work. If both a volume and a series field
|
---|
862 | % are there, we assume the series field is the title of the whole multivolume
|
---|
863 | % work (the title field should be the title of the thing being referred to),
|
---|
864 | % and we add an "of <series>". This function is called in mid-sentence.
|
---|
865 | FUNCTION {format.bvolume}
|
---|
866 | { volume empty$
|
---|
867 | { "" }
|
---|
868 | { "volume" volume tie.or.space.connect
|
---|
869 | series empty$
|
---|
870 | 'skip$
|
---|
871 | { " of " * series emphasize * }
|
---|
872 | if$
|
---|
873 | "volume and number" number either.or.check
|
---|
874 | }
|
---|
875 | if$
|
---|
876 | }
|
---|
877 | % The format.number.series function is for formatting the series name
|
---|
878 | % and perhaps number of a work in a series. This function is similar to
|
---|
879 | % format.bvolume, although for this one the series must exist (and the
|
---|
880 | % volume must not exist). If the number field is empty we output either
|
---|
881 | % the series field unchanged if it exists or else the null string.
|
---|
882 | % If both the number and series fields are there we assume the series field
|
---|
883 | % gives the name of the whole series (the title field should be the title
|
---|
884 | % of the work being one referred to), and we add an "in <series>".
|
---|
885 | % We capitilize Number when this function is used at the beginning of a block.
|
---|
886 | FUNCTION {format.number.series}
|
---|
887 | { volume empty$
|
---|
888 | { number empty$
|
---|
889 | { series field.or.null }
|
---|
890 | { output.state mid.sentence =
|
---|
891 | { "number" }
|
---|
892 | { "Number" }
|
---|
893 | if$
|
---|
894 | number tie.or.space.connect
|
---|
895 | series empty$
|
---|
896 | { "there's a number but no series in " cite$ * warning$ }
|
---|
897 | { " in " * series * }
|
---|
898 | if$
|
---|
899 | }
|
---|
900 | if$
|
---|
901 | }
|
---|
902 | { "" }
|
---|
903 | if$
|
---|
904 | }
|
---|
905 | % The format.edition function appends " edition" to the edition, if present.
|
---|
906 | % We lowercase the edition (it should be something like "Third"), because
|
---|
907 | % this doesn't start a sentence.
|
---|
908 | FUNCTION {format.edition}
|
---|
909 | { edition empty$
|
---|
910 | { "" }
|
---|
911 | { output.state mid.sentence =
|
---|
912 | { edition "l" change.case$ " edition" * }
|
---|
913 | { edition "t" change.case$ " edition" * }
|
---|
914 | if$
|
---|
915 | }
|
---|
916 | if$
|
---|
917 | }
|
---|
918 | % The format.pages function is used for formatting a page range in a book
|
---|
919 | % (and in rare circumstances, an article).
|
---|
920 | %
|
---|
921 | % The multi.page.check function examines the page field for a "-" or "," or "+"
|
---|
922 | % so that format.pages can use "page" instead of "pages" if none exists.
|
---|
923 | % Note: global.max$ here means "take the rest of the string"
|
---|
924 | %
|
---|
925 | % VAR: multiresult: INTEGER (actually, a boolean)
|
---|
926 | %
|
---|
927 | % multi.page.check(s) ==
|
---|
928 | % BEGIN
|
---|
929 | % t := s
|
---|
930 | % multiresult := false
|
---|
931 | % while ((not multiresult) and (not empty$(t)))
|
---|
932 | % do
|
---|
933 | % if (first character of t = "-" or "," or "+")
|
---|
934 | % then multiresult := true
|
---|
935 | % else t := t with the first character removed
|
---|
936 | % fi
|
---|
937 | % od
|
---|
938 | % return multiresult
|
---|
939 | % END
|
---|
940 | INTEGERS { multiresult }
|
---|
941 | FUNCTION {multi.page.check}
|
---|
942 | { 't :=
|
---|
943 | #0 'multiresult :=
|
---|
944 | { multiresult not
|
---|
945 | t empty$ not
|
---|
946 | and
|
---|
947 | }
|
---|
948 | { t #1 #1 substring$
|
---|
949 | duplicate$ "-" =
|
---|
950 | swap$ duplicate$ "," =
|
---|
951 | swap$ "+" =
|
---|
952 | or or
|
---|
953 | { #1 'multiresult := }
|
---|
954 | { t #2 global.max$ substring$ 't := }
|
---|
955 | if$
|
---|
956 | }
|
---|
957 | while$
|
---|
958 | multiresult
|
---|
959 | }
|
---|
960 | % This function doesn't begin a sentence so "pages" isn't capitalized.
|
---|
961 | % Other functions that use this should keep that in mind.
|
---|
962 | FUNCTION {format.pages}
|
---|
963 | { pages empty$
|
---|
964 | { "" }
|
---|
965 | { pages multi.page.check
|
---|
966 | { "pp." pages n.dashify tie.or.space.connect }
|
---|
967 | { "p." pages tie.or.space.connect }
|
---|
968 | if$
|
---|
969 | }
|
---|
970 | if$
|
---|
971 | }
|
---|
972 | FUNCTION {format.pages.a}
|
---|
973 | { pages empty$
|
---|
974 | { "" }
|
---|
975 | { "p." pages first.page tie.or.space.connect }
|
---|
976 | if$
|
---|
977 | }
|
---|
978 | % The format.vol.num.pages function is for the volume, number, and page range
|
---|
979 | % of a journal article. We use the format: vol(number):pages, with some
|
---|
980 | % variations for empty fields. This doesn't begin a sentence.
|
---|
981 | FUNCTION {format.vol.num.pages}
|
---|
982 | { volume field.or.null embolden
|
---|
983 | " " swap$ * *
|
---|
984 | format.date empty$
|
---|
985 | 'skip$
|
---|
986 | { duplicate$ empty$
|
---|
987 | { pop$ format.date paren }
|
---|
988 | { " " * format.date paren * }
|
---|
989 | if$
|
---|
990 | }
|
---|
991 | if$
|
---|
992 | pages empty$
|
---|
993 | 'skip$
|
---|
994 | { duplicate$ empty$
|
---|
995 | { pop$ format.pages.a }
|
---|
996 | { " " * pages first.page *}
|
---|
997 | if$
|
---|
998 | }
|
---|
999 | if$
|
---|
1000 | }
|
---|
1001 | % The format.chapter.pages, if the chapter is present, puts whatever is in the
|
---|
1002 | % type field (or else "chapter" if type is empty) in front of a chapter number.
|
---|
1003 | % It then appends the pages, if present. This doesn't begin a sentence.
|
---|
1004 | FUNCTION {format.chapter.pages}
|
---|
1005 | { chapter empty$
|
---|
1006 | 'format.pages
|
---|
1007 | { type empty$
|
---|
1008 | { "chapter" }
|
---|
1009 | { type "l" change.case$ }
|
---|
1010 | if$
|
---|
1011 | chapter tie.or.space.connect
|
---|
1012 | pages empty$
|
---|
1013 | 'skip$
|
---|
1014 | { ", " * format.pages * }
|
---|
1015 | if$
|
---|
1016 | }
|
---|
1017 | if$
|
---|
1018 | }
|
---|
1019 | % The format.in.ed.booktitle function is used for starting out a sentence
|
---|
1020 | % that begins "In <booktitle>", putting an editor before the title if one
|
---|
1021 | % exists.
|
---|
1022 | FUNCTION {format.in.ed.booktitle}
|
---|
1023 | { booktitle empty$
|
---|
1024 | { "" }
|
---|
1025 | { editor empty$
|
---|
1026 | { "in " booktitle emphasize * }
|
---|
1027 | { "in " format.editors * ", " * booktitle emphasize * }
|
---|
1028 | if$
|
---|
1029 | }
|
---|
1030 | if$
|
---|
1031 | }
|
---|
1032 | % The function empty.misc.check complains if all six fields are empty, and
|
---|
1033 | % if there's been no sorting or alphabetic-label complaint.
|
---|
1034 | FUNCTION {empty.misc.check}
|
---|
1035 | { author empty$ title empty$ howpublished empty$
|
---|
1036 | month empty$ year empty$ note empty$ eprint empty$
|
---|
1037 | and and and and and
|
---|
1038 | { "all relevant fields are empty in " cite$ * warning$ }
|
---|
1039 | 'skip$
|
---|
1040 | if$
|
---|
1041 | }
|
---|
1042 | % The function format.thesis.type returns either the (case-changed) type field,
|
---|
1043 | % if it is defined, or else the default string already on the stack
|
---|
1044 | % (like "Master's thesis" or "PhD thesis").
|
---|
1045 | FUNCTION {format.thesis.type}
|
---|
1046 | { type empty$
|
---|
1047 | 'skip$
|
---|
1048 | { pop$
|
---|
1049 | type "t" change.case$
|
---|
1050 | }
|
---|
1051 | if$
|
---|
1052 | }
|
---|
1053 | % The function format.tr.number makes a string starting with "Technical Report"
|
---|
1054 | % (or type, if that field is defined), followed by the number if there is one;
|
---|
1055 | % it returns the starting part (with a case change) even if there is no number.
|
---|
1056 | % This is used at the beginning of a sentence.
|
---|
1057 | FUNCTION {format.tr.number}
|
---|
1058 | { type empty$
|
---|
1059 | { "Technical Report" }
|
---|
1060 | 'type
|
---|
1061 | if$
|
---|
1062 | number empty$
|
---|
1063 | { "t" change.case$ }
|
---|
1064 | { number tie.or.space.connect }
|
---|
1065 | if$
|
---|
1066 | }
|
---|
1067 | % Now come the cross-referencing functions (these are invoked because
|
---|
1068 | % one entry in the database file(s) cross-references another, by giving
|
---|
1069 | % the other entry's database key in a `crossref' field). This feature
|
---|
1070 | % allows one or more titled things that are part of a larger titled
|
---|
1071 | % thing to cross-reference the larger thing. These styles allow for
|
---|
1072 | % five posibilities: (1) an ARTICLE may cross-reference an ARTICLE;
|
---|
1073 | % (2) a BOOK, (3) INBOOK, or (4) INCOLLECTION may cross-reference a BOOK;
|
---|
1074 | % or (5) an INPROCEEDINGS may cross-reference a PROCEEDINGS.
|
---|
1075 | % Each of these is explained in more detail later.
|
---|
1076 | %
|
---|
1077 | % An ARTICLE entry type may cross reference another ARTICLE (this is
|
---|
1078 | % intended for when an entire journal is devoted to a single topic---
|
---|
1079 | % but since there is no JOURNAL entry type, the journal, too, should be
|
---|
1080 | % classified as an ARTICLE but without the author and title fields).
|
---|
1081 | % This will result in two warning messages for the journal's entry
|
---|
1082 | % if it's included in the reference list, but such is life.
|
---|
1083 | %
|
---|
1084 | % format.article.crossref ==
|
---|
1085 | % BEGIN
|
---|
1086 | % if empty$(key) then
|
---|
1087 | % if empty$(journal) then
|
---|
1088 | % warning$("need key or journal for " * cite$ *
|
---|
1089 | % " to crossref " * crossref)
|
---|
1090 | % return(" \cite{" * crossref * "}")
|
---|
1091 | % else
|
---|
1092 | % return("In " * emphazise.correct (journal) *
|
---|
1093 | % " \cite{" * crossref * "}")
|
---|
1094 | % fi
|
---|
1095 | % else
|
---|
1096 | % return("In " * key * " \cite{" * crossref * "}")
|
---|
1097 | % fi
|
---|
1098 | % END
|
---|
1099 | %
|
---|
1100 | % The other cross-referencing functions are similar, so no "comment version"
|
---|
1101 | % will be given for them.
|
---|
1102 | FUNCTION {format.article.crossref}
|
---|
1103 | { key empty$
|
---|
1104 | { journal empty$
|
---|
1105 | { "need key or journal for " cite$ * " to crossref " * crossref *
|
---|
1106 | warning$
|
---|
1107 | ""
|
---|
1108 | }
|
---|
1109 | { "In " journal * }
|
---|
1110 | if$
|
---|
1111 | }
|
---|
1112 | { "In " key * }
|
---|
1113 | if$
|
---|
1114 | " \cite{" * crossref * "}" *
|
---|
1115 | }
|
---|
1116 | % We use just the last names of editors for a cross reference: either
|
---|
1117 | % "editor", or "editor1 and editor2", or "editor1 et~al." depending on
|
---|
1118 | % whether there are one, or two, or more than two editors.
|
---|
1119 | FUNCTION {format.crossref.editor}
|
---|
1120 | { editor #1 "{vv~}{ll}" format.name$
|
---|
1121 | editor num.names$ duplicate$
|
---|
1122 | { pop$ " et~al." * }
|
---|
1123 | { #2 <
|
---|
1124 | 'skip$
|
---|
1125 | { editor #2 "{ff }{vv }{ll}{ jj}" format.name$ "others" =
|
---|
1126 | { " et~al." * }
|
---|
1127 | { " and " * editor #2 "{vv~}{ll}" format.name$ * }
|
---|
1128 | if$
|
---|
1129 | }
|
---|
1130 | if$
|
---|
1131 | }
|
---|
1132 | if$
|
---|
1133 | }
|
---|
1134 | % A BOOK (or INBOOK) entry type (assumed to be for a single volume in a
|
---|
1135 | % multivolume work) may cross reference another BOOK (the entire multivolume).
|
---|
1136 | % Usually there will be an editor, in which case we use that to construct the
|
---|
1137 | % cross reference; otherwise we use a nonempty key field or else the series
|
---|
1138 | % field (since the series gives the title of the multivolume work).
|
---|
1139 | FUNCTION {format.book.crossref}
|
---|
1140 | { volume empty$
|
---|
1141 | { "empty volume in " cite$ * "'s crossref of " * crossref * warning$
|
---|
1142 | "In "
|
---|
1143 | }
|
---|
1144 | { "Volume" volume tie.or.space.connect
|
---|
1145 | " of " *
|
---|
1146 | }
|
---|
1147 | if$
|
---|
1148 | editor empty$
|
---|
1149 | editor field.or.null author field.or.null =
|
---|
1150 | or
|
---|
1151 | { key empty$
|
---|
1152 | { series empty$
|
---|
1153 | { "need editor, key, or series for " cite$ * " to crossref " *
|
---|
1154 | crossref * warning$
|
---|
1155 | "" *
|
---|
1156 | }
|
---|
1157 | { "{\em " * series * "\/}" * }
|
---|
1158 | if$
|
---|
1159 | }
|
---|
1160 | { key * }
|
---|
1161 | if$
|
---|
1162 | }
|
---|
1163 | { format.crossref.editor * }
|
---|
1164 | if$
|
---|
1165 | " \cite{" * crossref * "}" *
|
---|
1166 | }
|
---|
1167 | % An INCOLLECTION entry type may cross reference a BOOK (assumed to be the
|
---|
1168 | % collection), or an INPROCEEDINGS may cross reference a PROCEEDINGS.
|
---|
1169 | % Often there will be an editor, in which case we use that to construct
|
---|
1170 | % the cross reference; otherwise we use a nonempty key field or else
|
---|
1171 | % the booktitle field (which gives the cross-referenced work's title).
|
---|
1172 | FUNCTION {format.incoll.inproc.crossref}
|
---|
1173 | { editor empty$
|
---|
1174 | editor field.or.null author field.or.null =
|
---|
1175 | or
|
---|
1176 | { key empty$
|
---|
1177 | { booktitle empty$
|
---|
1178 | { "need editor, key, or booktitle for " cite$ * " to crossref " *
|
---|
1179 | crossref * warning$
|
---|
1180 | ""
|
---|
1181 | }
|
---|
1182 | { "In {\em " booktitle * "\/}" * }
|
---|
1183 | if$
|
---|
1184 | }
|
---|
1185 | { "In " key * }
|
---|
1186 | if$
|
---|
1187 | }
|
---|
1188 | { "In " format.crossref.editor * }
|
---|
1189 | if$
|
---|
1190 | " \cite{" * crossref * "}" *
|
---|
1191 | }
|
---|
1192 | % Now we define the type functions for all entry types that may appear
|
---|
1193 | % in the .BIB file---e.g., functions like `article' and `book'. These
|
---|
1194 | % are the routines that actually generate the .BBL-file output for
|
---|
1195 | % the entry. These must all precede the READ command. In addition, the
|
---|
1196 | % style designer should have a function `default.type' for unknown types.
|
---|
1197 | % Note: The fields (within each list) are listed in order of appearance,
|
---|
1198 | % except as described for an `inbook' or a `proceedings'.
|
---|
1199 | %
|
---|
1200 | % The article function is for an article in a journal. An article may
|
---|
1201 | % CROSSREF another article.
|
---|
1202 | % Required fields: author, title, journal, year
|
---|
1203 | % Optional fields: volume, number, pages, month, note, eprint
|
---|
1204 | %
|
---|
1205 | % article ==
|
---|
1206 | % BEGIN
|
---|
1207 | % output.bibitem
|
---|
1208 | % output.check(format.authors,"author")
|
---|
1209 | % new.block
|
---|
1210 | % output.check(format.title,"title")
|
---|
1211 | % new.block
|
---|
1212 | % if missing$(crossref) then
|
---|
1213 | % output.check(emphasize(journal),"journal")
|
---|
1214 | % output(format.vol.num.pages)
|
---|
1215 | % output.check(format.date,"year")
|
---|
1216 | % else
|
---|
1217 | % output.nonnull(format.article.crossref)
|
---|
1218 | % output(format.pages)
|
---|
1219 | % fi
|
---|
1220 | % new.block
|
---|
1221 | % output(note)
|
---|
1222 | % fin.entry
|
---|
1223 | % END
|
---|
1224 | %
|
---|
1225 | % The book function is for a whole book. A book may CROSSREF another book.
|
---|
1226 | % Required fields: author or editor, title, publisher, year
|
---|
1227 | % Optional fields: volume or number, series, address, edition, month,
|
---|
1228 | % note
|
---|
1229 | %
|
---|
1230 | % book ==
|
---|
1231 | % BEGIN
|
---|
1232 | % if empty$(author) then output.check(format.editors,"author and editor")
|
---|
1233 | % else output.check(format.authors,"author")
|
---|
1234 | % if missing$(crossref) then
|
---|
1235 | % either.or.check("author and editor",editor)
|
---|
1236 | % fi
|
---|
1237 | % fi
|
---|
1238 | % new.block
|
---|
1239 | % output.check(format.btitle,"title")
|
---|
1240 | % if missing$(crossref) then
|
---|
1241 | % output(format.bvolume)
|
---|
1242 | % new.block
|
---|
1243 | % output(format.number.series)
|
---|
1244 | % new.sentence
|
---|
1245 | % output.check(publisher,"publisher")
|
---|
1246 | % output(address)
|
---|
1247 | % else
|
---|
1248 | % new.block
|
---|
1249 | % output.nonnull(format.book.crossref)
|
---|
1250 | % fi
|
---|
1251 | % output(format.edition)
|
---|
1252 | % output.check(format.date,"year")
|
---|
1253 | % new.block
|
---|
1254 | % output(note)
|
---|
1255 | % fin.entry
|
---|
1256 | % END
|
---|
1257 | %
|
---|
1258 | % The other entry functions are all quite similar, so no "comment version"
|
---|
1259 | % will be given for them.
|
---|
1260 | FUNCTION {article}
|
---|
1261 | { output.bibitem
|
---|
1262 | format.authors *
|
---|
1263 | format.collaboration "collaboration" output.check
|
---|
1264 | % format.authors "author" *
|
---|
1265 | % format.collaboration empty$
|
---|
1266 | % 'skip$
|
---|
1267 | % { duplicate$ empty$
|
---|
1268 | % { pop$ format.collaboration paren }
|
---|
1269 | % { " " * format.collaboration paren * }
|
---|
1270 | % if$
|
---|
1271 | % }
|
---|
1272 | % if$
|
---|
1273 | % output.check
|
---|
1274 |
|
---|
1275 | new.block
|
---|
1276 | format.btitle "title" output.check
|
---|
1277 |
|
---|
1278 | new.block
|
---|
1279 | crossref missing$
|
---|
1280 | { journal field.or.null
|
---|
1281 | format.vol.num.pages output
|
---|
1282 | }
|
---|
1283 | { format.article.crossref output.nonnull
|
---|
1284 | format.pages output
|
---|
1285 | }
|
---|
1286 | if$
|
---|
1287 | note output
|
---|
1288 | eprint output
|
---|
1289 | fin.entry
|
---|
1290 | }
|
---|
1291 | FUNCTION {book}
|
---|
1292 | { output.bibitem
|
---|
1293 | author empty$
|
---|
1294 | { format.editors "author and editor" output.check }
|
---|
1295 | { format.authors output.nonnull
|
---|
1296 | crossref missing$
|
---|
1297 | { "author and editor" editor either.or.check }
|
---|
1298 | 'skip$
|
---|
1299 | if$
|
---|
1300 | }
|
---|
1301 | if$
|
---|
1302 | format.collabbook "collaboration" output.check
|
---|
1303 | new.block
|
---|
1304 | format.btitle "title" output.check
|
---|
1305 | crossref missing$
|
---|
1306 | { format.bvolume output
|
---|
1307 | new.block
|
---|
1308 | format.number.series output
|
---|
1309 | new.sentence
|
---|
1310 | publisher "publisher" output.check
|
---|
1311 | address output
|
---|
1312 | }
|
---|
1313 | { new.block
|
---|
1314 | format.book.crossref output.nonnull
|
---|
1315 | }
|
---|
1316 | if$
|
---|
1317 | format.edition output
|
---|
1318 | format.date "year" output.check
|
---|
1319 | new.block
|
---|
1320 | note output
|
---|
1321 | fin.entry
|
---|
1322 | }
|
---|
1323 | % A booklet is a bound thing without a publisher or sponsoring institution.
|
---|
1324 | % Required: title
|
---|
1325 | % Optional: author, howpublished, address, month, year, note
|
---|
1326 | FUNCTION {booklet}
|
---|
1327 | { output.bibitem
|
---|
1328 | format.authors output
|
---|
1329 | new.block
|
---|
1330 | format.title "title" output.check
|
---|
1331 | howpublished address new.block.checkb
|
---|
1332 | howpublished output
|
---|
1333 | address output
|
---|
1334 | format.date output
|
---|
1335 | new.block
|
---|
1336 | note output
|
---|
1337 | fin.entry
|
---|
1338 | }
|
---|
1339 | % For the conference entry type, see inproceedings.
|
---|
1340 | % An inbook is a piece of a book: either a chapter and/or a page range.
|
---|
1341 | % It may CROSSREF a book. If there's no volume field, the type field
|
---|
1342 | % will come before number and series.
|
---|
1343 | % Required: author or editor, title, chapter and/or pages, publisher,year
|
---|
1344 | % Optional: volume or number, series, type, address, edition, month, note
|
---|
1345 | FUNCTION {inbook}
|
---|
1346 | { output.bibitem
|
---|
1347 | author empty$
|
---|
1348 | { format.editors "author and editor" output.check }
|
---|
1349 | { format.authors output.nonnull
|
---|
1350 | crossref missing$
|
---|
1351 | { "author and editor" editor either.or.check }
|
---|
1352 | 'skip$
|
---|
1353 | if$
|
---|
1354 | }
|
---|
1355 | if$
|
---|
1356 | new.block
|
---|
1357 | format.btitle "title" output.check
|
---|
1358 | crossref missing$
|
---|
1359 | { format.bvolume output
|
---|
1360 | format.chapter.pages "chapter and pages" output.check
|
---|
1361 | new.block
|
---|
1362 | format.number.series output
|
---|
1363 | new.sentence
|
---|
1364 | publisher "publisher" output.check
|
---|
1365 | address output
|
---|
1366 | }
|
---|
1367 | { format.chapter.pages "chapter and pages" output.check
|
---|
1368 | new.block
|
---|
1369 | format.book.crossref output.nonnull
|
---|
1370 | }
|
---|
1371 | if$
|
---|
1372 | format.edition output
|
---|
1373 | format.date "year" output.check
|
---|
1374 | new.block
|
---|
1375 | note output
|
---|
1376 | fin.entry
|
---|
1377 | }
|
---|
1378 | % An incollection is like inbook, but where there is a separate title
|
---|
1379 | % for the referenced thing (and perhaps an editor for the whole).
|
---|
1380 | % An incollection may CROSSREF a book.
|
---|
1381 | % Required: author, title, booktitle, publisher, year
|
---|
1382 | % Optional: editor, volume or number, series, type, chapter, pages,
|
---|
1383 | % address, edition, month, note
|
---|
1384 | FUNCTION {incollection}
|
---|
1385 | { output.bibitem
|
---|
1386 | format.authors "author" output.check
|
---|
1387 | new.block
|
---|
1388 | format.title "title" output.check
|
---|
1389 | new.block
|
---|
1390 | crossref missing$
|
---|
1391 | { format.in.ed.booktitle "booktitle" output.check
|
---|
1392 | format.bvolume output
|
---|
1393 | format.number.series output
|
---|
1394 | format.chapter.pages output
|
---|
1395 | new.sentence
|
---|
1396 | publisher "publisher" output.check
|
---|
1397 | address output
|
---|
1398 | format.edition output
|
---|
1399 | format.date "year" output.check
|
---|
1400 | }
|
---|
1401 | { format.incoll.inproc.crossref output.nonnull
|
---|
1402 | format.chapter.pages output
|
---|
1403 | }
|
---|
1404 | if$
|
---|
1405 | new.block
|
---|
1406 | note output
|
---|
1407 | fin.entry
|
---|
1408 | }
|
---|
1409 | % An inproceedings is an article in a conference proceedings, and it may
|
---|
1410 | % CROSSREF a proceedings. If there's no address field, the month (& year)
|
---|
1411 | % will appear just before note.
|
---|
1412 | % Required: author, title, booktitle, year
|
---|
1413 | % Optional: editor, volume or number, series, pages, address, month,
|
---|
1414 | % organization, publisher, note
|
---|
1415 | FUNCTION {inproceedings}
|
---|
1416 | { output.bibitem
|
---|
1417 | format.authors "author" output.check
|
---|
1418 | new.block
|
---|
1419 | format.title "title" output.check
|
---|
1420 | new.block
|
---|
1421 | crossref missing$
|
---|
1422 | { format.in.ed.booktitle "booktitle" output.check
|
---|
1423 | format.bvolume output
|
---|
1424 | format.number.series output
|
---|
1425 | format.pages output
|
---|
1426 | address empty$
|
---|
1427 | { organization publisher new.sentence.checkb
|
---|
1428 | organization output
|
---|
1429 | publisher output
|
---|
1430 | format.date "year" output.check
|
---|
1431 | }
|
---|
1432 | { address output.nonnull
|
---|
1433 | format.date "year" output.check
|
---|
1434 | new.sentence
|
---|
1435 | organization output
|
---|
1436 | publisher output
|
---|
1437 | }
|
---|
1438 | if$
|
---|
1439 | }
|
---|
1440 | { format.incoll.inproc.crossref output.nonnull
|
---|
1441 | format.pages output
|
---|
1442 | }
|
---|
1443 | if$
|
---|
1444 | new.block
|
---|
1445 | note output
|
---|
1446 | fin.entry
|
---|
1447 | }
|
---|
1448 | % The conference function is included for Scribe compatibility.
|
---|
1449 | FUNCTION {conference} { inproceedings }
|
---|
1450 | % A manual is technical documentation.
|
---|
1451 | % Required: title
|
---|
1452 | % Optional: author, organization, address, edition, month, year, note
|
---|
1453 | FUNCTION {manual}
|
---|
1454 | { output.bibitem
|
---|
1455 | author empty$
|
---|
1456 | { organization empty$
|
---|
1457 | 'skip$
|
---|
1458 | { organization output.nonnull
|
---|
1459 | address output
|
---|
1460 | }
|
---|
1461 | if$
|
---|
1462 | }
|
---|
1463 | { format.authors output.nonnull }
|
---|
1464 | if$
|
---|
1465 | new.block
|
---|
1466 | format.btitle "title" output.check
|
---|
1467 | author empty$
|
---|
1468 | { organization empty$
|
---|
1469 | { address new.block.checka
|
---|
1470 | address output
|
---|
1471 | }
|
---|
1472 | 'skip$
|
---|
1473 | if$
|
---|
1474 | }
|
---|
1475 | { organization address new.block.checkb
|
---|
1476 | organization output
|
---|
1477 | address output
|
---|
1478 | }
|
---|
1479 | if$
|
---|
1480 | format.edition output
|
---|
1481 | format.date output
|
---|
1482 | new.block
|
---|
1483 | note output
|
---|
1484 | fin.entry
|
---|
1485 | }
|
---|
1486 | % A mastersthesis is a Master's thesis.
|
---|
1487 | % Required: author, title, school, year
|
---|
1488 | % Optional: type, address, month, note
|
---|
1489 | FUNCTION {mastersthesis}
|
---|
1490 | { output.bibitem
|
---|
1491 | format.authors "author" output.check
|
---|
1492 | new.block
|
---|
1493 | format.title "title" output.check
|
---|
1494 | new.block
|
---|
1495 | "Master's thesis" format.thesis.type output.nonnull
|
---|
1496 | school "school" output.check
|
---|
1497 | address output
|
---|
1498 | format.date "year" output.check
|
---|
1499 | new.block
|
---|
1500 | note output
|
---|
1501 | fin.entry
|
---|
1502 | }
|
---|
1503 | FUNCTION {diplomathesis}
|
---|
1504 | { output.bibitem
|
---|
1505 | format.authors "author" output.check
|
---|
1506 | new.block
|
---|
1507 | format.btitle "title" output.check
|
---|
1508 | new.block
|
---|
1509 | "Diploma thesis" format.thesis.type output.nonnull
|
---|
1510 | school "school" output.check
|
---|
1511 | address output
|
---|
1512 | format.date "year" output.check
|
---|
1513 | new.block
|
---|
1514 | note output
|
---|
1515 | fin.entry
|
---|
1516 | }
|
---|
1517 | FUNCTION {personal_communication}
|
---|
1518 | { output.bibitem
|
---|
1519 | format.authors "author" output.check
|
---|
1520 | new.block
|
---|
1521 | "private communication" format.thesis.type output.nonnull
|
---|
1522 | new.block
|
---|
1523 | note output
|
---|
1524 | fin.entry
|
---|
1525 | }
|
---|
1526 |
|
---|
1527 |
|
---|
1528 | % A misc is something that doesn't fit elsewhere.
|
---|
1529 | % Required: at least one of the `optional' fields
|
---|
1530 | % Optional: author, title, howpublished, month, year, note
|
---|
1531 | FUNCTION {misc}
|
---|
1532 | { output.bibitem
|
---|
1533 | format.authors output
|
---|
1534 | title howpublished new.block.checkb
|
---|
1535 | format.title output
|
---|
1536 | howpublished new.block.checka
|
---|
1537 | howpublished output
|
---|
1538 | format.date output
|
---|
1539 | new.block
|
---|
1540 | note output
|
---|
1541 | fin.entry
|
---|
1542 | empty.misc.check
|
---|
1543 | }
|
---|
1544 | % A phdthesis is like a mastersthesis.
|
---|
1545 | % Required: author, title, school, year
|
---|
1546 | % Optional: type, address, month, note
|
---|
1547 | FUNCTION {phdthesis}
|
---|
1548 | { output.bibitem
|
---|
1549 | format.authors "author" output.check
|
---|
1550 | new.block
|
---|
1551 | format.btitle "title" output.check
|
---|
1552 | new.block
|
---|
1553 | "PhD thesis" format.thesis.type output.nonnull
|
---|
1554 | school "school" output.check
|
---|
1555 | address output
|
---|
1556 | format.date "year" output.check
|
---|
1557 | new.block
|
---|
1558 | note output
|
---|
1559 | fin.entry
|
---|
1560 | }
|
---|
1561 | % A proceedings is a conference proceedings.
|
---|
1562 | % If there is an organization but no editor field, the organization will
|
---|
1563 | % appear as the first optional field (we try to make the first block nonempty);
|
---|
1564 | % if there's no address field, the month (& year) will appear just before note.
|
---|
1565 | % Required: title, year
|
---|
1566 | % Optional: editor, volume or number, series, address, month,
|
---|
1567 | % organization, publisher, note
|
---|
1568 | FUNCTION {proceedings}
|
---|
1569 | { output.bibitem
|
---|
1570 | editor empty$
|
---|
1571 | { organization output }
|
---|
1572 | { format.editors output.nonnull }
|
---|
1573 | if$
|
---|
1574 | new.block
|
---|
1575 | format.btitle "title" output.check
|
---|
1576 | format.bvolume output
|
---|
1577 | format.number.series output
|
---|
1578 | address empty$
|
---|
1579 | { editor empty$
|
---|
1580 | { publisher new.sentence.checka }
|
---|
1581 | { organization publisher new.sentence.checkb
|
---|
1582 | organization output
|
---|
1583 | }
|
---|
1584 | if$
|
---|
1585 | publisher output
|
---|
1586 | format.date "year" output.check
|
---|
1587 | }
|
---|
1588 | { address output.nonnull
|
---|
1589 | format.date "year" output.check
|
---|
1590 | new.sentence
|
---|
1591 | editor empty$
|
---|
1592 | 'skip$
|
---|
1593 | { organization output }
|
---|
1594 | if$
|
---|
1595 | publisher output
|
---|
1596 | }
|
---|
1597 | if$
|
---|
1598 | new.block
|
---|
1599 | note output
|
---|
1600 | fin.entry
|
---|
1601 | }
|
---|
1602 | % A techreport is a technical report.
|
---|
1603 | % Required: author, title, institution, year
|
---|
1604 | % Optional: type, number, address, month, note
|
---|
1605 | FUNCTION {techreport}
|
---|
1606 | { output.bibitem
|
---|
1607 |
|
---|
1608 | format.authors "author" output.check
|
---|
1609 | new.block
|
---|
1610 |
|
---|
1611 | format.collabbook "collaboration" output.check
|
---|
1612 | new.block
|
---|
1613 |
|
---|
1614 | format.btitle "title" output.check
|
---|
1615 | new.block
|
---|
1616 |
|
---|
1617 | institution "institution" output.check
|
---|
1618 | address output
|
---|
1619 | format.date "year" output.check
|
---|
1620 | new.block
|
---|
1621 | note output
|
---|
1622 | fin.entry
|
---|
1623 | }
|
---|
1624 | %format.title "title" output.check
|
---|
1625 | % format.tr.number output.nonnull
|
---|
1626 |
|
---|
1627 |
|
---|
1628 | FUNCTION {urlcite}
|
---|
1629 | { output.bibitem
|
---|
1630 |
|
---|
1631 | format.authors "author" output.check
|
---|
1632 | new.block
|
---|
1633 |
|
---|
1634 | format.btitle "title" output.check
|
---|
1635 | new.block
|
---|
1636 |
|
---|
1637 | format.url output
|
---|
1638 | new.block
|
---|
1639 |
|
---|
1640 | note output
|
---|
1641 | fin.entry
|
---|
1642 | }
|
---|
1643 |
|
---|
1644 |
|
---|
1645 |
|
---|
1646 | % An unpublished is something that hasn't been published.
|
---|
1647 | % Required: author, title, note
|
---|
1648 | % Optional: month, year
|
---|
1649 | FUNCTION {unpublished}
|
---|
1650 | { output.bibitem
|
---|
1651 | format.authors "author" output.check
|
---|
1652 | new.block
|
---|
1653 | format.title "title" output.check
|
---|
1654 | new.block
|
---|
1655 | note "note" output.check
|
---|
1656 | format.date output
|
---|
1657 | fin.entry
|
---|
1658 | }
|
---|
1659 | % We use entry type `misc' for an unknown type; BibTeX gives a warning.
|
---|
1660 | FUNCTION {default.type} { misc }
|
---|
1661 | % Here are macros for common things that may vary from style to style.
|
---|
1662 | % Users are encouraged to use these macros.
|
---|
1663 | %
|
---|
1664 | % Months are either written out in full or abbreviated
|
---|
1665 | MACRO {jan} {"Jan."}
|
---|
1666 | MACRO {feb} {"Feb."}
|
---|
1667 | MACRO {mar} {"Mar."}
|
---|
1668 | MACRO {apr} {"Apr."}
|
---|
1669 | MACRO {may} {"May"}
|
---|
1670 | MACRO {jun} {"June"}
|
---|
1671 | MACRO {jul} {"July"}
|
---|
1672 | MACRO {aug} {"Aug."}
|
---|
1673 | MACRO {sep} {"Sept."}
|
---|
1674 | MACRO {oct} {"Oct."}
|
---|
1675 | MACRO {nov} {"Nov."}
|
---|
1676 | MACRO {dec} {"Dec."}
|
---|
1677 | % Journals are either written out in full or abbreviated;
|
---|
1678 | % the abbreviations are like those found in ACM publications.
|
---|
1679 | %
|
---|
1680 | % To get a completely different set of abbreviations, it may be best to make
|
---|
1681 | % a separate .bib file with nothing but those abbreviations; users could then
|
---|
1682 | % include that file name as the first argument to the \bibliography command
|
---|
1683 | MACRO {acmcs} {"ACM Comput. Surv."}
|
---|
1684 | MACRO {acta} {"Acta Inf."}
|
---|
1685 | MACRO {cacm} {"Commun. ACM"}
|
---|
1686 | MACRO {ibmjrd} {"IBM J. Res. Dev."}
|
---|
1687 | MACRO {ibmsj} {"IBM Syst.~J."}
|
---|
1688 | MACRO {ieeese} {"IEEE Trans. Softw. Eng."}
|
---|
1689 | MACRO {ieeetc} {"IEEE Trans. Comput."}
|
---|
1690 | MACRO {ieeetcad}
|
---|
1691 | {"IEEE Trans. Comput.-Aided Design Integrated Circuits"}
|
---|
1692 | MACRO {ipl} {"Inf. Process. Lett."}
|
---|
1693 | MACRO {jacm} {"J.~ACM"}
|
---|
1694 | MACRO {jcss} {"J.~Comput. Syst. Sci."}
|
---|
1695 | MACRO {scp} {"Sci. Comput. Programming"}
|
---|
1696 | MACRO {sicomp} {"SIAM J. Comput."}
|
---|
1697 | MACRO {tocs} {"ACM Trans. Comput. Syst."}
|
---|
1698 | MACRO {tods} {"ACM Trans. Database Syst."}
|
---|
1699 | MACRO {tog} {"ACM Trans. Gr."}
|
---|
1700 | MACRO {toms} {"ACM Trans. Math. Softw."}
|
---|
1701 | MACRO {toois} {"ACM Trans. Office Inf. Syst."}
|
---|
1702 | MACRO {toplas} {"ACM Trans. Prog. Lang. Syst."}
|
---|
1703 | MACRO {tcs} {"Theoretical Comput. Sci."}
|
---|
1704 | %% /usr/local/lib/tex/bibtex/phyjfull.btx, Tue Jun 30 08:37:48 1992
|
---|
1705 | %% Edit by Nelson H. F. Beebe <beebe@alfred.math.utah.edu>
|
---|
1706 | %% Change file names in leading comment
|
---|
1707 | % Journal Title Abbreviations from the Physical Review Style and Notation
|
---|
1708 | % Guide, July, 1983, in BAPS Vol. 28.
|
---|
1709 | % Selected by Cris Barnes and Charles Karney, March 1988
|
---|
1710 | % IMPORTANT!! Don't make changes to this file without making the
|
---|
1711 | % corresponding changes to
|
---|
1712 | % phyjabb.bib
|
---|
1713 | % phyjabb.btx
|
---|
1714 | MACRO {advp} {"Advances in Physics"}
|
---|
1715 | MACRO {ajp} {"American Journal of Physics"}
|
---|
1716 | MACRO {ao} {"Applied Optics"}
|
---|
1717 | MACRO {apl} {"Applied Physics Letters"}
|
---|
1718 | MACRO {apj} {"Astrophysical Journal"}
|
---|
1719 | MACRO {baps} {"Bulletin of the American Physical Society"}
|
---|
1720 | MACRO {cpc} {"Computer Physics Communications"}
|
---|
1721 | MACRO {cppcf} {"Comments on Plasma Physics and Controlled Fusion"}
|
---|
1722 | MACRO {fed} {"Fusion Engineering and Design"}
|
---|
1723 | MACRO {ft} {"Fusion Technology"}
|
---|
1724 | MACRO {ieeens} {"IEEE Transactions on Nuclear Science"}
|
---|
1725 | MACRO {ieeeps} {"IEEE Transactions on Plasma Science"}
|
---|
1726 | MACRO {ijimw} {"International Journal of Infrared and Millimeter Waves"}
|
---|
1727 | MACRO {ip} {"Infrared Physics"}
|
---|
1728 | MACRO {jap} {"Journal of Applied Physics"}
|
---|
1729 | MACRO {jcp} {"Journal of Computational Physics"}
|
---|
1730 | MACRO {jetp} {"Soviet Physics-JETP"}
|
---|
1731 | MACRO {jfe} {"Journal of Fusion Energy"}
|
---|
1732 | MACRO {jfm} {"Journal of Fluid Mechanics"}
|
---|
1733 | MACRO {jgr} {"Journal of Geophysical Research"}
|
---|
1734 | MACRO {jmp} {"Journal of Mathematical Physics"}
|
---|
1735 | MACRO {jne} {"Journal of Nuclear Energy"}
|
---|
1736 | MACRO {jnec} {"Journal of Nuclear Energy, Part C: Plasma Physics, Accelerators, Thermonuclear Research"}
|
---|
1737 | MACRO {jnm} {"Journal of Nuclear Materials"}
|
---|
1738 | MACRO {josa} {"Journal of the Optical Society of America"}
|
---|
1739 | MACRO {jpp} {"Journal of Plasma Physics"}
|
---|
1740 | MACRO {jpsj} {"Journal of the Physical Society of Japan"}
|
---|
1741 | MACRO {jvst} {"Journal of Vacuum Science and Technology"}
|
---|
1742 | MACRO {nedf} {"Nuclear Engineering and Design/Fusion"}
|
---|
1743 | MACRO {nf} {"Nuclear Fusion"}
|
---|
1744 | MACRO {nim} {"Nuclear Instruments and Methods"}
|
---|
1745 | MACRO {nimpr} {"Nuclear Instruments and Methods in Physics Research"}
|
---|
1746 | MACRO {nt/f} {"Nuclear Technology/Fusion"}
|
---|
1747 | MACRO {pf} {"Physics of Fluids"}
|
---|
1748 | MACRO {pfa} {"Physics of Fluids A: Fluid Dynamics"}
|
---|
1749 | MACRO {pfb} {"Physics of Fluids B: Plasma Physics"}
|
---|
1750 | MACRO {pl} {"Physics Letters"}
|
---|
1751 | MACRO {pla} {"Physics Letters A"}
|
---|
1752 | MACRO {pnas} {"Proceedings of the National Academy of Sciences of the USA"}
|
---|
1753 | MACRO {pp} {"Plasma Physics"}
|
---|
1754 | MACRO {ppcf} {"Plasma Physics and Controlled Fusion"}
|
---|
1755 | MACRO {prl} {"Physical Review Letters"}
|
---|
1756 | MACRO {pr} {"Physical Review"}
|
---|
1757 | MACRO {pra} {"Physical Review A: General Physics"}
|
---|
1758 | MACRO {ps} {"Physica Scripta"}
|
---|
1759 | MACRO {rmp} {"Reviews of Modern Physics"}
|
---|
1760 | MACRO {rsi} {"Review of Scientific Instruments"}
|
---|
1761 | MACRO {sjpp} {"Soviet Journal of Plasma Phys."}
|
---|
1762 | MACRO {spd} {"Soviet Physics-Doklady"}
|
---|
1763 | MACRO {sptp} {"Soviet Physics-Technical Physics"}
|
---|
1764 | MACRO {spu} {"Soviet Physics-Uspeki"}
|
---|
1765 | % Now we read in the .BIB entries.
|
---|
1766 | READ
|
---|
1767 | % The sortify function converts to lower case after purify$ing; it's
|
---|
1768 | % used in sorting and in computing alphabetic labels after sorting
|
---|
1769 | %
|
---|
1770 | % The chop.word(w,len,s) function returns either s or, if the first len
|
---|
1771 | % letters of s equals w (this comparison is done in the third line of the
|
---|
1772 | % function's definition), it returns that part of s after w.
|
---|
1773 | % This long comment applies only to alphabetic labels
|
---|
1774 | %
|
---|
1775 | % The format.lab.names function makes a short label by using the initials of
|
---|
1776 | % the von and Last parts of the names (but if there are more than four names,
|
---|
1777 | % (i.e., people) it truncates after three and adds a superscripted "+";
|
---|
1778 | % it also adds such a "+" if the last of multiple authors is "others").
|
---|
1779 | % If there is only one name, and its von and Last parts combined have just
|
---|
1780 | % a single name-token ("Knuth" has a single token, "Brinch Hansen" has two),
|
---|
1781 | % we take the first three letters of the last name. The boolean
|
---|
1782 | % et.al.char.used tells whether we've used a superscripted "+", so that we
|
---|
1783 | % know whether to include a LaTeX macro for it.
|
---|
1784 | %
|
---|
1785 | % format.lab.names(s) ==
|
---|
1786 | % BEGIN
|
---|
1787 | % numnames := num.names$(s)
|
---|
1788 | % if numnames > 1 then
|
---|
1789 | % if numnames > 4 then
|
---|
1790 | % namesleft := 3
|
---|
1791 | % else
|
---|
1792 | % namesleft := numnames
|
---|
1793 | % nameptr := 1
|
---|
1794 | % nameresult := ""
|
---|
1795 | % while namesleft > 0
|
---|
1796 | % do
|
---|
1797 | % if (name_ptr = numnames) and
|
---|
1798 | % format.name$(s, nameptr, "{ff }{vv }{ll}{ jj}") = "others"
|
---|
1799 | % then nameresult := nameresult * "{\etalchar{+}}"
|
---|
1800 | % et.al.char.used := true
|
---|
1801 | % else nameresult := nameresult *
|
---|
1802 | % format.name$(s, nameptr, "{v{}}{l{}}")
|
---|
1803 | % nameptr := nameptr + 1
|
---|
1804 | % namesleft := namesleft - 1
|
---|
1805 | % od
|
---|
1806 | % if numnames > 4 then
|
---|
1807 | % nameresult := nameresult * "{\etalchar{+}}"
|
---|
1808 | % et.al.char.used := true
|
---|
1809 | % else
|
---|
1810 | % t := format.name$(s, 1, "{v{}}{l{}}")
|
---|
1811 | % if text.length$(t) < 2 then % there's just one name-token
|
---|
1812 | % nameresult := text.prefix$(format.name$(s,1,"{ll}"),3)
|
---|
1813 | % else
|
---|
1814 | % nameresult := t
|
---|
1815 | % fi
|
---|
1816 | % fi
|
---|
1817 | % return nameresult
|
---|
1818 | % END
|
---|
1819 | %
|
---|
1820 | % Exactly what fields we look at in constructing the primary part of the label
|
---|
1821 | % depends on the entry type; this selectivity (as opposed to, say, always
|
---|
1822 | % looking at author, then editor, then key) helps ensure that "ignored" fields,
|
---|
1823 | % as described in the LaTeX book, really are ignored. Note that MISC is part
|
---|
1824 | % of the deepest `else' clause in the nested part of calc.label; thus, any
|
---|
1825 | % unrecognized entry type in the database is handled correctly.
|
---|
1826 | %
|
---|
1827 | % There is one auxiliary function for each of the four different sequences of
|
---|
1828 | % fields we use. The first of these functions looks at the author field, and
|
---|
1829 | % then, if necessary, the key field. The other three functions, which might
|
---|
1830 | % look at two fields and the key field, are similar, except that the key field
|
---|
1831 | % takes precedence over the organization field (for labels---not for sorting).
|
---|
1832 | %
|
---|
1833 | % The calc.label function calculates the preliminary label of an entry, which
|
---|
1834 | % is formed by taking three letters of information from the author or editor or
|
---|
1835 | % key or organization field (depending on the entry type and on what's empty,
|
---|
1836 | % but ignoring a leading "The " in the organization), and appending the last
|
---|
1837 | % two characters (digits) of the year. It is an error if the appropriate fields
|
---|
1838 | % among author, editor, organization, and key are missing, and we use
|
---|
1839 | % the first three letters of the cite$ in desperation when this happens.
|
---|
1840 | % The resulting label has the year part, but not the name part, purify$ed
|
---|
1841 | % (purify$ing the year allows some sorting shenanigans by the user).
|
---|
1842 | %
|
---|
1843 | % This function also calculates the version of the label to be used in sorting.
|
---|
1844 | %
|
---|
1845 | % The final label may need a trailing 'a', 'b', etc., to distinguish it from
|
---|
1846 | % otherwise identical labels, but we can't calculated those "extra.label"s
|
---|
1847 | % until after sorting.
|
---|
1848 | %
|
---|
1849 | % calc.label ==
|
---|
1850 | % BEGIN
|
---|
1851 | % if type$ = "book" or "inbook" then
|
---|
1852 | % author.editor.key.label
|
---|
1853 | % else if type$ = "proceedings" then
|
---|
1854 | % editor.key.organization.label
|
---|
1855 | % else if type$ = "manual" then
|
---|
1856 | % author.key.organization.label
|
---|
1857 | % else
|
---|
1858 | % author.key.label
|
---|
1859 | % fi fi fi
|
---|
1860 | % label := label * substring$(purify$(field.or.null(year)), -1, 2)
|
---|
1861 | % % assuming we will also sort, we calculate a sort.label
|
---|
1862 | % sort.label := sortify(label), but use the last four, not two, digits
|
---|
1863 | % END
|
---|
1864 | % When sorting, we compute the sortkey by executing "presort" on each entry.
|
---|
1865 | % The presort key contains a number of "sortify"ed strings, concatenated
|
---|
1866 | % with multiple blanks between them. This makes things like "brinch per"
|
---|
1867 | % come before "brinch hansen per".
|
---|
1868 | %
|
---|
1869 | % The fields used here are: the sort.label for alphabetic labels (as set by
|
---|
1870 | % calc.label), followed by the author names (or editor names or organization
|
---|
1871 | % (with a leading "The " removed) or key field, depending on entry type and on
|
---|
1872 | % what's empty), followed by year, followed by the first bit of the title
|
---|
1873 | % (chopping off a leading "The ", "A ", or "An ").
|
---|
1874 | % Names are formatted: Von Last First Junior.
|
---|
1875 | % The names within a part will be separated by a single blank
|
---|
1876 | % (such as "brinch hansen"), two will separate the name parts themselves
|
---|
1877 | % (except the von and last), three will separate the names,
|
---|
1878 | % four will separate the names from year (and from label, if alphabetic),
|
---|
1879 | % and four will separate year from title.
|
---|
1880 | %
|
---|
1881 | % The sort.format.names function takes an argument that should be in
|
---|
1882 | % BibTeX name format, and returns a string containing " "-separated
|
---|
1883 | % names in the format described above. The function is almost the same
|
---|
1884 | % as format.names.
|
---|
1885 | % This long comment applies only to alphabetic labels, when sorted
|
---|
1886 | %
|
---|
1887 | % Now comes the final computation for alphabetic labels, putting in the 'a's
|
---|
1888 | % and 'b's and so forth if required. This involves two passes: a forward
|
---|
1889 | % pass to put in the 'b's, 'c's and so on, and a backwards pass
|
---|
1890 | % to put in the 'a's (we don't want to put in 'a's unless we know there
|
---|
1891 | % are 'b's).
|
---|
1892 | % We have to keep track of the longest (in width$ terms) label, for use
|
---|
1893 | % by the "thebibliography" environment.
|
---|
1894 | %
|
---|
1895 | % VAR: longest.label, last.sort.label, next.extra: string
|
---|
1896 | % longest.label.width, last.extra.num: integer
|
---|
1897 | %
|
---|
1898 | % initialize.longest.label ==
|
---|
1899 | % BEGIN
|
---|
1900 | % longest.label := ""
|
---|
1901 | % last.sort.label := int.to.chr$(0)
|
---|
1902 | % next.extra := ""
|
---|
1903 | % longest.label.width := 0
|
---|
1904 | % last.extra.num := 0
|
---|
1905 | % END
|
---|
1906 | %
|
---|
1907 | % forward.pass ==
|
---|
1908 | % BEGIN
|
---|
1909 | % if last.sort.label = sort.label then
|
---|
1910 | % last.extra.num := last.extra.num + 1
|
---|
1911 | % extra.label := int.to.chr$(last.extra.num)
|
---|
1912 | % else
|
---|
1913 | % last.extra.num := chr.to.int$("a")
|
---|
1914 | % extra.label := ""
|
---|
1915 | % last.sort.label := sort.label
|
---|
1916 | % fi
|
---|
1917 | % END
|
---|
1918 | %
|
---|
1919 | % reverse.pass ==
|
---|
1920 | % BEGIN
|
---|
1921 | % if next.extra = "b" then
|
---|
1922 | % extra.label := "a"
|
---|
1923 | % fi
|
---|
1924 | % label := label * extra.label
|
---|
1925 | % if width$(label) > longest.label.width then
|
---|
1926 | % longest.label := label
|
---|
1927 | % longest.label.width := width$(label)
|
---|
1928 | % fi
|
---|
1929 | % next.extra := extra.label
|
---|
1930 | % END
|
---|
1931 | % Now comes the computation for numeric labels.
|
---|
1932 | % We use either the sorted order or original order.
|
---|
1933 | % We still have to keep track of the longest (in width$ terms) label, for use
|
---|
1934 | % by the "thebibliography" environment.
|
---|
1935 | STRINGS { longest.label }
|
---|
1936 | INTEGERS { number.label longest.label.width }
|
---|
1937 | FUNCTION {initialize.longest.label}
|
---|
1938 | { "" 'longest.label :=
|
---|
1939 | #1 'number.label :=
|
---|
1940 | #0 'longest.label.width :=
|
---|
1941 | }
|
---|
1942 | FUNCTION {longest.label.pass}
|
---|
1943 | { number.label int.to.str$ 'label :=
|
---|
1944 | number.label #1 + 'number.label :=
|
---|
1945 | label width$ longest.label.width >
|
---|
1946 | { label 'longest.label :=
|
---|
1947 | label width$ 'longest.label.width :=
|
---|
1948 | }
|
---|
1949 | 'skip$
|
---|
1950 | if$
|
---|
1951 | }
|
---|
1952 | EXECUTE {initialize.longest.label}
|
---|
1953 | ITERATE {longest.label.pass}
|
---|
1954 | % Now we're ready to start writing the .BBL file.
|
---|
1955 | % We begin, if necessary, with a LaTeX macro for unnamed names in an alphabetic
|
---|
1956 | % label; next comes stuff from the `preamble' command in the database files.
|
---|
1957 | % Then we give an incantation containing the command
|
---|
1958 | % \begin{thebibliography}{...}
|
---|
1959 | % where the `...' is the longest label.
|
---|
1960 | %
|
---|
1961 | % We also call init.state.consts, for use by the output routines.
|
---|
1962 | FUNCTION {begin.bib}
|
---|
1963 | { preamble$ empty$
|
---|
1964 | 'skip$
|
---|
1965 | { preamble$ write$ newline$ }
|
---|
1966 | if$
|
---|
1967 | "\begin{thebibliography}{" longest.label * "}" * write$ newline$
|
---|
1968 | }
|
---|
1969 | EXECUTE {begin.bib}
|
---|
1970 | EXECUTE {init.state.consts}
|
---|
1971 | % Now we produce the output for all the entries
|
---|
1972 | ITERATE {call.type$}
|
---|
1973 | % Finally, we finish up by writing the `\end{thebibliography}' command.
|
---|
1974 | FUNCTION {end.bib}
|
---|
1975 | { newline$
|
---|
1976 | "\end{thebibliography}" write$ newline$
|
---|
1977 | }
|
---|
1978 | EXECUTE {end.bib}
|
---|