+++ /dev/null
-%%\r
-%% IEEEtran.bst\r
-%% BibTeX Bibliography Style file for IEEE Journals and Conferences (unsorted)\r
-%% Version 1.12 (2007/01/11)\r
-%% \r
-%% Copyright (c) 2003-2007 Michael Shell\r
-%% \r
-%% Original starting code base and algorithms obtained from the output of\r
-%% Patrick W. Daly's makebst package as well as from prior versions of\r
-%% IEEE BibTeX styles:\r
-%% \r
-%% 1. Howard Trickey and Oren Patashnik's ieeetr.bst (1985/1988)\r
-%% 2. Silvano Balemi and Richard H. Roy's IEEEbib.bst (1993)\r
-%% \r
-%% Support sites:\r
-%% http://www.michaelshell.org/tex/ieeetran/\r
-%% http://www.ctan.org/tex-archive/macros/latex/contrib/IEEEtran/\r
-%% and/or\r
-%% http://www.ieee.org/\r
-%% \r
-%% For use with BibTeX version 0.99a or later\r
-%%\r
-%% This is a numerical citation style.\r
-%% \r
-%%*************************************************************************\r
-%% Legal Notice:\r
-%% This code is offered as-is without any warranty either expressed or\r
-%% implied; without even the implied warranty of MERCHANTABILITY or\r
-%% FITNESS FOR A PARTICULAR PURPOSE! \r
-%% User assumes all risk.\r
-%% In no event shall IEEE or any contributor to this code be liable for\r
-%% any damages or losses, including, but not limited to, incidental,\r
-%% consequential, or any other damages, resulting from the use or misuse\r
-%% of any information contained here.\r
-%%\r
-%% All comments are the opinions of their respective authors and are not\r
-%% necessarily endorsed by the IEEE.\r
-%%\r
-%% This work is distributed under the LaTeX Project Public License (LPPL)\r
-%% ( http://www.latex-project.org/ ) version 1.3, and may be freely used,\r
-%% distributed and modified. A copy of the LPPL, version 1.3, is included\r
-%% in the base LaTeX documentation of all distributions of LaTeX released\r
-%% 2003/12/01 or later.\r
-%% Retain all contribution notices and credits.\r
-%% ** Modified files should be clearly indicated as such, including **\r
-%% ** renaming them and changing author support contact information. **\r
-%%\r
-%% File list of work: IEEEabrv.bib, IEEEfull.bib, IEEEexample.bib,\r
-%% IEEEtran.bst, IEEEtranS.bst, IEEEtranSA.bst,\r
-%% IEEEtranN.bst, IEEEtranSN.bst, IEEEtran_bst_HOWTO.pdf\r
-%%*************************************************************************\r
-%\r
-%\r
-% Changelog:\r
-%\r
-% 1.00 (2002/08/13) Initial release\r
-%\r
-% 1.10 (2002/09/27)\r
-% 1. Corrected minor bug for improperly formed warning message when a\r
-% book was not given a title. Thanks to Ming Kin Lai for reporting this.\r
-% 2. Added support for CTLname_format_string and CTLname_latex_cmd fields\r
-% in the BST control entry type.\r
-%\r
-% 1.11 (2003/04/02)\r
-% 1. Fixed bug with URLs containing underscores when using url.sty. Thanks\r
-% to Ming Kin Lai for reporting this.\r
-%\r
-% 1.12 (2007/01/11)\r
-% 1. Fixed bug with unwanted comma before "et al." when an entry contained\r
-% more than two author names. Thanks to Pallav Gupta for reporting this.\r
-% 2. Fixed bug with anomalous closing quote in tech reports that have a\r
-% type, but without a number or address. Thanks to Mehrdad Mirreza for\r
-% reporting this.\r
-% 3. Use braces in \providecommand in begin.bib to better support\r
-% latex2html. TeX style length assignments OK with recent versions\r
-% of latex2html - 1.71 (2002/2/1) or later is strongly recommended.\r
-% Use of the language field still causes trouble with latex2html.\r
-% Thanks to Federico Beffa for reporting this.\r
-% 4. Added IEEEtran.bst ID and version comment string to .bbl output.\r
-% 5. Provide a \BIBdecl hook that allows the user to execute commands\r
-% just prior to the first entry.\r
-% 6. Use default urlstyle (is using url.sty) of "same" rather than rm to\r
-% better work with a wider variety of bibliography styles.\r
-% 7. Changed month abbreviations from Sept., July and June to Sep., Jul.,\r
-% and Jun., respectively, as IEEE now does. Thanks to Moritz Borgmann\r
-% for reporting this.\r
-% 8. Control entry types should not be considered when calculating longest\r
-% label width.\r
-% 9. Added alias www for electronic/online.\r
-% 10. Added CTLname_url_prefix control entry type.\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-%% DEFAULTS FOR THE CONTROLS OF THE BST STYLE %%\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-% These are the defaults for the user adjustable controls. The values used\r
-% here can be overridden by the user via IEEEtranBSTCTL entry type.\r
-\r
-% NOTE: The recommended LaTeX command to invoke a control entry type is:\r
-% \r
-%\makeatletter\r
-%\def\bstctlcite{\@ifnextchar[{\@bstctlcite}{\@bstctlcite[@auxout]}}\r
-%\def\@bstctlcite[#1]#2{\@bsphack\r
-% \@for\@citeb:=#2\do{%\r
-% \edef\@citeb{\expandafter\@firstofone\@citeb}%\r
-% \if@filesw\immediate\write\csname #1\endcsname{\string\citation{\@citeb}}\fi}%\r
-% \@esphack}\r
-%\makeatother\r
-%\r
-% It is called at the start of the document, before the first \cite, like:\r
-% \bstctlcite{IEEEexample:BSTcontrol}\r
-%\r
-% IEEEtran.cls V1.6 and later does provide this command.\r
-\r
-\r
-\r
-% #0 turns off the display of the number for articles.\r
-% #1 enables\r
-FUNCTION {default.is.use.number.for.article} { #1 }\r
-\r
-\r
-% #0 turns off the display of the paper and type fields in @inproceedings.\r
-% #1 enables\r
-FUNCTION {default.is.use.paper} { #1 }\r
-\r
-\r
-% #0 turns off the forced use of "et al."\r
-% #1 enables\r
-FUNCTION {default.is.forced.et.al} { #0 }\r
-\r
-% The maximum number of names that can be present beyond which an "et al."\r
-% usage is forced. Be sure that num.names.shown.with.forced.et.al (below)\r
-% is not greater than this value!\r
-% Note: There are many instances of references in IEEE journals which have\r
-% a very large number of authors as well as instances in which "et al." is\r
-% used profusely.\r
-FUNCTION {default.max.num.names.before.forced.et.al} { #10 }\r
-\r
-% The number of names that will be shown with a forced "et al.".\r
-% Must be less than or equal to max.num.names.before.forced.et.al\r
-FUNCTION {default.num.names.shown.with.forced.et.al} { #1 }\r
-\r
-\r
-% #0 turns off the alternate interword spacing for entries with URLs.\r
-% #1 enables\r
-FUNCTION {default.is.use.alt.interword.spacing} { #1 }\r
-\r
-% If alternate interword spacing for entries with URLs is enabled, this is\r
-% the interword spacing stretch factor that will be used. For example, the\r
-% default "4" here means that the interword spacing in entries with URLs can\r
-% stretch to four times normal. Does not have to be an integer. Note that\r
-% the value specified here can be overridden by the user in their LaTeX\r
-% code via a command such as: \r
-% "\providecommand\BIBentryALTinterwordstretchfactor{1.5}" in addition to\r
-% that via the IEEEtranBSTCTL entry type.\r
-FUNCTION {default.ALTinterwordstretchfactor} { "4" }\r
-\r
-\r
-% #0 turns off the "dashification" of repeated (i.e., identical to those\r
-% of the previous entry) names. IEEE normally does this.\r
-% #1 enables\r
-FUNCTION {default.is.dash.repeated.names} { #1 }\r
-\r
-\r
-% The default name format control string.\r
-FUNCTION {default.name.format.string}{ "{f.~}{vv~}{ll}{, jj}" }\r
-\r
-\r
-% The default LaTeX font command for the names.\r
-FUNCTION {default.name.latex.cmd}{ "" }\r
-\r
-\r
-% The default URL prefix.\r
-FUNCTION {default.name.url.prefix}{ "[Online]. Available:" }\r
-\r
-\r
-% Other controls that cannot be accessed via IEEEtranBSTCTL entry type.\r
-\r
-% #0 turns off the terminal startup banner/completed message so as to\r
-% operate more quietly.\r
-% #1 enables\r
-FUNCTION {is.print.banners.to.terminal} { #1 }\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-%% FILE VERSION AND BANNER %%\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-FUNCTION{bst.file.version} { "1.12" }\r
-FUNCTION{bst.file.date} { "2007/01/11" }\r
-FUNCTION{bst.file.website} { "http://www.michaelshell.org/tex/ieeetran/bibtex/" }\r
-\r
-FUNCTION {banner.message}\r
-{ is.print.banners.to.terminal\r
- { "-- IEEEtran.bst version" " " * bst.file.version *\r
- " (" * bst.file.date * ") " * "by Michael Shell." *\r
- top$\r
- "-- " bst.file.website *\r
- top$\r
- "-- See the " quote$ * "IEEEtran_bst_HOWTO.pdf" * quote$ * " manual for usage information." *\r
- top$\r
- }\r
- { skip$ }\r
- if$\r
-}\r
-\r
-FUNCTION {completed.message}\r
-{ is.print.banners.to.terminal\r
- { ""\r
- top$\r
- "Done."\r
- top$\r
- }\r
- { skip$ }\r
- if$\r
-}\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%\r
-%% STRING CONSTANTS %%\r
-%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-FUNCTION {bbl.and}{ "and" }\r
-FUNCTION {bbl.etal}{ "et~al." }\r
-FUNCTION {bbl.editors}{ "eds." }\r
-FUNCTION {bbl.editor}{ "ed." }\r
-FUNCTION {bbl.edition}{ "ed." }\r
-FUNCTION {bbl.volume}{ "vol." }\r
-FUNCTION {bbl.of}{ "of" }\r
-FUNCTION {bbl.number}{ "no." }\r
-FUNCTION {bbl.in}{ "in" }\r
-FUNCTION {bbl.pages}{ "pp." }\r
-FUNCTION {bbl.page}{ "p." }\r
-FUNCTION {bbl.chapter}{ "ch." }\r
-FUNCTION {bbl.paper}{ "paper" }\r
-FUNCTION {bbl.part}{ "pt." }\r
-FUNCTION {bbl.patent}{ "Patent" }\r
-FUNCTION {bbl.patentUS}{ "U.S." }\r
-FUNCTION {bbl.revision}{ "Rev." }\r
-FUNCTION {bbl.series}{ "ser." }\r
-FUNCTION {bbl.standard}{ "Std." }\r
-FUNCTION {bbl.techrep}{ "Tech. Rep." }\r
-FUNCTION {bbl.mthesis}{ "Master's thesis" }\r
-FUNCTION {bbl.phdthesis}{ "Ph.D. dissertation" }\r
-FUNCTION {bbl.st}{ "st" }\r
-FUNCTION {bbl.nd}{ "nd" }\r
-FUNCTION {bbl.rd}{ "rd" }\r
-FUNCTION {bbl.th}{ "th" }\r
-\r
-\r
-% This is the LaTeX spacer that is used when a larger than normal space\r
-% is called for (such as just before the address:publisher).\r
-FUNCTION {large.space} { "\hskip 1em plus 0.5em minus 0.4em\relax " }\r
-\r
-% The LaTeX code for dashes that are used to represent repeated names.\r
-% Note: Some older IEEE journals used something like\r
-% "\rule{0.275in}{0.5pt}\," which is fairly thick and runs right along\r
-% the baseline. However, IEEE now uses a thinner, above baseline,\r
-% six dash long sequence.\r
-FUNCTION {repeated.name.dashes} { "------" }\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-%% PREDEFINED STRING MACROS %%\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-MACRO {jan} {"Jan."}\r
-MACRO {feb} {"Feb."}\r
-MACRO {mar} {"Mar."}\r
-MACRO {apr} {"Apr."}\r
-MACRO {may} {"May"}\r
-MACRO {jun} {"Jun."}\r
-MACRO {jul} {"Jul."}\r
-MACRO {aug} {"Aug."}\r
-MACRO {sep} {"Sep."}\r
-MACRO {oct} {"Oct."}\r
-MACRO {nov} {"Nov."}\r
-MACRO {dec} {"Dec."}\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%\r
-%% ENTRY FIELDS %%\r
-%%%%%%%%%%%%%%%%%%\r
-\r
-ENTRY\r
- { address\r
- assignee\r
- author\r
- booktitle\r
- chapter\r
- day\r
- dayfiled\r
- edition\r
- editor\r
- howpublished\r
- institution\r
- intype\r
- journal\r
- key\r
- language\r
- month\r
- monthfiled\r
- nationality\r
- note\r
- number\r
- organization\r
- pages\r
- paper\r
- publisher\r
- school\r
- series\r
- revision\r
- title\r
- type\r
- url\r
- volume\r
- year\r
- yearfiled\r
- CTLuse_article_number\r
- CTLuse_paper\r
- CTLuse_forced_etal\r
- CTLmax_names_forced_etal\r
- CTLnames_show_etal\r
- CTLuse_alt_spacing\r
- CTLalt_stretch_factor\r
- CTLdash_repeated_names\r
- CTLname_format_string\r
- CTLname_latex_cmd\r
- CTLname_url_prefix\r
- }\r
- {}\r
- { label }\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%%\r
-%% INTEGER VARIABLES %%\r
-%%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-INTEGERS { prev.status.punct this.status.punct punct.std\r
- punct.no punct.comma punct.period \r
- prev.status.space this.status.space space.std\r
- space.no space.normal space.large\r
- prev.status.quote this.status.quote quote.std\r
- quote.no quote.close\r
- prev.status.nline this.status.nline nline.std\r
- nline.no nline.newblock \r
- status.cap cap.std\r
- cap.no cap.yes}\r
-\r
-INTEGERS { longest.label.width multiresult nameptr namesleft number.label numnames }\r
-\r
-INTEGERS { is.use.number.for.article\r
- is.use.paper\r
- is.forced.et.al\r
- max.num.names.before.forced.et.al\r
- num.names.shown.with.forced.et.al\r
- is.use.alt.interword.spacing\r
- is.dash.repeated.names}\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%\r
-%% STRING VARIABLES %%\r
-%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-STRINGS { bibinfo\r
- longest.label\r
- oldname\r
- s\r
- t\r
- ALTinterwordstretchfactor\r
- name.format.string\r
- name.latex.cmd\r
- name.url.prefix}\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%%%%\r
-%% LOW LEVEL FUNCTIONS %%\r
-%%%%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-FUNCTION {initialize.controls}\r
-{ default.is.use.number.for.article 'is.use.number.for.article :=\r
- default.is.use.paper 'is.use.paper :=\r
- default.is.forced.et.al 'is.forced.et.al :=\r
- default.max.num.names.before.forced.et.al 'max.num.names.before.forced.et.al :=\r
- default.num.names.shown.with.forced.et.al 'num.names.shown.with.forced.et.al :=\r
- default.is.use.alt.interword.spacing 'is.use.alt.interword.spacing :=\r
- default.is.dash.repeated.names 'is.dash.repeated.names :=\r
- default.ALTinterwordstretchfactor 'ALTinterwordstretchfactor :=\r
- default.name.format.string 'name.format.string :=\r
- default.name.latex.cmd 'name.latex.cmd :=\r
- default.name.url.prefix 'name.url.prefix :=\r
-}\r
-\r
-\r
-% This IEEEtran.bst features a very powerful and flexible mechanism for\r
-% controlling the capitalization, punctuation, spacing, quotation, and\r
-% newlines of the formatted entry fields. (Note: IEEEtran.bst does not need\r
-% or use the newline/newblock feature, but it has been implemented for\r
-% possible future use.) The output states of IEEEtran.bst consist of\r
-% multiple independent attributes and, as such, can be thought of as being\r
-% vectors, rather than the simple scalar values ("before.all", \r
-% "mid.sentence", etc.) used in most other .bst files.\r
-% \r
-% The more flexible and complex design used here was motivated in part by\r
-% IEEE's rather unusual bibliography style. For example, IEEE ends the\r
-% previous field item with a period and large space prior to the publisher\r
-% address; the @electronic entry types use periods as inter-item punctuation\r
-% rather than the commas used by the other entry types; and URLs are never\r
-% followed by periods even though they are the last item in the entry.\r
-% Although it is possible to accommodate these features with the conventional\r
-% output state system, the seemingly endless exceptions make for convoluted,\r
-% unreliable and difficult to maintain code.\r
-%\r
-% IEEEtran.bst's output state system can be easily understood via a simple\r
-% illustration of two most recently formatted entry fields (on the stack):\r
-%\r
-% CURRENT_ITEM\r
-% "PREVIOUS_ITEM\r
-%\r
-% which, in this example, is to eventually appear in the bibliography as:\r
-% \r
-% "PREVIOUS_ITEM," CURRENT_ITEM\r
-%\r
-% It is the job of the output routine to take the previous item off of the\r
-% stack (while leaving the current item at the top of the stack), apply its\r
-% trailing punctuation (including closing quote marks) and spacing, and then\r
-% to write the result to BibTeX's output buffer:\r
-% \r
-% "PREVIOUS_ITEM," \r
-% \r
-% Punctuation (and spacing) between items is often determined by both of the\r
-% items rather than just the first one. The presence of quotation marks\r
-% further complicates the situation because, in standard English, trailing\r
-% punctuation marks are supposed to be contained within the quotes.\r
-% \r
-% IEEEtran.bst maintains two output state (aka "status") vectors which\r
-% correspond to the previous and current (aka "this") items. Each vector\r
-% consists of several independent attributes which track punctuation,\r
-% spacing, quotation, and newlines. Capitalization status is handled by a\r
-% separate scalar because the format routines, not the output routine,\r
-% handle capitalization and, therefore, there is no need to maintain the\r
-% capitalization attribute for both the "previous" and "this" items.\r
-% \r
-% When a format routine adds a new item, it copies the current output status\r
-% vector to the previous output status vector and (usually) resets the\r
-% current (this) output status vector to a "standard status" vector. Using a\r
-% "standard status" vector in this way allows us to redefine what we mean by\r
-% "standard status" at the start of each entry handler and reuse the same\r
-% format routines under the various inter-item separation schemes. For\r
-% example, the standard status vector for the @book entry type may use\r
-% commas for item separators, while the @electronic type may use periods,\r
-% yet both entry handlers exploit many of the exact same format routines.\r
-% \r
-% Because format routines have write access to the output status vector of\r
-% the previous item, they can override the punctuation choices of the\r
-% previous format routine! Therefore, it becomes trivial to implement rules\r
-% such as "Always use a period and a large space before the publisher." By\r
-% pushing the generation of the closing quote mark to the output routine, we\r
-% avoid all the problems caused by having to close a quote before having all\r
-% the information required to determine what the punctuation should be.\r
-%\r
-% The IEEEtran.bst output state system can easily be expanded if needed.\r
-% For instance, it is easy to add a "space.tie" attribute value if the\r
-% bibliography rules mandate that two items have to be joined with an\r
-% unbreakable space. \r
-\r
-FUNCTION {initialize.status.constants}\r
-{ #0 'punct.no :=\r
- #1 'punct.comma :=\r
- #2 'punct.period :=\r
- #0 'space.no := \r
- #1 'space.normal :=\r
- #2 'space.large :=\r
- #0 'quote.no :=\r
- #1 'quote.close :=\r
- #0 'cap.no :=\r
- #1 'cap.yes :=\r
- #0 'nline.no :=\r
- #1 'nline.newblock :=\r
-}\r
-\r
-FUNCTION {std.status.using.comma}\r
-{ punct.comma 'punct.std :=\r
- space.normal 'space.std :=\r
- quote.no 'quote.std :=\r
- nline.no 'nline.std :=\r
- cap.no 'cap.std :=\r
-}\r
-\r
-FUNCTION {std.status.using.period}\r
-{ punct.period 'punct.std :=\r
- space.normal 'space.std :=\r
- quote.no 'quote.std :=\r
- nline.no 'nline.std :=\r
- cap.yes 'cap.std :=\r
-}\r
-\r
-FUNCTION {initialize.prev.this.status}\r
-{ punct.no 'prev.status.punct :=\r
- space.no 'prev.status.space :=\r
- quote.no 'prev.status.quote :=\r
- nline.no 'prev.status.nline :=\r
- punct.no 'this.status.punct :=\r
- space.no 'this.status.space :=\r
- quote.no 'this.status.quote :=\r
- nline.no 'this.status.nline :=\r
- cap.yes 'status.cap :=\r
-}\r
-\r
-FUNCTION {this.status.std}\r
-{ punct.std 'this.status.punct :=\r
- space.std 'this.status.space :=\r
- quote.std 'this.status.quote :=\r
- nline.std 'this.status.nline :=\r
-}\r
-\r
-FUNCTION {cap.status.std}{ cap.std 'status.cap := }\r
-\r
-FUNCTION {this.to.prev.status}\r
-{ this.status.punct 'prev.status.punct :=\r
- this.status.space 'prev.status.space :=\r
- this.status.quote 'prev.status.quote :=\r
- this.status.nline 'prev.status.nline :=\r
-}\r
-\r
-\r
-FUNCTION {not}\r
-{ { #0 }\r
- { #1 }\r
- if$\r
-}\r
-\r
-FUNCTION {and}\r
-{ { skip$ }\r
- { pop$ #0 }\r
- if$\r
-}\r
-\r
-FUNCTION {or}\r
-{ { pop$ #1 }\r
- { skip$ }\r
- if$\r
-}\r
-\r
-\r
-% convert the strings "yes" or "no" to #1 or #0 respectively\r
-FUNCTION {yes.no.to.int}\r
-{ "l" change.case$ duplicate$\r
- "yes" =\r
- { pop$ #1 }\r
- { duplicate$ "no" =\r
- { pop$ #0 }\r
- { "unknown boolean " quote$ * swap$ * quote$ *\r
- " in " * cite$ * warning$\r
- #0\r
- }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-\r
-% pushes true if the single char string on the stack is in the\r
-% range of "0" to "9"\r
-FUNCTION {is.num}\r
-{ chr.to.int$\r
- duplicate$ "0" chr.to.int$ < not\r
- swap$ "9" chr.to.int$ > not and\r
-}\r
-\r
-% multiplies the integer on the stack by a factor of 10\r
-FUNCTION {bump.int.mag}\r
-{ #0 'multiresult :=\r
- { duplicate$ #0 > }\r
- { #1 -\r
- multiresult #10 +\r
- 'multiresult :=\r
- }\r
- while$\r
-pop$\r
-multiresult\r
-}\r
-\r
-% converts a single character string on the stack to an integer\r
-FUNCTION {char.to.integer}\r
-{ duplicate$ \r
- is.num\r
- { chr.to.int$ "0" chr.to.int$ - }\r
- {"noninteger character " quote$ * swap$ * quote$ *\r
- " in integer field of " * cite$ * warning$\r
- #0\r
- }\r
- if$\r
-}\r
-\r
-% converts a string on the stack to an integer\r
-FUNCTION {string.to.integer}\r
-{ duplicate$ text.length$ 'namesleft :=\r
- #1 'nameptr :=\r
- #0 'numnames :=\r
- { nameptr namesleft > not }\r
- { duplicate$ nameptr #1 substring$\r
- char.to.integer numnames bump.int.mag +\r
- 'numnames :=\r
- nameptr #1 +\r
- 'nameptr :=\r
- }\r
- while$\r
-pop$\r
-numnames\r
-}\r
-\r
-\r
-\r
-\r
-% The output routines write out the *next* to the top (previous) item on the\r
-% stack, adding punctuation and such as needed. Since IEEEtran.bst maintains\r
-% the output status for the top two items on the stack, these output\r
-% routines have to consider the previous output status (which corresponds to\r
-% the item that is being output). Full independent control of punctuation,\r
-% closing quote marks, spacing, and newblock is provided.\r
-% \r
-% "output.nonnull" does not check for the presence of a previous empty\r
-% item.\r
-% \r
-% "output" does check for the presence of a previous empty item and will\r
-% remove an empty item rather than outputing it.\r
-% \r
-% "output.warn" is like "output", but will issue a warning if it detects\r
-% an empty item.\r
-\r
-FUNCTION {output.nonnull}\r
-{ swap$\r
- prev.status.punct punct.comma =\r
- { "," * }\r
- { skip$ }\r
- if$\r
- prev.status.punct punct.period =\r
- { add.period$ }\r
- { skip$ }\r
- if$ \r
- prev.status.quote quote.close =\r
- { "''" * }\r
- { skip$ }\r
- if$\r
- prev.status.space space.normal =\r
- { " " * }\r
- { skip$ }\r
- if$\r
- prev.status.space space.large =\r
- { large.space * }\r
- { skip$ }\r
- if$\r
- write$\r
- prev.status.nline nline.newblock =\r
- { newline$ "\newblock " write$ }\r
- { skip$ }\r
- if$\r
-}\r
-\r
-FUNCTION {output}\r
-{ duplicate$ empty$\r
- 'pop$\r
- 'output.nonnull\r
- if$\r
-}\r
-\r
-FUNCTION {output.warn}\r
-{ 't :=\r
- duplicate$ empty$\r
- { pop$ "empty " t * " in " * cite$ * warning$ }\r
- 'output.nonnull\r
- if$\r
-}\r
-\r
-% "fin.entry" is the output routine that handles the last item of the entry\r
-% (which will be on the top of the stack when "fin.entry" is called).\r
-\r
-FUNCTION {fin.entry}\r
-{ this.status.punct punct.no =\r
- { skip$ }\r
- { add.period$ }\r
- if$\r
- this.status.quote quote.close =\r
- { "''" * }\r
- { skip$ }\r
- if$\r
-write$\r
-newline$\r
-}\r
-\r
-\r
-FUNCTION {is.last.char.not.punct}\r
-{ duplicate$\r
- "}" * add.period$\r
- #-1 #1 substring$ "." =\r
-}\r
-\r
-FUNCTION {is.multiple.pages}\r
-{ 't :=\r
- #0 'multiresult :=\r
- { multiresult not\r
- t empty$ not\r
- and\r
- }\r
- { t #1 #1 substring$\r
- duplicate$ "-" =\r
- swap$ duplicate$ "," =\r
- swap$ "+" =\r
- or or\r
- { #1 'multiresult := }\r
- { t #2 global.max$ substring$ 't := }\r
- if$\r
- }\r
- while$\r
- multiresult\r
-}\r
-\r
-FUNCTION {capitalize}{ "u" change.case$ "t" change.case$ }\r
-\r
-FUNCTION {emphasize}\r
-{ duplicate$ empty$\r
- { pop$ "" }\r
- { "\emph{" swap$ * "}" * }\r
- if$\r
-}\r
-\r
-FUNCTION {do.name.latex.cmd}\r
-{ name.latex.cmd\r
- empty$\r
- { skip$ }\r
- { name.latex.cmd "{" * swap$ * "}" * }\r
- if$\r
-}\r
-\r
-% IEEEtran.bst uses its own \BIBforeignlanguage command which directly\r
-% invokes the TeX hyphenation patterns without the need of the Babel\r
-% package. Babel does a lot more than switch hyphenation patterns and\r
-% its loading can cause unintended effects in many class files (such as\r
-% IEEEtran.cls).\r
-FUNCTION {select.language}\r
-{ duplicate$ empty$ 'pop$\r
- { language empty$ 'skip$\r
- { "\BIBforeignlanguage{" language * "}{" * swap$ * "}" * }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {tie.or.space.prefix}\r
-{ duplicate$ text.length$ #3 <\r
- { "~" }\r
- { " " }\r
- if$\r
- swap$\r
-}\r
-\r
-FUNCTION {get.bbl.editor}\r
-{ editor num.names$ #1 > 'bbl.editors 'bbl.editor if$ }\r
-\r
-FUNCTION {space.word}{ " " swap$ * " " * }\r
-\r
-\r
-% Field Conditioners, Converters, Checkers and External Interfaces\r
-\r
-FUNCTION {empty.field.to.null.string}\r
-{ duplicate$ empty$\r
- { pop$ "" }\r
- { skip$ }\r
- if$\r
-}\r
-\r
-FUNCTION {either.or.check}\r
-{ empty$\r
- { pop$ }\r
- { "can't use both " swap$ * " fields in " * cite$ * warning$ }\r
- if$\r
-}\r
-\r
-FUNCTION {empty.entry.warn}\r
-{ author empty$ title empty$ howpublished empty$\r
- month empty$ year empty$ note empty$ url empty$\r
- and and and and and and\r
- { "all relevant fields are empty in " cite$ * warning$ }\r
- 'skip$\r
- if$\r
-}\r
-\r
-\r
-% The bibinfo system provides a way for the electronic parsing/acquisition\r
-% of a bibliography's contents as is done by ReVTeX. For example, a field\r
-% could be entered into the bibliography as:\r
-% \bibinfo{volume}{2}\r
-% Only the "2" would show up in the document, but the LaTeX \bibinfo command\r
-% could do additional things with the information. IEEEtran.bst does provide\r
-% a \bibinfo command via "\providecommand{\bibinfo}[2]{#2}". However, it is\r
-% currently not used as the bogus bibinfo functions defined here output the\r
-% entry values directly without the \bibinfo wrapper. The bibinfo functions\r
-% themselves (and the calls to them) are retained for possible future use.\r
-% \r
-% bibinfo.check avoids acting on missing fields while bibinfo.warn will\r
-% issue a warning message if a missing field is detected. Prior to calling\r
-% the bibinfo functions, the user should push the field value and then its\r
-% name string, in that order.\r
-\r
-FUNCTION {bibinfo.check}\r
-{ swap$ duplicate$ missing$\r
- { pop$ pop$ "" }\r
- { duplicate$ empty$\r
- { swap$ pop$ }\r
- { swap$ pop$ }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {bibinfo.warn}\r
-{ swap$ duplicate$ missing$\r
- { swap$ "missing " swap$ * " in " * cite$ * warning$ pop$ "" }\r
- { duplicate$ empty$\r
- { swap$ "empty " swap$ * " in " * cite$ * warning$ }\r
- { swap$ pop$ }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-\r
-% IEEE separates large numbers with more than 4 digits into groups of\r
-% three. IEEE uses a small space to separate these number groups. \r
-% Typical applications include patent and page numbers.\r
-\r
-% number of consecutive digits required to trigger the group separation.\r
-FUNCTION {large.number.trigger}{ #5 }\r
-\r
-% For numbers longer than the trigger, this is the blocksize of the groups.\r
-% The blocksize must be less than the trigger threshold, and 2 * blocksize\r
-% must be greater than the trigger threshold (can't do more than one\r
-% separation on the initial trigger).\r
-FUNCTION {large.number.blocksize}{ #3 }\r
-\r
-% What is actually inserted between the number groups.\r
-FUNCTION {large.number.separator}{ "\," }\r
-\r
-% So as to save on integer variables by reusing existing ones, numnames\r
-% holds the current number of consecutive digits read and nameptr holds\r
-% the number that will trigger an inserted space.\r
-FUNCTION {large.number.separate}\r
-{ 't :=\r
- ""\r
- #0 'numnames :=\r
- large.number.trigger 'nameptr :=\r
- { t empty$ not }\r
- { t #-1 #1 substring$ is.num\r
- { numnames #1 + 'numnames := }\r
- { #0 'numnames := \r
- large.number.trigger 'nameptr :=\r
- }\r
- if$\r
- t #-1 #1 substring$ swap$ *\r
- t #-2 global.max$ substring$ 't :=\r
- numnames nameptr =\r
- { duplicate$ #1 nameptr large.number.blocksize - substring$ swap$\r
- nameptr large.number.blocksize - #1 + global.max$ substring$\r
- large.number.separator swap$ * *\r
- nameptr large.number.blocksize - 'numnames :=\r
- large.number.blocksize #1 + 'nameptr :=\r
- }\r
- { skip$ }\r
- if$\r
- }\r
- while$\r
-}\r
-\r
-% Converts all single dashes "-" to double dashes "--".\r
-FUNCTION {n.dashify}\r
-{ large.number.separate\r
- 't :=\r
- ""\r
- { t empty$ not }\r
- { t #1 #1 substring$ "-" =\r
- { t #1 #2 substring$ "--" = not\r
- { "--" *\r
- t #2 global.max$ substring$ 't :=\r
- }\r
- { { t #1 #1 substring$ "-" = }\r
- { "-" *\r
- t #2 global.max$ substring$ 't :=\r
- }\r
- while$\r
- }\r
- if$\r
- }\r
- { t #1 #1 substring$ *\r
- t #2 global.max$ substring$ 't :=\r
- }\r
- if$\r
- }\r
- while$\r
-}\r
-\r
-\r
-% This function detects entries with names that are identical to that of\r
-% the previous entry and replaces the repeated names with dashes (if the\r
-% "is.dash.repeated.names" user control is nonzero).\r
-FUNCTION {name.or.dash}\r
-{ 's :=\r
- oldname empty$\r
- { s 'oldname := s }\r
- { s oldname =\r
- { is.dash.repeated.names\r
- { repeated.name.dashes }\r
- { s 'oldname := s }\r
- if$\r
- }\r
- { s 'oldname := s }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-% Converts the number string on the top of the stack to\r
-% "numerical ordinal form" (e.g., "7" to "7th"). There is\r
-% no artificial limit to the upper bound of the numbers as the\r
-% least significant digit always determines the ordinal form.\r
-FUNCTION {num.to.ordinal}\r
-{ duplicate$ #-1 #1 substring$ "1" =\r
- { bbl.st * }\r
- { duplicate$ #-1 #1 substring$ "2" =\r
- { bbl.nd * }\r
- { duplicate$ #-1 #1 substring$ "3" =\r
- { bbl.rd * }\r
- { bbl.th * }\r
- if$\r
- }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-% If the string on the top of the stack begins with a number,\r
-% (e.g., 11th) then replace the string with the leading number\r
-% it contains. Otherwise retain the string as-is. s holds the\r
-% extracted number, t holds the part of the string that remains\r
-% to be scanned.\r
-FUNCTION {extract.num}\r
-{ duplicate$ 't :=\r
- "" 's :=\r
- { t empty$ not }\r
- { t #1 #1 substring$\r
- t #2 global.max$ substring$ 't :=\r
- duplicate$ is.num\r
- { s swap$ * 's := }\r
- { pop$ "" 't := }\r
- if$\r
- }\r
- while$\r
- s empty$\r
- 'skip$\r
- { pop$ s }\r
- if$\r
-}\r
-\r
-% Converts the word number string on the top of the stack to\r
-% Arabic string form. Will be successful up to "tenth".\r
-FUNCTION {word.to.num}\r
-{ duplicate$ "l" change.case$ 's :=\r
- s "first" =\r
- { pop$ "1" }\r
- { skip$ }\r
- if$\r
- s "second" =\r
- { pop$ "2" }\r
- { skip$ }\r
- if$\r
- s "third" =\r
- { pop$ "3" }\r
- { skip$ }\r
- if$\r
- s "fourth" =\r
- { pop$ "4" }\r
- { skip$ }\r
- if$\r
- s "fifth" =\r
- { pop$ "5" }\r
- { skip$ }\r
- if$\r
- s "sixth" =\r
- { pop$ "6" }\r
- { skip$ }\r
- if$\r
- s "seventh" =\r
- { pop$ "7" }\r
- { skip$ }\r
- if$\r
- s "eighth" =\r
- { pop$ "8" }\r
- { skip$ }\r
- if$\r
- s "ninth" =\r
- { pop$ "9" }\r
- { skip$ }\r
- if$\r
- s "tenth" =\r
- { pop$ "10" }\r
- { skip$ }\r
- if$\r
-}\r
-\r
-\r
-% Converts the string on the top of the stack to numerical\r
-% ordinal (e.g., "11th") form.\r
-FUNCTION {convert.edition}\r
-{ duplicate$ empty$ 'skip$\r
- { duplicate$ #1 #1 substring$ is.num\r
- { extract.num\r
- num.to.ordinal\r
- }\r
- { word.to.num\r
- duplicate$ #1 #1 substring$ is.num\r
- { num.to.ordinal }\r
- { "edition ordinal word " quote$ * edition * quote$ *\r
- " may be too high (or improper) for conversion" * " in " * cite$ * warning$\r
- }\r
- if$\r
- }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-%% LATEX BIBLIOGRAPHY CODE %%\r
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-FUNCTION {start.entry}\r
-{ newline$\r
- "\bibitem{" write$\r
- cite$ write$\r
- "}" write$\r
- newline$\r
- ""\r
- initialize.prev.this.status\r
-}\r
-\r
-% Here we write out all the LaTeX code that we will need. The most involved\r
-% code sequences are those that control the alternate interword spacing and\r
-% foreign language hyphenation patterns. The heavy use of \providecommand\r
-% gives users a way to override the defaults. Special thanks to Javier Bezos,\r
-% Johannes Braams, Robin Fairbairns, Heiko Oberdiek, Donald Arseneau and all\r
-% the other gurus on comp.text.tex for their help and advice on the topic of\r
-% \selectlanguage, Babel and BibTeX.\r
-FUNCTION {begin.bib}\r
-{ "% Generated by IEEEtran.bst, version: " bst.file.version * " (" * bst.file.date * ")" *\r
- write$ newline$\r
- preamble$ empty$ 'skip$\r
- { preamble$ write$ newline$ }\r
- if$\r
- "\begin{thebibliography}{" longest.label * "}" *\r
- write$ newline$\r
- "\providecommand{\url}[1]{#1}"\r
- write$ newline$\r
- "\csname url@samestyle\endcsname"\r
- write$ newline$\r
- "\providecommand{\newblock}{\relax}"\r
- write$ newline$\r
- "\providecommand{\bibinfo}[2]{#2}"\r
- write$ newline$\r
- "\providecommand{\BIBentrySTDinterwordspacing}{\spaceskip=0pt\relax}"\r
- write$ newline$\r
- "\providecommand{\BIBentryALTinterwordstretchfactor}{"\r
- ALTinterwordstretchfactor * "}" *\r
- write$ newline$\r
- "\providecommand{\BIBentryALTinterwordspacing}{\spaceskip=\fontdimen2\font plus "\r
- write$ newline$\r
- "\BIBentryALTinterwordstretchfactor\fontdimen3\font minus \fontdimen4\font\relax}"\r
- write$ newline$\r
- "\providecommand{\BIBforeignlanguage}[2]{{%"\r
- write$ newline$\r
- "\expandafter\ifx\csname l@#1\endcsname\relax"\r
- write$ newline$\r
- "\typeout{** WARNING: IEEEtran.bst: No hyphenation pattern has been}%"\r
- write$ newline$\r
- "\typeout{** loaded for the language `#1'. Using the pattern for}%"\r
- write$ newline$\r
- "\typeout{** the default language instead.}%"\r
- write$ newline$\r
- "\else"\r
- write$ newline$\r
- "\language=\csname l@#1\endcsname"\r
- write$ newline$\r
- "\fi"\r
- write$ newline$\r
- "#2}}"\r
- write$ newline$\r
- "\providecommand{\BIBdecl}{\relax}"\r
- write$ newline$\r
- "\BIBdecl"\r
- write$ newline$\r
-}\r
-\r
-FUNCTION {end.bib}\r
-{ newline$ "\end{thebibliography}" write$ newline$ }\r
-\r
-FUNCTION {if.url.alt.interword.spacing}\r
-{ is.use.alt.interword.spacing \r
- {url empty$ 'skip$ {"\BIBentryALTinterwordspacing" write$ newline$} if$}\r
- { skip$ }\r
- if$\r
-}\r
-\r
-FUNCTION {if.url.std.interword.spacing}\r
-{ is.use.alt.interword.spacing \r
- {url empty$ 'skip$ {"\BIBentrySTDinterwordspacing" write$ newline$} if$}\r
- { skip$ }\r
- if$\r
-}\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%%%%\r
-%% LONGEST LABEL PASS %%\r
-%%%%%%%%%%%%%%%%%%%%%%%%\r
-\r
-FUNCTION {initialize.longest.label}\r
-{ "" 'longest.label :=\r
- #1 'number.label :=\r
- #0 'longest.label.width :=\r
-}\r
-\r
-FUNCTION {longest.label.pass}\r
-{ type$ "ieeetranbstctl" =\r
- { skip$ }\r
- { number.label int.to.str$ 'label :=\r
- number.label #1 + 'number.label :=\r
- label width$ longest.label.width >\r
- { label 'longest.label :=\r
- label width$ 'longest.label.width :=\r
- }\r
- { skip$ }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%%\r
-%% FORMAT HANDLERS %%\r
-%%%%%%%%%%%%%%%%%%%%%\r
-\r
-%% Lower Level Formats (used by higher level formats)\r
-\r
-FUNCTION {format.address.org.or.pub.date}\r
-{ 't :=\r
- ""\r
- year empty$\r
- { "empty year in " cite$ * warning$ }\r
- { skip$ }\r
- if$\r
- address empty$ t empty$ and\r
- year empty$ and month empty$ and\r
- { skip$ }\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- address "address" bibinfo.check *\r
- t empty$\r
- { skip$ }\r
- { punct.period 'prev.status.punct :=\r
- space.large 'prev.status.space :=\r
- address empty$\r
- { skip$ }\r
- { ": " * }\r
- if$\r
- t *\r
- }\r
- if$\r
- year empty$ month empty$ and\r
- { skip$ }\r
- { t empty$ address empty$ and\r
- { skip$ }\r
- { ", " * }\r
- if$\r
- month empty$\r
- { year empty$\r
- { skip$ }\r
- { year "year" bibinfo.check * }\r
- if$\r
- }\r
- { month "month" bibinfo.check *\r
- year empty$\r
- { skip$ }\r
- { " " * year "year" bibinfo.check * }\r
- if$\r
- }\r
- if$\r
- }\r
- if$\r
- }\r
- if$\r
-}\r
-\r
-\r
-FUNCTION {format.names}\r
-{ 'bibinfo :=\r
- duplicate$ empty$ 'skip$ {\r
- this.to.prev.status\r
- this.status.std\r
- 's :=\r
- "" 't :=\r
- #1 'nameptr :=\r
- s num.names$ 'numnames :=\r
- numnames 'namesleft :=\r
- { namesleft #0 > }\r
- { s nameptr\r
- name.format.string\r
- format.name$\r
- bibinfo bibinfo.check\r
- 't :=\r
- nameptr #1 >\r
- { nameptr num.names.shown.with.forced.et.al #1 + =\r
- numnames max.num.names.before.forced.et.al >\r
- is.forced.et.al and and\r
- { "others" 't :=\r
- #1 'namesleft :=\r
- }\r
- { skip$ }\r
- if$\r
- namesleft #1 >\r
- { ", " * t do.name.latex.cmd * }\r
- { s nameptr "{ll}" format.name$ duplicate$ "others" =\r
- { 't := }\r
- { pop$ }\r
- if$\r
- t "others" =\r
- { " " * bbl.etal emphasize * }\r
- { numnames #2 >\r
- { "," * }\r
- { skip$ }\r
- if$\r
- bbl.and\r
- space.word * t do.name.latex.cmd *\r
- }\r
- if$\r
- }\r
- if$\r
- }\r
- { t do.name.latex.cmd }\r
- if$\r
- nameptr #1 + 'nameptr :=\r
- namesleft #1 - 'namesleft :=\r
- }\r
- while$\r
- cap.status.std\r
- } if$\r
-}\r
-\r
-\r
-\r
-\r
-%% Higher Level Formats\r
-\r
-%% addresses/locations\r
-\r
-FUNCTION {format.address}\r
-{ address duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% author/editor names\r
-\r
-FUNCTION {format.authors}{ author "author" format.names }\r
-\r
-FUNCTION {format.editors}\r
-{ editor "editor" format.names duplicate$ empty$ 'skip$\r
- { ", " *\r
- get.bbl.editor\r
- capitalize\r
- *\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% date\r
-\r
-FUNCTION {format.date}\r
-{\r
- month "month" bibinfo.check duplicate$ empty$\r
- year "year" bibinfo.check duplicate$ empty$\r
- { swap$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- "there's a month but no year in " cite$ * warning$ }\r
- if$\r
- *\r
- }\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- swap$ 'skip$\r
- {\r
- swap$\r
- " " * swap$\r
- }\r
- if$\r
- *\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.date.electronic}\r
-{ month "month" bibinfo.check duplicate$ empty$\r
- year "year" bibinfo.check duplicate$ empty$\r
- { swap$ \r
- { pop$ }\r
- { "there's a month but no year in " cite$ * warning$\r
- pop$ ")" * "(" swap$ *\r
- this.to.prev.status\r
- punct.no 'this.status.punct :=\r
- space.normal 'this.status.space :=\r
- quote.no 'this.status.quote :=\r
- cap.yes 'status.cap :=\r
- }\r
- if$\r
- }\r
- { swap$ \r
- { swap$ pop$ ")" * "(" swap$ * }\r
- { "(" swap$ * ", " * swap$ * ")" * }\r
- if$\r
- this.to.prev.status\r
- punct.no 'this.status.punct :=\r
- space.normal 'this.status.space :=\r
- quote.no 'this.status.quote :=\r
- cap.yes 'status.cap :=\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% edition/title\r
-\r
-% Note: IEEE considers the edition to be closely associated with\r
-% the title of a book. So, in IEEEtran.bst the edition is normally handled \r
-% within the formatting of the title. The format.edition function is \r
-% retained here for possible future use.\r
-FUNCTION {format.edition}\r
-{ edition duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- convert.edition\r
- status.cap\r
- { "t" }\r
- { "l" }\r
- if$ change.case$\r
- "edition" bibinfo.check\r
- "~" * bbl.edition *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-% This is used to format the booktitle of a conference proceedings.\r
-% Here we use the "intype" field to provide the user a way to \r
-% override the word "in" (e.g., with things like "presented at")\r
-% Use of intype stops the emphasis of the booktitle to indicate that\r
-% we no longer mean the written conference proceedings, but the\r
-% conference itself.\r
-FUNCTION {format.in.booktitle}\r
-{ booktitle "booktitle" bibinfo.check duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- select.language\r
- intype missing$\r
- { emphasize\r
- bbl.in " " *\r
- }\r
- { intype " " * }\r
- if$\r
- swap$ *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-% This is used to format the booktitle of collection.\r
-% Here the "intype" field is not supported, but "edition" is.\r
-FUNCTION {format.in.booktitle.edition}\r
-{ booktitle "booktitle" bibinfo.check duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- select.language\r
- emphasize\r
- edition empty$ 'skip$\r
- { ", " *\r
- edition\r
- convert.edition\r
- "l" change.case$\r
- * "~" * bbl.edition *\r
- }\r
- if$\r
- bbl.in " " * swap$ *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.article.title}\r
-{ title duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- "t" change.case$\r
- }\r
- if$\r
- "title" bibinfo.check\r
- duplicate$ empty$ 'skip$\r
- { quote.close 'this.status.quote :=\r
- is.last.char.not.punct\r
- { punct.std 'this.status.punct := }\r
- { punct.no 'this.status.punct := }\r
- if$\r
- select.language\r
- "``" swap$ *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.article.title.electronic}\r
-{ title duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- "t" change.case$ \r
- }\r
- if$\r
- "title" bibinfo.check\r
- duplicate$ empty$ \r
- { skip$ } \r
- { select.language }\r
- if$\r
-}\r
-\r
-FUNCTION {format.book.title.edition}\r
-{ title "title" bibinfo.check\r
- duplicate$ empty$\r
- { "empty title in " cite$ * warning$ }\r
- { this.to.prev.status\r
- this.status.std\r
- select.language\r
- emphasize\r
- edition empty$ 'skip$\r
- { ", " *\r
- edition\r
- convert.edition\r
- status.cap\r
- { "t" }\r
- { "l" }\r
- if$\r
- change.case$\r
- * "~" * bbl.edition *\r
- }\r
- if$\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.book.title}\r
-{ title "title" bibinfo.check\r
- duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- select.language\r
- emphasize\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% journal\r
-\r
-FUNCTION {format.journal}\r
-{ journal duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- select.language\r
- emphasize\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% how published\r
-\r
-FUNCTION {format.howpublished}\r
-{ howpublished duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% institutions/organization/publishers/school\r
-\r
-FUNCTION {format.institution}\r
-{ institution duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.organization}\r
-{ organization duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.address.publisher.date}\r
-{ publisher "publisher" bibinfo.warn format.address.org.or.pub.date }\r
-\r
-FUNCTION {format.address.publisher.date.nowarn}\r
-{ publisher "publisher" bibinfo.check format.address.org.or.pub.date }\r
-\r
-FUNCTION {format.address.organization.date}\r
-{ organization "organization" bibinfo.check format.address.org.or.pub.date }\r
-\r
-FUNCTION {format.school}\r
-{ school duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% volume/number/series/chapter/pages\r
-\r
-FUNCTION {format.volume}\r
-{ volume empty.field.to.null.string\r
- duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- bbl.volume \r
- status.cap\r
- { capitalize }\r
- { skip$ }\r
- if$\r
- swap$ tie.or.space.prefix\r
- "volume" bibinfo.check\r
- * *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.number}\r
-{ number empty.field.to.null.string\r
- duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- status.cap\r
- { bbl.number capitalize }\r
- { bbl.number }\r
- if$\r
- swap$ tie.or.space.prefix\r
- "number" bibinfo.check\r
- * *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-FUNCTION {format.number.if.use.for.article}\r
-{ is.use.number.for.article \r
- { format.number }\r
- { "" }\r
- if$\r
-}\r
-\r
-% IEEE does not seem to tie the series so closely with the volume\r
-% and number as is done in other bibliography styles. Instead the\r
-% series is treated somewhat like an extension of the title.\r
-FUNCTION {format.series}\r
-{ series empty$ \r
- { "" }\r
- { this.to.prev.status\r
- this.status.std\r
- bbl.series " " *\r
- series "series" bibinfo.check *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-\r
-FUNCTION {format.chapter}\r
-{ chapter empty$\r
- { "" }\r
- { this.to.prev.status\r
- this.status.std\r
- type empty$\r
- { bbl.chapter }\r
- { type "l" change.case$\r
- "type" bibinfo.check\r
- }\r
- if$\r
- chapter tie.or.space.prefix\r
- "chapter" bibinfo.check\r
- * *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-\r
-% The intended use of format.paper is for paper numbers of inproceedings.\r
-% The paper type can be overridden via the type field.\r
-% We allow the type to be displayed even if the paper number is absent\r
-% for things like "postdeadline paper"\r
-FUNCTION {format.paper}\r
-{ is.use.paper\r
- { paper empty$\r
- { type empty$\r
- { "" }\r
- { this.to.prev.status\r
- this.status.std\r
- type "type" bibinfo.check\r
- cap.status.std\r
- }\r
- if$\r
- }\r
- { this.to.prev.status\r
- this.status.std\r
- type empty$\r
- { bbl.paper }\r
- { type "type" bibinfo.check }\r
- if$\r
- " " * paper\r
- "paper" bibinfo.check\r
- *\r
- cap.status.std\r
- }\r
- if$\r
- }\r
- { "" } \r
- if$\r
-}\r
-\r
-\r
-FUNCTION {format.pages}\r
-{ pages duplicate$ empty$ 'skip$\r
- { this.to.prev.status\r
- this.status.std\r
- duplicate$ is.multiple.pages\r
- {\r
- bbl.pages swap$\r
- n.dashify\r
- }\r
- {\r
- bbl.page swap$\r
- }\r
- if$\r
- tie.or.space.prefix\r
- "pages" bibinfo.check\r
- * *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% technical report number\r
-\r
-FUNCTION {format.tech.report.number}\r
-{ number "number" bibinfo.check\r
- this.to.prev.status\r
- this.status.std\r
- cap.status.std\r
- type duplicate$ empty$\r
- { pop$ \r
- bbl.techrep\r
- }\r
- { skip$ }\r
- if$\r
- "type" bibinfo.check \r
- swap$ duplicate$ empty$\r
- { pop$ }\r
- { tie.or.space.prefix * * }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% note\r
-\r
-FUNCTION {format.note}\r
-{ note empty$\r
- { "" }\r
- { this.to.prev.status\r
- this.status.std\r
- punct.period 'this.status.punct :=\r
- note #1 #1 substring$\r
- duplicate$ "{" =\r
- { skip$ }\r
- { status.cap\r
- { "u" }\r
- { "l" }\r
- if$\r
- change.case$\r
- }\r
- if$\r
- note #2 global.max$ substring$ * "note" bibinfo.check\r
- cap.yes 'status.cap :=\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-%% patent\r
-\r
-FUNCTION {format.patent.date}\r
-{ this.to.prev.status\r
- this.status.std\r
- year empty$\r
- { monthfiled duplicate$ empty$\r
- { "monthfiled" bibinfo.check pop$ "" }\r
- { "monthfiled" bibinfo.check }\r
- if$\r
- dayfiled duplicate$ empty$\r
- { "dayfiled" bibinfo.check pop$ "" * }\r
- { "dayfiled" bibinfo.check \r
- monthfiled empty$ \r
- { "dayfiled without a monthfiled in " cite$ * warning$\r
- * \r
- }\r
- { " " swap$ * * }\r
- if$\r
- }\r
- if$\r
- yearfiled empty$\r
- { "no year or yearfiled in " cite$ * warning$ }\r
- { yearfiled "yearfiled" bibinfo.check \r
- swap$\r
- duplicate$ empty$\r
- { pop$ }\r
- { ", " * swap$ * }\r
- if$\r
- }\r
- if$\r
- }\r
- { month duplicate$ empty$\r
- { "month" bibinfo.check pop$ "" }\r
- { "month" bibinfo.check }\r
- if$\r
- day duplicate$ empty$\r
- { "day" bibinfo.check pop$ "" * }\r
- { "day" bibinfo.check \r
- month empty$ \r
- { "day without a month in " cite$ * warning$\r
- * \r
- }\r
- { " " swap$ * * }\r
- if$\r
- }\r
- if$\r
- year "year" bibinfo.check \r
- swap$\r
- duplicate$ empty$\r
- { pop$ }\r
- { ", " * swap$ * }\r
- if$\r
- }\r
- if$\r
- cap.status.std\r
-}\r
-\r
-FUNCTION {format.patent.nationality.type.number}\r
-{ this.to.prev.status\r
- this.status.std\r
- nationality duplicate$ empty$\r
- { "nationality" bibinfo.warn pop$ "" }\r
- { "nationality" bibinfo.check\r
- duplicate$ "l" change.case$ "united states" =\r
- { pop$ bbl.patentUS }\r
- { skip$ }\r
- if$\r
- " " *\r
- }\r
- if$\r
- type empty$\r
- { bbl.patent "type" bibinfo.check }\r
- { type "type" bibinfo.check }\r
- if$ \r
- *\r
- number duplicate$ empty$\r
- { "number" bibinfo.warn pop$ }\r
- { "number" bibinfo.check\r
- large.number.separate\r
- swap$ " " * swap$ *\r
- }\r
- if$ \r
- cap.status.std\r
-}\r
-\r
-\r
-\r
-%% standard\r
-\r
-FUNCTION {format.organization.institution.standard.type.number}\r
-{ this.to.prev.status\r
- this.status.std\r
- organization duplicate$ empty$\r
- { pop$ \r
- institution duplicate$ empty$\r
- { "institution" bibinfo.warn }\r
- { "institution" bibinfo.warn " " * }\r
- if$\r
- }\r
- { "organization" bibinfo.warn " " * }\r
- if$\r
- type empty$\r
- { bbl.standard "type" bibinfo.check }\r
- { type "type" bibinfo.check }\r
- if$ \r
- *\r
- number duplicate$ empty$\r
- { "number" bibinfo.check pop$ }\r
- { "number" bibinfo.check\r
- large.number.separate\r
- swap$ " " * swap$ *\r
- }\r
- if$ \r
- cap.status.std\r
-}\r
-\r
-FUNCTION {format.revision}\r
-{ revision empty$\r
- { "" }\r
- { this.to.prev.status\r
- this.status.std\r
- bbl.revision\r
- revision tie.or.space.prefix\r
- "revision" bibinfo.check\r
- * *\r
- cap.status.std\r
- }\r
- if$\r
-}\r
-\r
-\r
-%% thesis\r
-\r
-FUNCTION {format.master.thesis.type}\r
-{ this.to.prev.status\r
- this.status.std\r
- type empty$\r
- {\r
- bbl.mthesis\r
- }\r
- { \r
- type "type" bibinfo.check\r
- }\r
- if$\r
-cap.status.std\r
-}\r
-\r
-FUNCTION {format.phd.thesis.type}\r
-{ this.to.prev.status\r
- this.status.std\r
- type empty$\r
- {\r
- bbl.phdthesis\r
- }\r
- { \r
- type "type" bibinfo.check\r
- }\r
- if$\r
-cap.status.std\r
-}\r
-\r
-\r
-\r
-%% URL\r
-\r
-FUNCTION {format.url}\r
-{ url empty$\r
- { "" }\r
- { this.to.prev.status\r
- this.status.std\r
- cap.yes 'status.cap :=\r
- name.url.prefix " " *\r
- "\url{" * url * "}" *\r
- punct.no 'this.status.punct :=\r
- punct.period 'prev.status.punct :=\r
- space.normal 'this.status.space :=\r
- space.normal 'prev.status.space :=\r
- quote.no 'this.status.quote :=\r
- }\r
- if$\r
-}\r
-\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%%\r
-%% ENTRY HANDLERS %%\r
-%%%%%%%%%%%%%%%%%%%%\r
-\r
-\r
-% Note: In many journals, IEEE (or the authors) tend not to show the number\r
-% for articles, so the display of the number is controlled here by the\r
-% switch "is.use.number.for.article"\r
-FUNCTION {article}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors "author" output.warn\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.journal "journal" bibinfo.check "journal" output.warn\r
- format.volume output\r
- format.number.if.use.for.article output\r
- format.pages output\r
- format.date "year" output.warn\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {book}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- author empty$\r
- { format.editors "author and editor" output.warn }\r
- { format.authors output.nonnull }\r
- if$\r
- name.or.dash\r
- format.book.title.edition output\r
- format.series output\r
- author empty$\r
- { skip$ }\r
- { format.editors output }\r
- if$\r
- format.address.publisher.date output\r
- format.volume output\r
- format.number output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {booklet}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors output\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.howpublished "howpublished" bibinfo.check output\r
- format.organization "organization" bibinfo.check output\r
- format.address "address" bibinfo.check output\r
- format.date output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {electronic}\r
-{ std.status.using.period\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors output\r
- name.or.dash\r
- format.date.electronic output\r
- format.article.title.electronic output\r
- format.howpublished "howpublished" bibinfo.check output\r
- format.organization "organization" bibinfo.check output\r
- format.address "address" bibinfo.check output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- empty.entry.warn\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {inbook}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- author empty$\r
- { format.editors "author and editor" output.warn }\r
- { format.authors output.nonnull }\r
- if$\r
- name.or.dash\r
- format.book.title.edition output\r
- format.series output\r
- format.address.publisher.date output\r
- format.volume output\r
- format.number output\r
- format.chapter output\r
- format.pages output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {incollection}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors "author" output.warn\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.in.booktitle.edition "booktitle" output.warn\r
- format.series output\r
- format.editors output\r
- format.address.publisher.date.nowarn output\r
- format.volume output\r
- format.number output\r
- format.chapter output\r
- format.pages output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {inproceedings}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors "author" output.warn\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.in.booktitle "booktitle" output.warn\r
- format.series output\r
- format.editors output\r
- format.volume output\r
- format.number output\r
- publisher empty$\r
- { format.address.organization.date output }\r
- { format.organization "organization" bibinfo.check output\r
- format.address.publisher.date output\r
- }\r
- if$\r
- format.paper output\r
- format.pages output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {manual}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors output\r
- name.or.dash\r
- format.book.title.edition "title" output.warn\r
- format.howpublished "howpublished" bibinfo.check output \r
- format.organization "organization" bibinfo.check output\r
- format.address "address" bibinfo.check output\r
- format.date output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {mastersthesis}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors "author" output.warn\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.master.thesis.type output.nonnull\r
- format.school "school" bibinfo.warn output\r
- format.address "address" bibinfo.check output\r
- format.date "year" output.warn\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {misc}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors output\r
- name.or.dash\r
- format.article.title output\r
- format.howpublished "howpublished" bibinfo.check output \r
- format.organization "organization" bibinfo.check output\r
- format.address "address" bibinfo.check output\r
- format.pages output\r
- format.date output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- empty.entry.warn\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {patent}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors output\r
- name.or.dash\r
- format.article.title output\r
- format.patent.nationality.type.number output\r
- format.patent.date output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- empty.entry.warn\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {periodical}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.editors output\r
- name.or.dash\r
- format.book.title "title" output.warn\r
- format.series output\r
- format.volume output\r
- format.number output\r
- format.organization "organization" bibinfo.check output\r
- format.date "year" output.warn\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {phdthesis}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors "author" output.warn\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.phd.thesis.type output.nonnull\r
- format.school "school" bibinfo.warn output\r
- format.address "address" bibinfo.check output\r
- format.date "year" output.warn\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {proceedings}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.editors output\r
- name.or.dash\r
- format.book.title "title" output.warn\r
- format.series output\r
- format.volume output\r
- format.number output\r
- publisher empty$\r
- { format.address.organization.date output }\r
- { format.organization "organization" bibinfo.check output\r
- format.address.publisher.date output\r
- }\r
- if$\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {standard}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors output\r
- name.or.dash\r
- format.book.title "title" output.warn\r
- format.howpublished "howpublished" bibinfo.check output \r
- format.organization.institution.standard.type.number output\r
- format.revision output\r
- format.date output\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {techreport}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors "author" output.warn\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.howpublished "howpublished" bibinfo.check output \r
- format.institution "institution" bibinfo.warn output\r
- format.address "address" bibinfo.check output\r
- format.tech.report.number output.nonnull\r
- format.date "year" output.warn\r
- format.note output\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-FUNCTION {unpublished}\r
-{ std.status.using.comma\r
- start.entry\r
- if.url.alt.interword.spacing\r
- format.authors "author" output.warn\r
- name.or.dash\r
- format.article.title "title" output.warn\r
- format.date output\r
- format.note "note" output.warn\r
- format.url output\r
- fin.entry\r
- if.url.std.interword.spacing\r
-}\r
-\r
-\r
-% The special entry type which provides the user interface to the\r
-% BST controls\r
-FUNCTION {IEEEtranBSTCTL}\r
-{ is.print.banners.to.terminal\r
- { "** IEEEtran BST control entry " quote$ * cite$ * quote$ * " detected." *\r
- top$\r
- }\r
- { skip$ }\r
- if$\r
- CTLuse_article_number\r
- empty$\r
- { skip$ }\r
- { CTLuse_article_number\r
- yes.no.to.int\r
- 'is.use.number.for.article :=\r
- }\r
- if$\r
- CTLuse_paper\r
- empty$\r
- { skip$ }\r
- { CTLuse_paper\r
- yes.no.to.int\r
- 'is.use.paper :=\r
- }\r
- if$\r
- CTLuse_forced_etal\r
- empty$\r
- { skip$ }\r
- { CTLuse_forced_etal\r
- yes.no.to.int\r
- 'is.forced.et.al :=\r
- }\r
- if$\r
- CTLmax_names_forced_etal\r
- empty$\r
- { skip$ }\r
- { CTLmax_names_forced_etal\r
- string.to.integer\r
- 'max.num.names.before.forced.et.al :=\r
- }\r
- if$\r
- CTLnames_show_etal\r
- empty$\r
- { skip$ }\r
- { CTLnames_show_etal\r
- string.to.integer\r
- 'num.names.shown.with.forced.et.al :=\r
- }\r
- if$\r
- CTLuse_alt_spacing\r
- empty$\r
- { skip$ }\r
- { CTLuse_alt_spacing\r
- yes.no.to.int\r
- 'is.use.alt.interword.spacing :=\r
- }\r
- if$\r
- CTLalt_stretch_factor\r
- empty$\r
- { skip$ }\r
- { CTLalt_stretch_factor\r
- 'ALTinterwordstretchfactor :=\r
- "\renewcommand{\BIBentryALTinterwordstretchfactor}{"\r
- ALTinterwordstretchfactor * "}" *\r
- write$ newline$\r
- }\r
- if$\r
- CTLdash_repeated_names\r
- empty$\r
- { skip$ }\r
- { CTLdash_repeated_names\r
- yes.no.to.int\r
- 'is.dash.repeated.names :=\r
- }\r
- if$\r
- CTLname_format_string\r
- empty$\r
- { skip$ }\r
- { CTLname_format_string\r
- 'name.format.string :=\r
- }\r
- if$\r
- CTLname_latex_cmd\r
- empty$\r
- { skip$ }\r
- { CTLname_latex_cmd\r
- 'name.latex.cmd :=\r
- }\r
- if$\r
- CTLname_url_prefix\r
- missing$\r
- { skip$ }\r
- { CTLname_url_prefix\r
- 'name.url.prefix :=\r
- }\r
- if$\r
-\r
-\r
- num.names.shown.with.forced.et.al max.num.names.before.forced.et.al >\r
- { "CTLnames_show_etal cannot be greater than CTLmax_names_forced_etal in " cite$ * warning$ \r
- max.num.names.before.forced.et.al 'num.names.shown.with.forced.et.al :=\r
- }\r
- { skip$ }\r
- if$\r
-}\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%%\r
-%% ENTRY ALIASES %%\r
-%%%%%%%%%%%%%%%%%%%\r
-FUNCTION {conference}{inproceedings}\r
-FUNCTION {online}{electronic}\r
-FUNCTION {internet}{electronic}\r
-FUNCTION {webpage}{electronic}\r
-FUNCTION {www}{electronic}\r
-FUNCTION {default.type}{misc}\r
-\r
-\r
-\r
-%%%%%%%%%%%%%%%%%%\r
-%% MAIN PROGRAM %%\r
-%%%%%%%%%%%%%%%%%%\r
-\r
-READ\r
-\r
-EXECUTE {initialize.controls}\r
-EXECUTE {initialize.status.constants}\r
-EXECUTE {banner.message}\r
-\r
-EXECUTE {initialize.longest.label}\r
-ITERATE {longest.label.pass}\r
-\r
-EXECUTE {begin.bib}\r
-ITERATE {call.type$}\r
-EXECUTE {end.bib}\r
-\r
-EXECUTE{completed.message}\r
-\r
-\r
-%% That's all folks, mds.\r