Physics307L F08:People/Smith/styles/apjuc

From OpenWetWare
Revision as of 10:45, 24 August 2009 by Bill Flanagan (talk | contribs) (1 revision)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigationJump to search

% Copyright (C) 1990 Sake J. Hogeveen.

% Corrected by Mike Gross to correspond to ApJ citation style % ALL FILE NAMES HAVE BEEN CHANGED FROM THE ASTRON PACKAGE, except mnemonic.bib, % which is unchanged.

% This is APJ.BST, a BibTeX style for use with BibTeX version 0.99c. % APJ.BST has to be used in conjunction with the LaTeX style APJ.STY. % Both files are slightly hacked versions of the ASTRON package.

% ASTRON.BST is an adaptation of APALIKE.BST by Oren Patashnik and Suzan King.

% This style produces citations in the `author-year' format, which is widely % used among astronomical journals. % It supports two forms of citation: the \cite command produces: (Author, year) % in the text; the \cite* command only: (year) .

% The long an short citation trickery is adapted from NAMED.BST by % Peter F. Patel-Schneider.

% Copyright Notice: % The files ASTRON.BST, ASTRON.STY, ASTDOC.TEX, ASTDOC.BIB, EXAMPLE.TEX, % EXAMPLE.BIB, MNEMONIC.BIB, and TEMPLATE.BIB are a package. % You may copy and distribute them freely for non-commercial purposes, % provided that you keep the package together and this copyright notice % in tact. % You may not alter or modify the files; this helps to ensure that all % distributions of ASTRON.BST and related files are the same. % If you make any modifications, then you must give the files new names, % other than the present. % % -- Previous restriction performed by Mike Gross--name changed to apj.bst. % % The author bears no responsibilities for errors in this document or % the software it describes; and shall not be held liable for any indirect, % incidental, or consequential damages.

ENTRY

 { 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 }

FUNCTION {init.state.consts} { #0 'before.all :=

 #1 'mid.sentence :=
 #2 'after.sentence :=
 #3 'after.block :=

}

STRINGS { s t }

FUNCTION {output.nonnull} { 's :=

 output.state mid.sentence =
   { ", " * write$ }
   { output.state after.block =
       { ", " *  write$
         newline$
         "\newblock " write$
       }
       { output.state before.all =
           'write$
           { ", " * write$ }
         if$
       }
     if$
     mid.sentence 'output.state :=
   }
 if$
 s

}

FUNCTION {output.nonnull.extra} { 's :=

 output.state mid.sentence =

% changed by hk. % { " " * write$ }

   { ", " * write$ }
   { output.state after.block =
       { ", " *  write$
         newline$
         "\newblock " write$
       }
       { output.state before.all =
           'write$
           { ", " * write$ }
         if$
       }
     if$
     mid.sentence 'output.state :=
   }
 if$
 s

}

FUNCTION {output} { duplicate$ empty$

   'pop$
   'output.nonnull
 if$

}

FUNCTION {output.extra} { duplicate$ empty$

   'pop$
   'output.nonnull.extra
 if$

}

FUNCTION {output.check} { 't :=

 duplicate$ empty$
   { pop$ "empty " t * " in " * cite$ * warning$ }
   'output.nonnull
 if$

}

FUNCTION {output.check.extra} { 't :=

 duplicate$ empty$
   { pop$ "empty " t * " in " * cite$ * warning$ }
   'output.nonnull.extra
 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$ * warning$ }
   { write$

% changed by hk. % ": " year * extra.label *

     " " year * extra.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} { 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 {boldface} { duplicate$ empty$

   { pop$ "" }
   { "{\bf " swap$ * "}" * }
 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 > }

% changed by hk. % { s nameptr "{vv~}{ll}{ jj}{ f.}" format.name$ 't :=  % last name first

    { s nameptr "{vv~}{ll}{, jj}{, f.}" format.name$ 't :=   % last name first
     nameptr #1 >
       { namesleft #1 >
           { ", " * t * }
           { numnames #2 >
               { "," * }
               'skip$
             if$
             t "others" =
               { " et~al." * }
               { " \& " * t * }
             if$
           }
         if$
       }
       't
     if$
     nameptr #1 + 'nameptr :=
     namesleft #1 - 'namesleft :=
   }
 while$

}

FUNCTION {format.ed.names} { 's :=

 #1 'nameptr :=
 s num.names$ 'numnames :=
 numnames 'namesleft :=
   { namesleft #0 > }
   { s nameptr "{f. }{vv~}{ll}{, jj}" format.name$ 't :=
     nameptr #1 >
       { namesleft #1 >
           { ", " * t * }
           { numnames #2 >
               { "," * }
               'skip$
             if$
             t "others" =
               { " et~al." * }
               { " \& " * 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.)" * }
       { " (ed.)" * }
     if$
   }
 if$

}

FUNCTION {format.editors.extra} { editor empty$

   { "" }
   { editor format.ed.names
     editor num.names$ #1 >
       { " (eds.)" * }
       { " (ed.)" * }
     if$
   }
 if$

}

FUNCTION {format.title} { title empty$

   { "" }
   { title "t" change.case$ }
 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 {first.page.number} { 't :=

 ""
   { t "" =
       { #0 }
       { t #1 #1 substring$ "-" = not }
     if$
   }
   { t #1 #1 substring$ *
     t #2 global.max$ substring$ 't :=
   }
 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$

   { "" }
   { "Vol." volume tie.or.space.connect
     series empty$
       'skip$
       { " of " * series emphasize * }
     if$
     "volume and number" number either.or.check
   }
 if$

}

FUNCTION {format.number.series} { volume empty$

   { number empty$
       { series field.or.null }
       { output.state mid.sentence =
           { "No." }
           { "No." }
         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" * }
       { edition "t" change.case$ " edition" * }
     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 }
   { "p." pages tie.or.space.connect }
     if$
   }
 if$

}

FUNCTION {format.page} { pages empty$

   { "" }
   { "p.~" pages first.page.number * }
 if$

}

FUNCTION {format.vol.num.pages} { volume field.or.null

 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 }
       { boldface ", " * pages n.dashify * }
     if$
   }
 if$

}

FUNCTION {format.vol.num.page} { volume field.or.null

 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 }
       { boldface ", " * pages first.page.number * }
     if$
   }
 if$

}

FUNCTION {format.chapter.pages} { chapter empty$

   'format.pages
   { type empty$
       { "Chapt." }
       { 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 * }
   { "in " format.editors.extra * ", " * booktitle emphasize * }
     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

 " \cite{" * crossref * "}" *

}

FUNCTION {format.book.crossref} { volume empty$

   { "empty volume in " cite$ * "'s crossref of " * crossref * warning$
     "in "
   }
   { "Vol." volume tie.or.space.connect
     " of " *
   }
 if$
 "\cite{" * crossref * "}" *                           % this is for apalike

}

FUNCTION {format.incoll.inproc.crossref} { "in"  % this is for apalike

 " \cite{" * crossref * "}" *

}

FUNCTION {article} { output.bibitem

 format.authors "author" output.check
 author format.key output                              % special for
 output.year.check                                     % apalike
 new.block
 crossref missing$
   { journal emphasize "journal" output.check.extra
     format.vol.num.page output.extra
   }
   { format.article.crossref output.nonnull
     format.page output
   }
 if$
 new.block
 note output
 fin.entry

}

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
 format.btitle "title" output.check
 crossref missing$
   { format.bvolume output
     new.block
     format.number.series output
     new.sentence
     publisher "publisher" output.check
     address output
   }
   { new.block
     format.book.crossref output.nonnull
   }
 if$
 format.edition output
 new.block
 note output
 fin.entry

}

FUNCTION {booklet} { output.bibitem

 format.authors output
 author format.key output                              % special for
 output.year.check                                     % apalike
 new.block
 format.btitle "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
 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
     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
 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

% 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
     new.sentence
     publisher "publisher" output.check
     address output
     format.edition output
   }
   { format.incoll.inproc.crossref output.nonnull
     format.chapter.pages output
   }
 if$
 new.block
 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

% format.title "title" output.check % new.block

 crossref missing$
   { format.in.ed.booktitle "booktitle" output.check
     format.bvolume output
     format.number.series output
     format.pages output
     new.sentence                                      % there's no year
     organization output                               % here so things
     publisher output                                  % are simpler
     address output                                    % for apalike
   }
   { 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
 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" emphasize 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.btitle 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

 "Ph.D. thesis" emphasize 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.btitle "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
 format.btitle "title" output.check
 new.block
 note "note" output.check
 fin.entry

}

FUNCTION {default.type} { misc }

MACRO {jan} {"Jan."}

MACRO {feb} {"Feb."}

MACRO {mar} {"Mar."}

MACRO {apr} {"Apr,"}

MACRO {may} {"May"}

MACRO {jun} {"June"}

MACRO {jul} {"July"}

MACRO {aug} {"Aug."}

MACRO {sep} {"Sept."}

MACRO {oct} {"Oct."}

MACRO {nov} {"Nov."}

MACRO {dec} {"Dec."}

READ

FUNCTION {sortify} { purify$

 "l" change.case$

}

INTEGERS { len }

FUNCTION {chop.word} { 's :=

 'len :=
 s #1 len substring$ =
   { s len #1 + global.max$ substring$ }
   's
 if$

}

% There are three apalike cases: one person (Jones), % two (Jones \& de~Bruijn), and more (Jones et~al.). % This function is much like format.crossref.editors. % FUNCTION {format.lab.names} { 's :=

 s #1 "{vv~}{ll}" format.name$
 s num.names$ duplicate$
 #2 >
   { pop$ " et~al." * }
   { #2 <
       'skip$
       { s #2 "{ff }{vv }{ll}{ jj}" format.name$ "others" =
           { " et~al." * }
           { " \& " * s #2 "{vv~}{ll}" format.name$ * }
         if$
       }
     if$
   }
 if$

}

FUNCTION {author.key.label} { author empty$

   { key empty$
       { cite$ #1 #3 substring$ }
       'key                                    % apalike uses the whole key
     if$
   }
   { author format.lab.names }
 if$

}

FUNCTION {author.editor.key.label} { author empty$

   { editor empty$
       { key empty$
           { cite$ #1 #3 substring$ }
           'key                                % apalike uses the whole key
         if$
       }
       { editor format.lab.names }
     if$
   }
   { author format.lab.names }
 if$

}

FUNCTION {editor.key.label} { editor empty$

   { key empty$
       { cite$ #1 #3 substring$ }
       'key                    % apalike uses the whole key, no organization
     if$
   }
   { editor format.lab.names }
 if$

}

FUNCTION {calc.label} { type$ "book" =

 type$ "inbook" =
 or
   'author.editor.key.label
   { type$ "proceedings" =
       'editor.key.label                       % apalike ignores organization
       'author.key.label                       % for labeling and sorting
     if$
   }
 if$
 "\protect\astroncite{" swap$ * "}{"                   % these three lines are
 *                                                     % for apalike, which
 year field.or.null purify$ #-1 #4 substring$          % uses all four digits
 *                       % the mathing closing "}" comes in at the reverse.pass
 'label :=

}

FUNCTION {sort.format.names} { 's :=

 #1 'nameptr :=
 ""
 s num.names$ 'numnames :=
 numnames 'namesleft :=
   { namesleft #0 > }
   { nameptr #1 >
       { "   " * }
       'skip$
     if$                                               % apalike uses initials
     s nameptr "{vv{ } }{ll{ }}{  f{ }}{  jj{ }}" format.name$ 't := % <= here
     nameptr numnames = t "others" = and
       { "et al" * }
       { t sortify * }
     if$
     nameptr #1 + 'nameptr :=
     namesleft #1 - 'namesleft :=
   }
 while$

}

FUNCTION {sort.format.title} { 't :=

 "A " #2
   "An " #3
     "The " #4 t chop.word
   chop.word
 chop.word
 sortify
 #1 global.max$ substring$

}

FUNCTION {author.sort} { author empty$

   { key empty$
       { "to sort, need author or key in " cite$ * warning$
         ""
       }
       { key sortify }
     if$
   }
   { author sort.format.names }
 if$

}

FUNCTION {author.editor.sort} { author empty$

   { editor empty$
       { key empty$
           { "to sort, need author, editor, or key in " cite$ * warning$
             ""
           }
           { key sortify }
         if$
       }
       { editor sort.format.names }
     if$
   }
   { author sort.format.names }
 if$

}

FUNCTION {editor.sort} { editor empty$

   { key empty$
       { "to sort, need editor or key in " cite$ * warning$
         ""
       }
       { key sortify }
     if$
   }
   { editor sort.format.names }
 if$

}

% apalike uses two sorting passes; the first one sets the % labels so that the `a's, `b's, etc. can be computed; % the second pass puts the references in "correct" order. % The presort function is for the first pass. It computes % label, sort.label, and title, and then concatenates. FUNCTION {presort} { calc.label

 label sortify
 "    "
 *
 type$ "book" =
 type$ "inbook" =
 or
   'author.editor.sort
   { type$ "proceedings" =
       'editor.sort
       'author.sort
     if$
   }
 if$
 #1 entry.max$ substring$      % for
 'sort.label :=                % apalike
 sort.label                    % style
 *
 "    "
 *
 title field.or.null
 sort.format.title
 *
 #1 entry.max$ substring$
 'sort.key$ :=

}

ITERATE {presort}

SORT  % by label, sort.label, title---for final label calculation

STRINGS { last.label next.extra }  % apalike labels are only for the text;

INTEGERS { last.extra.num }  % there are none in the bibliography

FUNCTION {initialize.extra.label.stuff} % and hence there is no `longest.label' { #0 int.to.chr$ 'last.label :=

 "" 'next.extra :=
 #0 'last.extra.num :=

}

FUNCTION {forward.pass} { last.label label =

   { last.extra.num #1 + 'last.extra.num :=
     last.extra.num int.to.chr$ 'extra.label :=
   }
   { "a" chr.to.int$ 'last.extra.num :=
     "" 'extra.label :=
     label 'last.label :=
   }
 if$

}

FUNCTION {reverse.pass} { next.extra "b" =

   { "a" 'extra.label := }
   'skip$
 if$
 label extra.label * "}" * 'label :=
 extra.label 'next.extra :=

}

EXECUTE {initialize.extra.label.stuff}

ITERATE {forward.pass}

REVERSE {reverse.pass}

% Now that the label is right we sort for real, % on sort.label then year then title. This is % for the second sorting pass. FUNCTION {bib.sort.order} { sort.label

 "    "
 *
 year field.or.null sortify
 *
 "    "
 *
 title field.or.null
 sort.format.title
 *
 #1 entry.max$ substring$
 'sort.key$ :=

}

ITERATE {bib.sort.order}

SORT  % by sort.label, year, title---giving final bibliography order

FUNCTION {begin.bib} { preamble$ empty$  % no \etalchar in apalike

   'skip$
   { preamble$ write$ newline$ }
 if$
 "\begin{thebibliography}{}" write$ newline$           % no labels in apalike

}

EXECUTE {begin.bib}

EXECUTE {init.state.consts}

ITERATE {call.type$}

FUNCTION {end.bib} { newline$

 "\end{thebibliography}" write$ newline$

}

EXECUTE {end.bib}