-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbioinfo.bst
1444 lines (1278 loc) · 35.5 KB
/
bioinfo.bst
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
% BibTex `bioinformatics' bibliography style
% http://bioinformatics.oupjournals.org/
% http://www.lecb.ncifcrf.gov/~toms/latex.html
%
% version = 1.02 of bioinformatics.bst 2004 Sep 23
% 2004 Sep 23, 1.02: modified by Allan A. Sioson (see notes below)
% 2001 Apr 2, 1.01: origin by Bruce Shapiro from jmb.bst
%
% FROM:
% BibTex `jmb' bibliography style
% version = 1.28 of jmb.bst 1992 November 2
%
% Thomas Schneider
% National Cancer Institute
% Laboratory of Mathematical Biology
% Frederick, Maryland 21702-1013
%
% This file is available by anonymous ftp from ncifcrf.gov in pub/delila.
%
% TITLES can be turned on and off!
% Just nocite the reference TitlesOn in the paper (i.e. \nocite{TitlesOn})
% and have a bibliography article in your database with that cite key!
% Without titles is Journal of Molecular Biology;
% With titles is Journal of Theoretical Biology.
%
% WARNING: Since I use mostly article, book and inproceedings, these
% are formatted pretty closely to the Journal of Theoretical Biology style
% while other things are neglected. Also, I can't guarantee that the style
% is exactly right.
%
% The following documentation is identical from the source of jmb.bst,
% which was the apalike.bst taken from the Clarkson archive on 1989 June 19.
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% BibTeX `apalike' bibliography style (24-Jan-88 version)
% Adapted from the `alpha' style, version 0.99a; for BibTeX version 0.99a.
% Copyright (C) 1988, all rights reserved.
% Copying of this file is allowed, provided that if you make any changes at all
% you name it something other than `apalike.bst'.
% This restriction helps ensure that all copies are identical.
% Differences between this style and `alpha' are generally heralded by a `%'.
% The file btxbst.doc has the documentation for alpha.bst.
%
% This style should be used with the `apalike' LaTeX style (apalike.sty).
% \cite's come out like "(Jones, 1986)" in the text but there are no labels
% in the bibliography, and something like "(1986)" comes out immediately
% after the author. Author (and editor) names appear as last name, comma,
% initials. A `year' field is required for every entry, and so is either
% an author (or in some cases, an editor) field or a key field.
%
% Editorial note:
% Many journals require a style like `apalike', but I strongly, strongly,
% strongly recommend that you not use it if you have a choice---use something
% like `plain' instead. Mary-Claire van Leunen (A Handbook for Scholars,
% Knopf, 1979) argues convincingly that a style like `plain' encourages better
% writing than one like `apalike'. Furthermore the strongest arguments for
% using an author-date style like `apalike'---that it's "the most practical"
% (The Chicago Manual of Style, University of Chicago Press, thirteenth
% edition, 1982, pages 400--401)---fall flat on their face with the new
% computer-typesetting technology. For instance page 401 anachronistically
% states "The chief disadvantage of [a style like `plain'] is that additions
% or deletions cannot be made after the manuscript is typed without changing
% numbers in both text references and list." LaTeX sidesteps the disadvantage.
%
% History:
% 15-sep-86 (SK,OP) Original version, by Susan King and Oren Patashnik.
% 10-nov-86 (OP) Truncated the sort.key$ string to the correct length
% in bib.sort.order to eliminate error message.
% 24-jan-88 (OP) Updated for BibTeX version 0.99a, from alpha.bst 0.99a;
% apalike now sorts by author, then year, then title;
% THIS `apalike' VERSION DOES NOT WORK WITH BIBTEX 0.98i.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% Allan A. Sioson (virginia tech, va 24061-0106, [email protected])
% added the following modifications
%
% 2004 September 21 (AAS) Bioinformatics Journal uses 'and' instead of &
% hence all & are reverted to 'and'.
% (AAS) Author names in Bioinformatics journal looks
% like 'Last,F.S.' and not like 'Last, F. S.'
% (i.e. spaces are removed).
%
% The program was further modified by Tom Schneider:
% 1989 June 19 (TDS) Renamed jmb.bst. Items that do not have years were
% listed in the bibliography without identifiers. However, they
% have identifiers in the text. The identifier was added.
% Titles were removed :-(.
%
% 1989 October 2 (TDS) Made labels in the paper use the & symbol rather
% than `and', as required by JMB.
% 1989 October 3 (TDS) Made et~al. be in italics.
% Removed comma after journal name. (actually, all
% mid sentence commas go!)
% Made volume number be bold faced.
% Converted colon (:) after volume number to a comma (,).
% If a journal name does NOT end in a period, add
% a comma after the name.
% 1989 October 14 (TDS) Without a year the program used to sort on the
% title. I made it sort on the cite$ if there is no year.
% 1989 October 18 (TDS) If there is one reference without a year, put
% an "a" at the end of its label, so that it comes out
% as (Smith, a) in the text. in FUNCTION {forward.pass}
% 1989 November 2 (TDS) Unpublished papers now give the title.
% 1989 November 18 (TDS) TITLES can be turned on and off!
% Just nocite the reference TitlesOn in the paper
% and have a bibliography article in your database
% with that cite key!
% 1989 December 5 (TDS) I can't stand sorting to fall back on the
% titles of the article - no control! So in function
% bib.sort.order the default is now cite$.
% 1990 November 14 (TDS) Changes to match JTB better:
% Names in the bibliography are now connected
% with "\&" instead of "and", since this fits JTB better.
% "In" is now "In:".
% "editors" and "editor" are now "eds" and "ed".
% booktitle follows editors. editors in parenthesis.
% pp. and p. instead of pages and page.
% location followed by colon (:) and then publisher.
% 1992 October 22 (TDS) Publisher address is at the end of books.
% with no colon after address.
% no comma before & in name list in bibliography.
% The extra.label (as the a of 1991a) is emphasized.
% "In:" goes back to "In"!
% publisher address is at the end of inproceedings.
% volume is "vol.", with comma after number.
% ed.", and comma after ) closing editors.
% as a colon (:), JMB does NOT want the next
% ed, but the format.title function uses
% which leaves it capitalized. To fix this, a
% place change.case$ must be written.
%
% When a title has a colon (:), JMB does NOT want the next
% word capitalized, but the format.title function uses
% change.case$, which leaves it capitalized. To fix this, a
% function to replace change.case$ was written:
% special.change.case
%
% edition should follow TITLE for books!
% possible bug: sorting order probably should be first author followed
% by year; but this is not absolutely clear. Sorting here is (I think)
% by all authors (or perhaps the key) then year.
ENTRY % declare variables that have a value for each entry on the list
{ address
author
booktitle
chapter
edition
editor
howpublished
institution
journal
key
% month not used in apalike
note
number
organization
pages
publisher
school
series
title
type
volume
year
}
{}
{ label extra.label sort.label }
INTEGERS { output.state before.all mid.sentence after.sentence after.block
docomma givetitles }
FUNCTION {init.state.consts}
{ #0 'before.all :=
#1 'mid.sentence :=
#2 'after.sentence :=
#3 'after.block :=
#0 'docomma := % if it is 0 then don't do commas, otherwise do them.
}
FUNCTION {init.toggle.switches}
{% set switches for controlling the output!
#1 'givetitles := % if it is 0 then don't give titles, otherwise do them.
}
STRINGS { s t }
FUNCTION {output.nonnull}
{ 's :=
output.state mid.sentence =
% % { ", " * write$ } % the comma here is responsible for every comma!
% % % But JMB doesn't want commas, so away it goes!
% { " " * write$ } % That does it!
{ % doing a comma is controlled specifically in JMB using docomma
docomma #0 =
{ " " * write$ }
{ ", " * write$ }
if$
}
{ output.state after.block =
{ add.period$ write$
newline$
"\newblock " write$
}
{ output.state before.all =
'write$
{ add.period$ " " * write$ }
if$
}
if$
mid.sentence 'output.state :=
}
if$
s
}
FUNCTION {output}
{ duplicate$ empty$
'pop$
'output.nonnull
if$
}
FUNCTION {output.check}
{ 't :=
duplicate$ empty$
{ t "title" =
{ pop$ } % jmb ignores titles and does not object if missing
{ pop$ "empty " t * " in " * cite$ * warning$ }
if$
}
'output.nonnull % block periods
% { pop$ } % don't do anything
if$
}
% t "title" =
% { "zowie" warning$ }
% { duplicate$ empty$
% { pop$ "EmPtY " t * " in " * cite$ * warning$ }
% 'output.nonnull
% }
% if$
% if$
%}
% apalike needs this function because
% the year has special punctuation;
% apalike ignores the month
FUNCTION {output.year.check}
{ year empty$
{
"empty year in " cite$ ", using label: " extra.label * * * warning$
write$
% " (" extra.label * ")" * % TDS UNemphasized label
" ({\em{" extra.label * "}})" * % TDS emphasized label
{ label "{\em{" extra.label "}}" * * * 'label :=}
mid.sentence 'output.state :=
}
{ write$
% " (" year * extra.label * ")" * % TDS UNemphasized label
" (" year * "{\em{" extra.label "}}" * * * ")" * % TDS emphasized label
mid.sentence 'output.state :=
}
if$
}
FUNCTION {output.bibitem}
{ newline$
"\bibitem[" write$
label write$
"]{" write$
cite$ write$
"}" write$
newline$
""
before.all 'output.state :=
}
FUNCTION {fin.entry}
{ add.period$
write$
newline$
}
FUNCTION {new.block}
{ output.state before.all =
'skip$
{ after.block 'output.state := }
if$
}
FUNCTION {new.sentence}
{ output.state after.block =
'skip$
{ output.state before.all =
'skip$
{ after.sentence 'output.state := }
if$
}
if$
}
FUNCTION {not}
{ { #0 }
{ #1 }
if$
}
FUNCTION {and}
{ 'skip$
{ pop$ #0 }
if$
}
FUNCTION {or}
{ { pop$ #1 }
'skip$
if$
}
FUNCTION {new.block.checkb}
{ empty$
swap$ empty$
and
'skip$
'new.block
if$
}
FUNCTION {field.or.null}
{ duplicate$ empty$
{ pop$ "" }
'skip$
if$
}
FUNCTION {emphasize}
{ duplicate$ empty$
{ pop$ "" }
{ "{\em " swap$ * "}" * }
if$
}
INTEGERS { nameptr namesleft numnames }
FUNCTION {format.names}
{ 's :=
#1 'nameptr :=
s num.names$ 'numnames :=
numnames 'namesleft :=
{ namesleft #0 > }
% { s nameptr "{vv~}{ll}{, jj}{, f.}" format.name$ 't := % last name first
{ s nameptr "{vv~}{ll}{,jj}{,f{.}.}" format.name$ 't := % last name first
% in bioinformatics, Author names look like 'Last,F.S.'
% i.e. no space in between the last name and first name initial
% and between the first name and second name initials. -allan-
nameptr #1 >
{ namesleft #1 >
{ ", " * t * }
{ numnames #2 >
% { "," * } % remove this comma TDS
{ " " * }
'skip$
if$
t "others" =
{ " {\em et~al.}" * }
% { " \& " * t * }
{ " and " * t * }
if$
}
if$
}
't
if$
nameptr #1 + 'nameptr :=
namesleft #1 - 'namesleft :=
}
while$
}
FUNCTION {format.authors}
{ author empty$
{ "" }
{ author format.names }
if$
}
FUNCTION {format.key} % this function is just for apalike
{ empty$
{ key field.or.null }
{ "" }
if$
}
FUNCTION {format.editors}
{ editor empty$
{ "" }
{ editor format.names
editor num.names$ #1 >
{ ", eds" * } % TDS
{ ", ed." * } % TDS
if$
}
if$
}
FUNCTION {special.change.case}
% change the entire string to lower case except
% for the first letter and things inside {}
% That is, force the first letter after a colon (:) to be lower case
% but otherwise use the change.case$ rules.
{
% title "t" change.case$ % TDS this line was the original method
% start with the first letter of the title, hang on stack
title #1 #1 substring$
% unearth this to see the breakpoint
%"|---|" *
% take the title, change to entire lower case.
title "l" change.case$
% take from second position of lowered title to end of title
#2
global.max$
substring$
% concatenate first letter to rest of title
*
}
FUNCTION {format.title}
{ title empty$
{ "" }
{ % decide whether to give the title or not
givetitles #1 =
% { title "t" change.case$ } % produce the title % TDS original function
{ special.change.case } % produce the title
{ title pop$ "" } % don't produce the title
if$
}
if$
}
FUNCTION {n.dashify}
{ 't :=
""
{ t empty$ not }
{ t #1 #1 substring$ "-" =
{ t #1 #2 substring$ "--" = not
{ "--" *
t #2 global.max$ substring$ 't :=
}
{ { t #1 #1 substring$ "-" = }
{ "-" *
t #2 global.max$ substring$ 't :=
}
while$
}
if$
}
{ t #1 #1 substring$ *
t #2 global.max$ substring$ 't :=
}
if$
}
while$
}
FUNCTION {format.btitle}
{ title emphasize
}
FUNCTION {tie.or.space.connect}
{ duplicate$ text.length$ #3 <
{ "~" }
{ " " }
if$
swap$ * *
}
FUNCTION {either.or.check}
{ empty$
'pop$
{ "can't use both " swap$ * " fields in " * cite$ * warning$ }
if$
}
FUNCTION {format.bvolume}
{ volume empty$
{ "" }
% { "volume" volume tie.or.space.connect % TDS
{ "vol." volume "," * tie.or.space.connect % made vol.
series empty$
'skip$
{ " of " * series emphasize * }
if$
% "volume and number" number either.or.check % TDS
"vol. and num." number either.or.check % made vol.
}
if$
}
FUNCTION {format.number.series}
{ volume empty$
{ number empty$
{ series field.or.null }
{ output.state mid.sentence =
{ "number" }
{ "Number" }
if$
number tie.or.space.connect
series empty$
{ "there's a number but no series in " cite$ * warning$ }
{ " in " * series * }
if$
}
if$
}
{ "" }
if$
}
FUNCTION {format.edition}
{ edition empty$
{ "" }
{ output.state mid.sentence =
{ edition "l" change.case$ " edition," * } % added for CABIOS
{ edition "t" change.case$ " edition," * } % added for CABIOS
if$
}
if$
}
INTEGERS { multiresult }
FUNCTION {multi.page.check}
{ 't :=
#0 'multiresult :=
{ multiresult not
t empty$ not
and
}
{ t #1 #1 substring$
duplicate$ "-" =
swap$ duplicate$ "," =
swap$ "+" =
or or
{ #1 'multiresult := }
{ t #2 global.max$ substring$ 't := }
if$
}
while$
multiresult
}
FUNCTION {format.pages}
{ pages empty$
{ "" }
{ pages multi.page.check
{ "pp." pages n.dashify tie.or.space.connect } % TDS
{ "p." pages tie.or.space.connect } % TDS
if$
}
if$
}
FUNCTION {format.vol.num.pages}
{ "{\bf " volume "}" * * field.or.null % make volume bold face
number empty$
'skip$
{ " (" number * ")" * *
volume empty$
{ "there's a number but no volume in " cite$ * warning$ }
'skip$
if$
}
if$
pages empty$
'skip$
{ duplicate$ empty$
{ pop$ format.pages }
% { ":" * pages n.dashify * } % no more colons after the volume
{ ", " * pages n.dashify * } % comma's instead
if$
}
if$
}
FUNCTION {format.chapter.pages}
{ chapter empty$
'format.pages
{ type empty$
{ "chapter" }
{ type "l" change.case$ }
if$
chapter tie.or.space.connect
pages empty$
'skip$
{ ", " * format.pages * }
if$
}
if$
}
FUNCTION {format.in.ed.booktitle}
{ booktitle empty$
{ "" }
{ editor empty$
{ "In " booktitle emphasize * } % TDS
{ "In " booktitle emphasize * ", " * % That's the comma after the title
"(" format.editors ")," * * * } % TDS
if$
}
if$
}
FUNCTION {format.thesis.type}
{ type empty$
'skip$
{ pop$
type "t" change.case$
}
if$
}
FUNCTION {format.tr.number}
{ type empty$
{ "Technical Report" }
'type
if$
number empty$
{ "t" change.case$ }
{ number tie.or.space.connect }
if$
}
FUNCTION {format.article.crossref}
{ "In" % this is for apalike % TDS
" \cite{" * crossref * "}" *
}
FUNCTION {format.book.crossref}
{ volume empty$
{ "empty volume in " cite$ * "'s crossref of " * crossref * warning$
"In " % TDS
}
{ "Volume" volume tie.or.space.connect
" of " *
}
if$
"\cite{" * crossref * "}" * % this is for apalike
}
FUNCTION {format.incoll.inproc.crossref}
{ "In" % this is for apalike % TDS
" \cite{" * crossref * "}" *
}
FUNCTION {article}
{
cite$ "TitlesOn" =
'skip$ % Don't write out an article of this kind, it's a toggle switch!
{
output.bibitem
format.authors "author" output.check
author format.key output % special for
output.year.check % apalike
% new.block %change for CABIOS don't use period after year
format.title "title" output.check
new.block
crossref missing$
{ % figure out the last character of the journal name.
% "<<" journal #-1 #1 substring$ ">>" * * % for testing
% "<" journal ">" * * % this works ok % for testing
journal #-1 #1 substring$ "." =
{ journal ", " *} % journal ended in period so add comma too
{ journal ", " *} % journal ended without period, so add comma
if$
emphasize "journal" output.check
% journal * emphasize "journal" output.check % the original method
format.vol.num.pages output
}
{ format.article.crossref output.nonnull
format.pages output
}
if$
new.block
note output
fin.entry
}
if$
}
FUNCTION {book}
{ output.bibitem
author empty$
{ format.editors "author and editor" output.check
editor format.key output
}
{ format.authors output.nonnull
crossref missing$
{ "author and editor" editor either.or.check }
'skip$
if$
}
if$
output.year.check % special for apalike
% new.block %change for CABIOS don't use period after year
format.btitle "title" output.check
#1 'docomma := % TURN COMMAS ON FOR JMB
crossref missing$
{
format.bvolume output
new.block
format.number.series output
format.edition output % TDS JMB position for edition
% new.sentence
% #0 'docomma := % no comma after address
% address ":" * output % TDS
publisher "publisher" output.check % TDS
% #1 'docomma := % comma back on
% publisher "publisher" output.check
% address output
address output % TDS - no colon!
}
{ new.block
format.book.crossref output.nonnull
}
if$
% format.edition output % TDS original position of edition
new.block
note output
fin.entry
#0 'docomma := % TURN COMMAS OFF
}
FUNCTION {booklet}
{ output.bibitem
format.authors output
author format.key output % special for
output.year.check % apalike
new.block
format.title "title" output.check
new.block
howpublished output
address output
new.block
note output
fin.entry
}
FUNCTION {inbook}
{ output.bibitem
author empty$
{ format.editors "author and editor" output.check
editor format.key output
}
{ format.authors output.nonnull
crossref missing$
{ "author and editor" editor either.or.check }
'skip$
if$
}
if$
output.year.check % special for apalike
% new.block % changed for CABIOS no period after year
format.btitle "title" output.check
crossref missing$
{ format.bvolume output
% format.chapter.pages "chapter and pages" output.check
% new.block
format.number.series output
new.sentence
#0 'docomma := % no comma after address
address ":" * output % TDS
publisher "publisher" output.check % TDS
#0 'docomma := % comma back on %changed to keep comma's off for CABIOS
% publisher "publisher" output.check
% address output
}
{ format.chapter.pages "chapter and pages" output.check
new.block
format.book.crossref output.nonnull
}
if$
format.edition output
% new.block %removed period for CABIOS
format.pages output %added for CABIOS
note output
fin.entry
}
FUNCTION {incollection}
{ output.bibitem
format.authors "author" output.check
author format.key output % special for
output.year.check % apalike
% new.block % changed for CABIOS no period after year
format.title "title" output.check
new.block
crossref missing$
{ format.in.ed.booktitle "booktitle" output.check
format.bvolume output
format.number.series output
% format.chapter.pages output %changed for CABIOS
new.sentence
publisher "publisher" output.check
address output
format.edition output
}
{ format.incoll.inproc.crossref output.nonnull
format.chapter.pages output
}
if$
format.pages output %added for CABIOS
% new.block %removed for CABIOS
note output
fin.entry
}
FUNCTION {inproceedings}
{ output.bibitem
format.authors "author" output.check
author format.key output % special for
output.year.check % apalike
% new.block % no period after year in CABIOS
format.title "title" output.check
new.block
crossref missing$
{
% #1 'docomma := % TURN COMMAS ON FOR JMB, BUT NOT FOR JTB: inconsistent. TDS NOW
format.in.ed.booktitle "booktitle" output.check
format.bvolume output
format.number.series output
format.pages
pages empty$
{ output }
% { "," * output } % TDS toss in comma instead of period
{ output }
if$
% address output % TDS address is below for JTB
% new.sentence % TDS remove period
organization output
#0 'docomma := % NO COMMA AFTER ADDRESS
publisher "publisher" output.check % TDS
#1 'docomma := % comma back on
% publisher output % are simpler
address output % TDS
#0 'docomma := % TURN COMMAS OFF
}
{ format.incoll.inproc.crossref output.nonnull
format.pages output
}
if$
new.block
note output
fin.entry
}
FUNCTION {conference} { inproceedings }
FUNCTION {manual}
{ output.bibitem
format.authors output
author format.key output % special for
output.year.check % apalike
% new.block % change for CABIOS don't use period after year
format.btitle "title" output.check
organization address new.block.checkb
organization output
address output
format.edition output
new.block
note output
fin.entry
}
FUNCTION {mastersthesis}
{ output.bibitem
format.authors "author" output.check
author format.key output % special for
output.year.check % apalike
new.block
format.title "title" output.check
new.block
"Master's thesis" format.thesis.type output.nonnull
school "school" output.check
address output
new.block
note output
fin.entry
}
FUNCTION {misc}
{ output.bibitem
format.authors output
author format.key output % special for
output.year.check % apalike
new.block
format.title output
new.block
howpublished output
new.block
note output
fin.entry
}
FUNCTION {phdthesis}
{ output.bibitem
format.authors "author" output.check
author format.key output % special for
output.year.check % apalike
new.block
format.btitle "title" output.check
new.block
"PhD thesis," format.thesis.type output.nonnull
school "school" output.check
address output
new.block
note output
fin.entry
}
FUNCTION {proceedings}
{ output.bibitem
format.editors output
editor format.key output % special for
output.year.check % apalike
new.block
format.btitle "title" output.check
format.bvolume output
format.number.series output
address output % for apalike
new.sentence % we always output
organization output % a nonempty organization
publisher output % here
new.block
note output
fin.entry
}
FUNCTION {techreport}
{ output.bibitem
format.authors "author" output.check
author format.key output % special for
output.year.check % apalike
new.block
format.title "title" output.check
new.block
format.tr.number output.nonnull
institution "institution" output.check
address output
new.block
note output
fin.entry
}
FUNCTION {unpublished}
{ output.bibitem
format.authors "author" output.check
author format.key output % special for
% output.year.check % apalike
new.block
% zzz
format.title "title" output.check
% Since format.title is out of commission, the original method won't work:
% format.title "title" output.check
% so do the equivalent of the format.title procedure: (TDS)
% title empty$
% { "" }
% { title "t" change.case$ } % produce the title
% if$
% "title" output.check
new.block
note "note" output.check
fin.entry