12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976 |
- %%% acl_natbib.bst
- %%% Modification of BibTeX style file acl_natbib_nourl.bst
- %%% ... by urlbst, version 0.7 (marked with "% urlbst")
- %%% See <http://purl.org/nxg/dist/urlbst>
- %%% Added webpage entry type, and url and lastchecked fields.
- %%% Added eprint support.
- %%% Added DOI support.
- %%% Added PUBMED support.
- %%% Added hyperref support.
- %%% Original headers follow...
- %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- %
- % BibTeX style file acl_natbib_nourl.bst
- %
- % intended as input to urlbst script
- % $ ./urlbst --hyperref --inlinelinks acl_natbib_nourl.bst > acl_natbib.bst
- %
- % adapted from compling.bst
- % in order to mimic the style files for ACL conferences prior to 2017
- % by making the following three changes:
- % - for @incollection, page numbers now follow volume title.
- % - for @inproceedings, address now follows conference name.
- % (address is intended as location of conference,
- % not address of publisher.)
- % - for papers with three authors, use et al. in citation
- % Dan Gildea 2017/06/08
- % - fixed a bug with format.chapter - error given if chapter is empty
- % with inbook.
- % Shay Cohen 2018/02/16
- %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- %
- % BibTeX style file compling.bst
- %
- % Intended for the journal Computational Linguistics (ACL/MIT Press)
- % Created by Ron Artstein on 2005/08/22
- % For use with <natbib.sty> for author-year citations.
- %
- % I created this file in order to allow submissions to the journal
- % Computational Linguistics using the <natbib> package for author-year
- % citations, which offers a lot more flexibility than <fullname>, CL's
- % official citation package. This file adheres strictly to the official
- % style guide available from the MIT Press:
- %
- % http://mitpress.mit.edu/journals/coli/compling_style.pdf
- %
- % This includes all the various quirks of the style guide, for example:
- % - a chapter from a monograph (@inbook) has no page numbers.
- % - an article from an edited volume (@incollection) has page numbers
- % after the publisher and address.
- % - an article from a proceedings volume (@inproceedings) has page
- % numbers before the publisher and address.
- %
- % Where the style guide was inconsistent or not specific enough I
- % looked at actual published articles and exercised my own judgment.
- % I noticed two inconsistencies in the style guide:
- %
- % - The style guide gives one example of an article from an edited
- % volume with the editor's name spelled out in full, and another
- % with the editors' names abbreviated. I chose to accept the first
- % one as correct, since the style guide generally shuns abbreviations,
- % and editors' names are also spelled out in some recently published
- % articles.
- %
- % - The style guide gives one example of a reference where the word
- % "and" between two authors is preceded by a comma. This is most
- % likely a typo, since in all other cases with just two authors or
- % editors there is no comma before the word "and".
- %
- % One case where the style guide is not being specific is the placement
- % of the edition number, for which no example is given. I chose to put
- % it immediately after the title, which I (subjectively) find natural,
- % and is also the place of the edition in a few recently published
- % articles.
- %
- % This file correctly reproduces all of the examples in the official
- % style guide, except for the two inconsistencies noted above. I even
- % managed to get it to correctly format the proceedings example which
- % has an organization, a publisher, and two addresses (the conference
- % location and the publisher's address), though I cheated a bit by
- % putting the conference location and month as part of the title field;
- % I feel that in this case the conference location and month can be
- % considered as part of the title, and that adding a location field
- % is not justified. Note also that a location field is not standard,
- % so entries made with this field would not port nicely to other styles.
- % However, if authors feel that there's a need for a location field
- % then tell me and I'll see what I can do.
- %
- % The file also produces to my satisfaction all the bibliographical
- % entries in my recent (joint) submission to CL (this was the original
- % motivation for creating the file). I also tested it by running it
- % on a larger set of entries and eyeballing the results. There may of
- % course still be errors, especially with combinations of fields that
- % are not that common, or with cross-references (which I seldom use).
- % If you find such errors please write to me.
- %
- % I hope people find this file useful. Please email me with comments
- % and suggestions.
- %
- % Ron Artstein
- % artstein [at] essex.ac.uk
- % August 22, 2005.
- %
- % Some technical notes.
- %
- % This file is based on a file generated with the package <custom-bib>
- % by Patrick W. Daly (see selected options below), which was then
- % manually customized to conform with certain CL requirements which
- % cannot be met by <custom-bib>. Departures from the generated file
- % include:
- %
- % Function inbook: moved publisher and address to the end; moved
- % edition after title; replaced function format.chapter.pages by
- % new function format.chapter to output chapter without pages.
- %
- % Function inproceedings: moved publisher and address to the end;
- % replaced function format.in.ed.booktitle by new function
- % format.in.booktitle to output the proceedings title without
- % the editor.
- %
- % Functions book, incollection, manual: moved edition after title.
- %
- % Function mastersthesis: formatted title as for articles (unlike
- % phdthesis which is formatted as book) and added month.
- %
- % Function proceedings: added new.sentence between organization and
- % publisher when both are present.
- %
- % Function format.lab.names: modified so that it gives all the
- % authors' surnames for in-text citations for one, two and three
- % authors and only uses "et. al" for works with four authors or more
- % (thanks to Ken Shan for convincing me to go through the trouble of
- % modifying this function rather than using unreliable hacks).
- %
- % Changes:
- %
- % 2006-10-27: Changed function reverse.pass so that the extra label is
- % enclosed in parentheses when the year field ends in an uppercase or
- % lowercase letter (change modeled after Uli Sauerland's modification
- % of nals.bst). RA.
- %
- %
- % The preamble of the generated file begins below:
- %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- %%
- %% This is file `compling.bst',
- %% generated with the docstrip utility.
- %%
- %% The original source files were:
- %%
- %% merlin.mbs (with options: `ay,nat,vonx,nm-revv1,jnrlst,keyxyr,blkyear,dt-beg,yr-per,note-yr,num-xser,pre-pub,xedn,nfss')
- %% ----------------------------------------
- %% *** Intended for the journal Computational Linguistics ***
- %%
- %% Copyright 1994-2002 Patrick W Daly
- % ===============================================================
- % IMPORTANT NOTICE:
- % This bibliographic style (bst) file has been generated from one or
- % more master bibliographic style (mbs) files, listed above.
- %
- % This generated file can be redistributed and/or modified under the terms
- % of the LaTeX Project Public License Distributed from CTAN
- % archives in directory macros/latex/base/lppl.txt; either
- % version 1 of the License, or any later version.
- % ===============================================================
- % Name and version information of the main mbs file:
- % \ProvidesFile{merlin.mbs}[2002/10/21 4.05 (PWD, AO, DPC)]
- % For use with BibTeX version 0.99a or later
- %-------------------------------------------------------------------
- % This bibliography style file is intended for texts in ENGLISH
- % This is an author-year citation style bibliography. As such, it is
- % non-standard LaTeX, and requires a special package file to function properly.
- % Such a package is natbib.sty by Patrick W. Daly
- % The form of the \bibitem entries is
- % \bibitem[Jones et al.(1990)]{key}...
- % \bibitem[Jones et al.(1990)Jones, Baker, and Smith]{key}...
- % The essential feature is that the label (the part in brackets) consists
- % of the author names, as they should appear in the citation, with the year
- % in parentheses following. There must be no space before the opening
- % parenthesis!
- % With natbib v5.3, a full list of authors may also follow the year.
- % In natbib.sty, it is possible to define the type of enclosures that is
- % really wanted (brackets or parentheses), but in either case, there must
- % be parentheses in the label.
- % The \cite command functions as follows:
- % \citet{key} ==>> Jones et al. (1990)
- % \citet*{key} ==>> Jones, Baker, and Smith (1990)
- % \citep{key} ==>> (Jones et al., 1990)
- % \citep*{key} ==>> (Jones, Baker, and Smith, 1990)
- % \citep[chap. 2]{key} ==>> (Jones et al., 1990, chap. 2)
- % \citep[e.g.][]{key} ==>> (e.g. Jones et al., 1990)
- % \citep[e.g.][p. 32]{key} ==>> (e.g. Jones et al., p. 32)
- % \citeauthor{key} ==>> Jones et al.
- % \citeauthor*{key} ==>> Jones, Baker, and Smith
- % \citeyear{key} ==>> 1990
- %---------------------------------------------------------------------
- ENTRY
- { address
- author
- booktitle
- chapter
- edition
- editor
- howpublished
- institution
- journal
- key
- month
- note
- number
- organization
- pages
- publisher
- school
- series
- title
- type
- volume
- year
- eprint % urlbst
- doi % urlbst
- pubmed % urlbst
- url % urlbst
- lastchecked % urlbst
- }
- {}
- { label extra.label sort.label short.list }
- INTEGERS { output.state before.all mid.sentence after.sentence after.block }
- % urlbst...
- % urlbst constants and state variables
- STRINGS { urlintro
- eprinturl eprintprefix doiprefix doiurl pubmedprefix pubmedurl
- citedstring onlinestring linktextstring
- openinlinelink closeinlinelink }
- INTEGERS { hrefform inlinelinks makeinlinelink
- addeprints adddoiresolver addpubmedresolver }
- FUNCTION {init.urlbst.variables}
- {
- % The following constants may be adjusted by hand, if desired
- % The first set allow you to enable or disable certain functionality.
- #1 'addeprints := % 0=no eprints; 1=include eprints
- #1 'adddoiresolver := % 0=no DOI resolver; 1=include it
- #1 'addpubmedresolver := % 0=no PUBMED resolver; 1=include it
- #2 'hrefform := % 0=no crossrefs; 1=hypertex xrefs; 2=hyperref refs
- #1 'inlinelinks := % 0=URLs explicit; 1=URLs attached to titles
- % String constants, which you _might_ want to tweak.
- "URL: " 'urlintro := % prefix before URL; typically "Available from:" or "URL":
- "online" 'onlinestring := % indication that resource is online; typically "online"
- "cited " 'citedstring := % indicator of citation date; typically "cited "
- "[link]" 'linktextstring := % dummy link text; typically "[link]"
- "http://arxiv.org/abs/" 'eprinturl := % prefix to make URL from eprint ref
- "arXiv:" 'eprintprefix := % text prefix printed before eprint ref; typically "arXiv:"
- "https://doi.org/" 'doiurl := % prefix to make URL from DOI
- "doi:" 'doiprefix := % text prefix printed before DOI ref; typically "doi:"
- "http://www.ncbi.nlm.nih.gov/pubmed/" 'pubmedurl := % prefix to make URL from PUBMED
- "PMID:" 'pubmedprefix := % text prefix printed before PUBMED ref; typically "PMID:"
- % The following are internal state variables, not configuration constants,
- % so they shouldn't be fiddled with.
- #0 'makeinlinelink := % state variable managed by possibly.setup.inlinelink
- "" 'openinlinelink := % ditto
- "" 'closeinlinelink := % ditto
- }
- INTEGERS {
- bracket.state
- outside.brackets
- open.brackets
- within.brackets
- close.brackets
- }
- % ...urlbst to here
- FUNCTION {init.state.consts}
- { #0 'outside.brackets := % urlbst...
- #1 'open.brackets :=
- #2 'within.brackets :=
- #3 'close.brackets := % ...urlbst to here
- #0 'before.all :=
- #1 'mid.sentence :=
- #2 'after.sentence :=
- #3 'after.block :=
- }
- STRINGS { s t}
- % urlbst
- FUNCTION {output.nonnull.original}
- { 's :=
- output.state mid.sentence =
- { ", " * write$ }
- { 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
- }
- % urlbst...
- % The following three functions are for handling inlinelink. They wrap
- % a block of text which is potentially output with write$ by multiple
- % other functions, so we don't know the content a priori.
- % They communicate between each other using the variables makeinlinelink
- % (which is true if a link should be made), and closeinlinelink (which holds
- % the string which should close any current link. They can be called
- % at any time, but start.inlinelink will be a no-op unless something has
- % previously set makeinlinelink true, and the two ...end.inlinelink functions
- % will only do their stuff if start.inlinelink has previously set
- % closeinlinelink to be non-empty.
- % (thanks to 'ijvm' for suggested code here)
- FUNCTION {uand}
- { 'skip$ { pop$ #0 } if$ } % 'and' (which isn't defined at this point in the file)
- FUNCTION {possibly.setup.inlinelink}
- { makeinlinelink hrefform #0 > uand
- { doi empty$ adddoiresolver uand
- { pubmed empty$ addpubmedresolver uand
- { eprint empty$ addeprints uand
- { url empty$
- { "" }
- { url }
- if$ }
- { eprinturl eprint * }
- if$ }
- { pubmedurl pubmed * }
- if$ }
- { doiurl doi * }
- if$
- % an appropriately-formatted URL is now on the stack
- hrefform #1 = % hypertex
- { "\special {html:<a href=" quote$ * swap$ * quote$ * "> }{" * 'openinlinelink :=
- "\special {html:</a>}" 'closeinlinelink := }
- { "\href {" swap$ * "} {" * 'openinlinelink := % hrefform=#2 -- hyperref
- % the space between "} {" matters: a URL of just the right length can cause "\% newline em"
- "}" 'closeinlinelink := }
- if$
- #0 'makeinlinelink :=
- }
- 'skip$
- if$ % makeinlinelink
- }
- FUNCTION {add.inlinelink}
- { openinlinelink empty$
- 'skip$
- { openinlinelink swap$ * closeinlinelink *
- "" 'openinlinelink :=
- }
- if$
- }
- FUNCTION {output.nonnull}
- { % Save the thing we've been asked to output
- 's :=
- % If the bracket-state is close.brackets, then add a close-bracket to
- % what is currently at the top of the stack, and set bracket.state
- % to outside.brackets
- bracket.state close.brackets =
- { "]" *
- outside.brackets 'bracket.state :=
- }
- 'skip$
- if$
- bracket.state outside.brackets =
- { % We're outside all brackets -- this is the normal situation.
- % Write out what's currently at the top of the stack, using the
- % original output.nonnull function.
- s
- add.inlinelink
- output.nonnull.original % invoke the original output.nonnull
- }
- { % Still in brackets. Add open-bracket or (continuation) comma, add the
- % new text (in s) to the top of the stack, and move to the close-brackets
- % state, ready for next time (unless inbrackets resets it). If we come
- % into this branch, then output.state is carefully undisturbed.
- bracket.state open.brackets =
- { " [" * }
- { ", " * } % bracket.state will be within.brackets
- if$
- s *
- close.brackets 'bracket.state :=
- }
- if$
- }
- % Call this function just before adding something which should be presented in
- % brackets. bracket.state is handled specially within output.nonnull.
- FUNCTION {inbrackets}
- { bracket.state close.brackets =
- { within.brackets 'bracket.state := } % reset the state: not open nor closed
- { open.brackets 'bracket.state := }
- if$
- }
- FUNCTION {format.lastchecked}
- { lastchecked empty$
- { "" }
- { inbrackets citedstring lastchecked * }
- if$
- }
- % ...urlbst to here
- FUNCTION {output}
- { duplicate$ empty$
- 'pop$
- 'output.nonnull
- if$
- }
- FUNCTION {output.check}
- { 't :=
- duplicate$ empty$
- { pop$ "empty " t * " in " * cite$ * warning$ }
- 'output.nonnull
- if$
- }
- FUNCTION {fin.entry.original} % urlbst (renamed from fin.entry, so it can be wrapped below)
- { 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 {add.blank}
- { " " * before.all 'output.state :=
- }
- FUNCTION {date.block}
- {
- new.block
- }
- 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$ "" }
- { "\emph{" swap$ * "}" * }
- if$
- }
- FUNCTION {tie.or.space.prefix}
- { duplicate$ text.length$ #3 <
- { "~" }
- { " " }
- if$
- swap$
- }
- FUNCTION {capitalize}
- { "u" change.case$ "t" change.case$ }
- FUNCTION {space.word}
- { " " swap$ * " " * }
- % Here are the language-specific definitions for explicit words.
- % Each function has a name bbl.xxx where xxx is the English word.
- % The language selected here is ENGLISH
- FUNCTION {bbl.and}
- { "and"}
- FUNCTION {bbl.etal}
- { "et~al." }
- FUNCTION {bbl.editors}
- { "editors" }
- FUNCTION {bbl.editor}
- { "editor" }
- FUNCTION {bbl.edby}
- { "edited by" }
- FUNCTION {bbl.edition}
- { "edition" }
- FUNCTION {bbl.volume}
- { "volume" }
- FUNCTION {bbl.of}
- { "of" }
- FUNCTION {bbl.number}
- { "number" }
- FUNCTION {bbl.nr}
- { "no." }
- FUNCTION {bbl.in}
- { "in" }
- FUNCTION {bbl.pages}
- { "pages" }
- FUNCTION {bbl.page}
- { "page" }
- FUNCTION {bbl.chapter}
- { "chapter" }
- FUNCTION {bbl.techrep}
- { "Technical Report" }
- FUNCTION {bbl.mthesis}
- { "Master's thesis" }
- FUNCTION {bbl.phdthesis}
- { "Ph.D. thesis" }
- MACRO {jan} {"January"}
- MACRO {feb} {"February"}
- MACRO {mar} {"March"}
- MACRO {apr} {"April"}
- MACRO {may} {"May"}
- MACRO {jun} {"June"}
- MACRO {jul} {"July"}
- MACRO {aug} {"August"}
- MACRO {sep} {"September"}
- MACRO {oct} {"October"}
- MACRO {nov} {"November"}
- MACRO {dec} {"December"}
- MACRO {acmcs} {"ACM Computing Surveys"}
- MACRO {acta} {"Acta Informatica"}
- MACRO {cacm} {"Communications of the ACM"}
- MACRO {ibmjrd} {"IBM Journal of Research and Development"}
- MACRO {ibmsj} {"IBM Systems Journal"}
- MACRO {ieeese} {"IEEE Transactions on Software Engineering"}
- MACRO {ieeetc} {"IEEE Transactions on Computers"}
- MACRO {ieeetcad}
- {"IEEE Transactions on Computer-Aided Design of Integrated Circuits"}
- MACRO {ipl} {"Information Processing Letters"}
- MACRO {jacm} {"Journal of the ACM"}
- MACRO {jcss} {"Journal of Computer and System Sciences"}
- MACRO {scp} {"Science of Computer Programming"}
- MACRO {sicomp} {"SIAM Journal on Computing"}
- MACRO {tocs} {"ACM Transactions on Computer Systems"}
- MACRO {tods} {"ACM Transactions on Database Systems"}
- MACRO {tog} {"ACM Transactions on Graphics"}
- MACRO {toms} {"ACM Transactions on Mathematical Software"}
- MACRO {toois} {"ACM Transactions on Office Information Systems"}
- MACRO {toplas} {"ACM Transactions on Programming Languages and Systems"}
- MACRO {tcs} {"Theoretical Computer Science"}
- FUNCTION {bibinfo.check}
- { swap$
- duplicate$ missing$
- {
- pop$ pop$
- ""
- }
- { duplicate$ empty$
- {
- swap$ pop$
- }
- { swap$
- pop$
- }
- if$
- }
- if$
- }
- FUNCTION {bibinfo.warn}
- { swap$
- duplicate$ missing$
- {
- swap$ "missing " swap$ * " in " * cite$ * warning$ pop$
- ""
- }
- { duplicate$ empty$
- {
- swap$ "empty " swap$ * " in " * cite$ * warning$
- }
- { swap$
- pop$
- }
- if$
- }
- if$
- }
- STRINGS { bibinfo}
- INTEGERS { nameptr namesleft numnames }
- FUNCTION {format.names}
- { 'bibinfo :=
- duplicate$ empty$ 'skip$ {
- 's :=
- "" 't :=
- #1 'nameptr :=
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr
- duplicate$ #1 >
- { "{ff~}{vv~}{ll}{, jj}" }
- { "{ff~}{vv~}{ll}{, jj}" } % first name first for first author
- % { "{vv~}{ll}{, ff}{, jj}" } % last name first for first author
- if$
- format.name$
- bibinfo bibinfo.check
- 't :=
- nameptr #1 >
- {
- namesleft #1 >
- { ", " * t * }
- {
- numnames #2 >
- { "," * }
- 'skip$
- if$
- s nameptr "{ll}" format.name$ duplicate$ "others" =
- { 't := }
- { pop$ }
- if$
- t "others" =
- {
- " " * bbl.etal *
- }
- {
- bbl.and
- space.word * t *
- }
- if$
- }
- if$
- }
- 't
- if$
- nameptr #1 + 'nameptr :=
- namesleft #1 - 'namesleft :=
- }
- while$
- } if$
- }
- FUNCTION {format.names.ed}
- {
- 'bibinfo :=
- duplicate$ empty$ 'skip$ {
- 's :=
- "" 't :=
- #1 'nameptr :=
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr
- "{ff~}{vv~}{ll}{, jj}"
- format.name$
- bibinfo bibinfo.check
- 't :=
- nameptr #1 >
- {
- namesleft #1 >
- { ", " * t * }
- {
- numnames #2 >
- { "," * }
- 'skip$
- if$
- s nameptr "{ll}" format.name$ duplicate$ "others" =
- { 't := }
- { pop$ }
- if$
- t "others" =
- {
- " " * bbl.etal *
- }
- {
- bbl.and
- space.word * t *
- }
- if$
- }
- if$
- }
- 't
- if$
- nameptr #1 + 'nameptr :=
- namesleft #1 - 'namesleft :=
- }
- while$
- } if$
- }
- FUNCTION {format.key}
- { empty$
- { key field.or.null }
- { "" }
- if$
- }
- FUNCTION {format.authors}
- { author "author" format.names
- }
- FUNCTION {get.bbl.editor}
- { editor num.names$ #1 > 'bbl.editors 'bbl.editor if$ }
- FUNCTION {format.editors}
- { editor "editor" format.names duplicate$ empty$ 'skip$
- {
- "," *
- " " *
- get.bbl.editor
- *
- }
- if$
- }
- FUNCTION {format.note}
- {
- note empty$
- { "" }
- { note #1 #1 substring$
- duplicate$ "{" =
- 'skip$
- { output.state mid.sentence =
- { "l" }
- { "u" }
- if$
- change.case$
- }
- if$
- note #2 global.max$ substring$ * "note" bibinfo.check
- }
- if$
- }
- FUNCTION {format.title}
- { title
- duplicate$ empty$ 'skip$
- { "t" change.case$ }
- if$
- "title" bibinfo.check
- }
- FUNCTION {format.full.names}
- {'s :=
- "" 't :=
- #1 'nameptr :=
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr
- "{vv~}{ll}" format.name$
- 't :=
- nameptr #1 >
- {
- namesleft #1 >
- { ", " * t * }
- {
- s nameptr "{ll}" format.name$ duplicate$ "others" =
- { 't := }
- { pop$ }
- if$
- t "others" =
- {
- " " * bbl.etal *
- }
- {
- numnames #2 >
- { "," * }
- 'skip$
- if$
- bbl.and
- space.word * t *
- }
- if$
- }
- if$
- }
- 't
- if$
- nameptr #1 + 'nameptr :=
- namesleft #1 - 'namesleft :=
- }
- while$
- }
- FUNCTION {author.editor.key.full}
- { author empty$
- { editor empty$
- { key empty$
- { cite$ #1 #3 substring$ }
- 'key
- if$
- }
- { editor format.full.names }
- if$
- }
- { author format.full.names }
- if$
- }
- FUNCTION {author.key.full}
- { author empty$
- { key empty$
- { cite$ #1 #3 substring$ }
- 'key
- if$
- }
- { author format.full.names }
- if$
- }
- FUNCTION {editor.key.full}
- { editor empty$
- { key empty$
- { cite$ #1 #3 substring$ }
- 'key
- if$
- }
- { editor format.full.names }
- if$
- }
- FUNCTION {make.full.names}
- { type$ "book" =
- type$ "inbook" =
- or
- 'author.editor.key.full
- { type$ "proceedings" =
- 'editor.key.full
- 'author.key.full
- if$
- }
- if$
- }
- FUNCTION {output.bibitem.original} % urlbst (renamed from output.bibitem, so it can be wrapped below)
- { newline$
- "\bibitem[{" write$
- label write$
- ")" make.full.names duplicate$ short.list =
- { pop$ }
- { * }
- if$
- "}]{" * write$
- cite$ write$
- "}" write$
- newline$
- ""
- before.all 'output.state :=
- }
- 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 {word.in}
- { bbl.in capitalize
- " " * }
- FUNCTION {format.date}
- { year "year" bibinfo.check duplicate$ empty$
- {
- }
- 'skip$
- if$
- extra.label *
- before.all 'output.state :=
- after.sentence 'output.state :=
- }
- FUNCTION {format.btitle}
- { title "title" bibinfo.check
- duplicate$ empty$ 'skip$
- {
- emphasize
- }
- if$
- }
- FUNCTION {either.or.check}
- { empty$
- 'pop$
- { "can't use both " swap$ * " fields in " * cite$ * warning$ }
- if$
- }
- FUNCTION {format.bvolume}
- { volume empty$
- { "" }
- { bbl.volume volume tie.or.space.prefix
- "volume" bibinfo.check * *
- series "series" bibinfo.check
- duplicate$ empty$ 'pop$
- { swap$ bbl.of space.word * swap$
- emphasize * }
- if$
- "volume and number" number either.or.check
- }
- if$
- }
- FUNCTION {format.number.series}
- { volume empty$
- { number empty$
- { series field.or.null }
- { series empty$
- { number "number" bibinfo.check }
- { output.state mid.sentence =
- { bbl.number }
- { bbl.number capitalize }
- if$
- number tie.or.space.prefix "number" bibinfo.check * *
- bbl.in space.word *
- series "series" bibinfo.check *
- }
- if$
- }
- if$
- }
- { "" }
- if$
- }
- FUNCTION {format.edition}
- { edition duplicate$ empty$ 'skip$
- {
- output.state mid.sentence =
- { "l" }
- { "t" }
- if$ change.case$
- "edition" bibinfo.check
- " " * bbl.edition *
- }
- 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 duplicate$ empty$ 'skip$
- { duplicate$ multi.page.check
- {
- bbl.pages swap$
- n.dashify
- }
- {
- bbl.page swap$
- }
- if$
- tie.or.space.prefix
- "pages" bibinfo.check
- * *
- }
- if$
- }
- FUNCTION {format.journal.pages}
- { pages duplicate$ empty$ 'pop$
- { swap$ duplicate$ empty$
- { pop$ pop$ format.pages }
- {
- ":" *
- swap$
- n.dashify
- "pages" bibinfo.check
- *
- }
- if$
- }
- if$
- }
- FUNCTION {format.vol.num.pages}
- { volume field.or.null
- duplicate$ empty$ 'skip$
- {
- "volume" bibinfo.check
- }
- if$
- number "number" bibinfo.check duplicate$ empty$ 'skip$
- {
- swap$ duplicate$ empty$
- { "there's a number but no volume in " cite$ * warning$ }
- 'skip$
- if$
- swap$
- "(" swap$ * ")" *
- }
- if$ *
- format.journal.pages
- }
- FUNCTION {format.chapter}
- { chapter empty$
- 'format.pages
- { type empty$
- { bbl.chapter }
- { type "l" change.case$
- "type" bibinfo.check
- }
- if$
- chapter tie.or.space.prefix
- "chapter" bibinfo.check
- * *
- }
- if$
- }
- FUNCTION {format.chapter.pages}
- { chapter empty$
- 'format.pages
- { type empty$
- { bbl.chapter }
- { type "l" change.case$
- "type" bibinfo.check
- }
- if$
- chapter tie.or.space.prefix
- "chapter" bibinfo.check
- * *
- pages empty$
- 'skip$
- { ", " * format.pages * }
- if$
- }
- if$
- }
- FUNCTION {format.booktitle}
- {
- booktitle "booktitle" bibinfo.check
- emphasize
- }
- FUNCTION {format.in.booktitle}
- { format.booktitle duplicate$ empty$ 'skip$
- {
- word.in swap$ *
- }
- if$
- }
- FUNCTION {format.in.ed.booktitle}
- { format.booktitle duplicate$ empty$ 'skip$
- {
- editor "editor" format.names.ed duplicate$ empty$ 'pop$
- {
- "," *
- " " *
- get.bbl.editor
- ", " *
- * swap$
- * }
- if$
- word.in swap$ *
- }
- if$
- }
- FUNCTION {format.thesis.type}
- { type duplicate$ empty$
- 'pop$
- { swap$ pop$
- "t" change.case$ "type" bibinfo.check
- }
- if$
- }
- FUNCTION {format.tr.number}
- { number "number" bibinfo.check
- type duplicate$ empty$
- { pop$ bbl.techrep }
- 'skip$
- if$
- "type" bibinfo.check
- swap$ duplicate$ empty$
- { pop$ "t" change.case$ }
- { tie.or.space.prefix * * }
- if$
- }
- FUNCTION {format.article.crossref}
- {
- word.in
- " \cite{" * crossref * "}" *
- }
- FUNCTION {format.book.crossref}
- { volume duplicate$ empty$
- { "empty volume in " cite$ * "'s crossref of " * crossref * warning$
- pop$ word.in
- }
- { bbl.volume
- capitalize
- swap$ tie.or.space.prefix "volume" bibinfo.check * * bbl.of space.word *
- }
- if$
- " \cite{" * crossref * "}" *
- }
- FUNCTION {format.incoll.inproc.crossref}
- {
- word.in
- " \cite{" * crossref * "}" *
- }
- FUNCTION {format.org.or.pub}
- { 't :=
- ""
- address empty$ t empty$ and
- 'skip$
- {
- t empty$
- { address "address" bibinfo.check *
- }
- { t *
- address empty$
- 'skip$
- { ", " * address "address" bibinfo.check * }
- if$
- }
- if$
- }
- if$
- }
- FUNCTION {format.publisher.address}
- { publisher "publisher" bibinfo.warn format.org.or.pub
- }
- FUNCTION {format.organization.address}
- { organization "organization" bibinfo.check format.org.or.pub
- }
- % urlbst...
- % Functions for making hypertext links.
- % In all cases, the stack has (link-text href-url)
- %
- % make 'null' specials
- FUNCTION {make.href.null}
- {
- pop$
- }
- % make hypertex specials
- FUNCTION {make.href.hypertex}
- {
- "\special {html:<a href=" quote$ *
- swap$ * quote$ * "> }" * swap$ *
- "\special {html:</a>}" *
- }
- % make hyperref specials
- FUNCTION {make.href.hyperref}
- {
- "\href {" swap$ * "} {\path{" * swap$ * "}}" *
- }
- FUNCTION {make.href}
- { hrefform #2 =
- 'make.href.hyperref % hrefform = 2
- { hrefform #1 =
- 'make.href.hypertex % hrefform = 1
- 'make.href.null % hrefform = 0 (or anything else)
- if$
- }
- if$
- }
- % If inlinelinks is true, then format.url should be a no-op, since it's
- % (a) redundant, and (b) could end up as a link-within-a-link.
- FUNCTION {format.url}
- { inlinelinks #1 = url empty$ or
- { "" }
- { hrefform #1 =
- { % special case -- add HyperTeX specials
- urlintro "\url{" url * "}" * url make.href.hypertex * }
- { urlintro "\url{" * url * "}" * }
- if$
- }
- if$
- }
- FUNCTION {format.eprint}
- { eprint empty$
- { "" }
- { eprintprefix eprint * eprinturl eprint * make.href }
- if$
- }
- FUNCTION {format.doi}
- { doi empty$
- { "" }
- { doiprefix doi * doiurl doi * make.href }
- if$
- }
- FUNCTION {format.pubmed}
- { pubmed empty$
- { "" }
- { pubmedprefix pubmed * pubmedurl pubmed * make.href }
- if$
- }
- % Output a URL. We can't use the more normal idiom (something like
- % `format.url output'), because the `inbrackets' within
- % format.lastchecked applies to everything between calls to `output',
- % so that `format.url format.lastchecked * output' ends up with both
- % the URL and the lastchecked in brackets.
- FUNCTION {output.url}
- { url empty$
- 'skip$
- { new.block
- format.url output
- format.lastchecked output
- }
- if$
- }
- FUNCTION {output.web.refs}
- {
- new.block
- inlinelinks
- 'skip$ % links were inline -- don't repeat them
- {
- output.url
- addeprints eprint empty$ not and
- { format.eprint output.nonnull }
- 'skip$
- if$
- adddoiresolver doi empty$ not and
- { format.doi output.nonnull }
- 'skip$
- if$
- addpubmedresolver pubmed empty$ not and
- { format.pubmed output.nonnull }
- 'skip$
- if$
- }
- if$
- }
- % Wrapper for output.bibitem.original.
- % If the URL field is not empty, set makeinlinelink to be true,
- % so that an inline link will be started at the next opportunity
- FUNCTION {output.bibitem}
- { outside.brackets 'bracket.state :=
- output.bibitem.original
- inlinelinks url empty$ not doi empty$ not or pubmed empty$ not or eprint empty$ not or and
- { #1 'makeinlinelink := }
- { #0 'makeinlinelink := }
- if$
- }
- % Wrapper for fin.entry.original
- FUNCTION {fin.entry}
- { output.web.refs % urlbst
- makeinlinelink % ooops, it appears we didn't have a title for inlinelink
- { possibly.setup.inlinelink % add some artificial link text here, as a fallback
- linktextstring output.nonnull }
- 'skip$
- if$
- bracket.state close.brackets = % urlbst
- { "]" * }
- 'skip$
- if$
- fin.entry.original
- }
- % Webpage entry type.
- % Title and url fields required;
- % author, note, year, month, and lastchecked fields optional
- % See references
- % ISO 690-2 http://www.nlc-bnc.ca/iso/tc46sc9/standard/690-2e.htm
- % http://www.classroom.net/classroom/CitingNetResources.html
- % http://neal.ctstateu.edu/history/cite.html
- % http://www.cas.usf.edu/english/walker/mla.html
- % for citation formats for web pages.
- FUNCTION {webpage}
- { output.bibitem
- author empty$
- { editor empty$
- 'skip$ % author and editor both optional
- { format.editors output.nonnull }
- if$
- }
- { editor empty$
- { format.authors output.nonnull }
- { "can't use both author and editor fields in " cite$ * warning$ }
- if$
- }
- if$
- new.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$
- format.title "title" output.check
- inbrackets onlinestring output
- new.block
- year empty$
- 'skip$
- { format.date "year" output.check }
- if$
- % We don't need to output the URL details ('lastchecked' and 'url'),
- % because fin.entry does that for us, using output.web.refs. The only
- % reason we would want to put them here is if we were to decide that
- % they should go in front of the rather miscellaneous information in 'note'.
- new.block
- note output
- fin.entry
- }
- % ...urlbst to here
- FUNCTION {article}
- { output.bibitem
- format.authors "author" output.check
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title "title" output.check
- new.block
- crossref missing$
- {
- journal
- "journal" bibinfo.check
- emphasize
- "journal" output.check
- possibly.setup.inlinelink format.vol.num.pages output% urlbst
- }
- { format.article.crossref output.nonnull
- format.pages output
- }
- if$
- new.block
- format.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$
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.btitle "title" output.check
- format.edition output
- crossref missing$
- { format.bvolume output
- new.block
- format.number.series output
- new.sentence
- format.publisher.address output
- }
- {
- new.block
- format.book.crossref output.nonnull
- }
- if$
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {booklet}
- { output.bibitem
- format.authors output
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title "title" output.check
- new.block
- howpublished "howpublished" bibinfo.check output
- address "address" bibinfo.check output
- new.block
- format.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$
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.btitle "title" output.check
- format.edition output
- crossref missing$
- {
- format.bvolume output
- format.number.series output
- format.chapter "chapter" output.check
- new.sentence
- format.publisher.address output
- new.block
- }
- {
- format.chapter "chapter" output.check
- new.block
- format.book.crossref output.nonnull
- }
- if$
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {incollection}
- { output.bibitem
- format.authors "author" output.check
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title "title" output.check
- new.block
- crossref missing$
- { format.in.ed.booktitle "booktitle" output.check
- format.edition output
- format.bvolume output
- format.number.series output
- format.chapter.pages output
- new.sentence
- format.publisher.address output
- }
- { format.incoll.inproc.crossref output.nonnull
- format.chapter.pages output
- }
- if$
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {inproceedings}
- { output.bibitem
- format.authors "author" output.check
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title "title" output.check
- new.block
- crossref missing$
- { format.in.booktitle "booktitle" output.check
- format.bvolume output
- format.number.series output
- format.pages output
- address "address" bibinfo.check output
- new.sentence
- organization "organization" bibinfo.check output
- publisher "publisher" bibinfo.check output
- }
- { format.incoll.inproc.crossref output.nonnull
- format.pages output
- }
- if$
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {conference} { inproceedings }
- FUNCTION {manual}
- { output.bibitem
- format.authors output
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.btitle "title" output.check
- format.edition output
- organization address new.block.checkb
- organization "organization" bibinfo.check output
- address "address" bibinfo.check output
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {mastersthesis}
- { output.bibitem
- format.authors "author" output.check
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title
- "title" output.check
- new.block
- bbl.mthesis format.thesis.type output.nonnull
- school "school" bibinfo.warn output
- address "address" bibinfo.check output
- month "month" bibinfo.check output
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {misc}
- { output.bibitem
- format.authors output
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title output
- new.block
- howpublished "howpublished" bibinfo.check output
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {phdthesis}
- { output.bibitem
- format.authors "author" output.check
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.btitle
- "title" output.check
- new.block
- bbl.phdthesis format.thesis.type output.nonnull
- school "school" bibinfo.warn output
- address "address" bibinfo.check output
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {proceedings}
- { output.bibitem
- format.editors output
- editor format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.btitle "title" output.check
- format.bvolume output
- format.number.series output
- new.sentence
- publisher empty$
- { format.organization.address output }
- { organization "organization" bibinfo.check output
- new.sentence
- format.publisher.address output
- }
- if$
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {techreport}
- { output.bibitem
- format.authors "author" output.check
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title
- "title" output.check
- new.block
- format.tr.number output.nonnull
- institution "institution" bibinfo.warn output
- address "address" bibinfo.check output
- new.block
- format.note output
- fin.entry
- }
- FUNCTION {unpublished}
- { output.bibitem
- format.authors "author" output.check
- author format.key output
- format.date "year" output.check
- date.block
- title empty$ 'skip$ 'possibly.setup.inlinelink if$ % urlbst
- format.title "title" output.check
- new.block
- format.note "note" output.check
- fin.entry
- }
- FUNCTION {default.type} { misc }
- 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$
- }
- FUNCTION {format.lab.names}
- { 's :=
- "" 't :=
- s #1 "{vv~}{ll}" format.name$
- s num.names$ duplicate$
- #2 >
- { pop$
- " " * bbl.etal *
- }
- { #2 <
- 'skip$
- { s #2 "{ff }{vv }{ll}{ jj}" format.name$ "others" =
- {
- " " * bbl.etal *
- }
- { bbl.and space.word * s #2 "{vv~}{ll}" format.name$
- * }
- if$
- }
- if$
- }
- if$
- }
- FUNCTION {author.key.label}
- { author empty$
- { key empty$
- { cite$ #1 #3 substring$ }
- 'key
- if$
- }
- { author format.lab.names }
- if$
- }
- FUNCTION {author.editor.key.label}
- { author empty$
- { editor empty$
- { key empty$
- { cite$ #1 #3 substring$ }
- '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
- if$
- }
- { editor format.lab.names }
- if$
- }
- FUNCTION {calc.short.authors}
- { type$ "book" =
- type$ "inbook" =
- or
- 'author.editor.key.label
- { type$ "proceedings" =
- 'editor.key.label
- 'author.key.label
- if$
- }
- if$
- 'short.list :=
- }
- FUNCTION {calc.label}
- { calc.short.authors
- short.list
- "("
- *
- year duplicate$ empty$
- short.list key field.or.null = or
- { pop$ "" }
- 'skip$
- if$
- *
- 'label :=
- }
- FUNCTION {sort.format.names}
- { 's :=
- #1 'nameptr :=
- ""
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr
- "{ll{ }}{ ff{ }}{ jj{ }}"
- format.name$ 't :=
- nameptr #1 >
- {
- " " *
- namesleft #1 = t "others" = and
- { "zzzzz" * }
- { t sortify * }
- if$
- }
- { 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$
- }
- 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$
- 'sort.label :=
- sort.label
- *
- " "
- *
- title field.or.null
- sort.format.title
- *
- #1 entry.max$ substring$
- 'sort.key$ :=
- }
- ITERATE {presort}
- SORT
- STRINGS { last.label next.extra }
- INTEGERS { last.extra.num number.label }
- FUNCTION {initialize.extra.label.stuff}
- { #0 int.to.chr$ 'last.label :=
- "" 'next.extra :=
- #0 'last.extra.num :=
- #0 'number.label :=
- }
- 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$
- number.label #1 + 'number.label :=
- }
- FUNCTION {reverse.pass}
- { next.extra "b" =
- { "a" 'extra.label := }
- 'skip$
- if$
- extra.label 'next.extra :=
- extra.label
- duplicate$ empty$
- 'skip$
- { year field.or.null #-1 #1 substring$ chr.to.int$ #65 <
- { "{\natexlab{" swap$ * "}}" * }
- { "{(\natexlab{" swap$ * "})}" * }
- if$ }
- if$
- 'extra.label :=
- label extra.label * 'label :=
- }
- EXECUTE {initialize.extra.label.stuff}
- ITERATE {forward.pass}
- REVERSE {reverse.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
- FUNCTION {begin.bib}
- { preamble$ empty$
- 'skip$
- { preamble$ write$ newline$ }
- if$
- "\begin{thebibliography}{" number.label int.to.str$ * "}" *
- write$ newline$
- "\expandafter\ifx\csname natexlab\endcsname\relax\def\natexlab#1{#1}\fi"
- write$ newline$
- }
- EXECUTE {begin.bib}
- EXECUTE {init.urlbst.variables} % urlbst
- EXECUTE {init.state.consts}
- ITERATE {call.type$}
- FUNCTION {end.bib}
- { newline$
- "\end{thebibliography}" write$ newline$
- }
- EXECUTE {end.bib}
- %% End of customized bst file
- %%
- %% End of file `compling.bst'.
|