texlive[50504] Master/texmf-dist: gbt7714 (21mar19)
commits+karl at tug.org
commits+karl at tug.org
Thu Mar 21 21:45:45 CET 2019
Revision: 50504
http://tug.org/svn/texlive?view=revision&revision=50504
Author: karl
Date: 2019-03-21 21:45:44 +0100 (Thu, 21 Mar 2019)
Log Message:
-----------
gbt7714 (21mar19)
Modified Paths:
--------------
trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-plain.bst
trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-unsrt.bst
trunk/Master/texmf-dist/doc/bibtex/gbt7714/README.md
trunk/Master/texmf-dist/doc/bibtex/gbt7714/gbt7714.pdf
trunk/Master/texmf-dist/source/bibtex/gbt7714/gbt7714.dtx
trunk/Master/texmf-dist/tex/latex/gbt7714/gbt7714.sty
Added Paths:
-----------
trunk/Master/texmf-dist/doc/bibtex/gbt7714/y.tex
Removed Paths:
-------------
trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-plain.bst
trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-unsrt.bst
Deleted: trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-plain.bst
===================================================================
--- trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-plain.bst 2019-03-21 20:24:13 UTC (rev 50503)
+++ trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-plain.bst 2019-03-21 20:45:44 UTC (rev 50504)
@@ -1,1924 +0,0 @@
-%%
-%% This is file `gbt7714-2005-plain.bst',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% gbt7714.dtx (with options: `2005,authoryear')
-%% Version: 2018/08/05 v1.0.9
-%%
-%% Copyright (C) 2016-2018 by Zeping Lee <zepinglee AT gmail.com>
-%%
-%% This file may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% https://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2005/12/01 or later.
-%%
-
-INTEGERS {
- uppercase.name
- max.num.authors
- period.between.author.year
- sentence.case.title
- link.title
- show.mark
- italic.jounal
- show.missing.address.publisher
- show.url
- show.doi
- show.note
-}
-
-FUNCTION {load.config}
-{
- #1 'uppercase.name :=
- #3 'max.num.authors :=
- #0 'period.between.author.year :=
- #1 'sentence.case.title :=
- #0 'link.title :=
- #1 'show.mark :=
- #0 'italic.jounal :=
- #1 'show.missing.address.publisher :=
- #1 'show.url :=
- #0 'show.doi :=
- #0 'show.note :=
-}
-
-ENTRY
- { address
- author
- booktitle
- date
- doi
- edition
- editor
- howpublished
- institution
- journal
- key
- language
- mark
- medium
- note
- number
- organization
- pages
- publisher
- school
- series
- title
- translator
- url
- urldate
- volume
- year
- }
- { entry.lang entry.is.electronic }
- { label extra.label sort.label short.list entry.mark entry.url }
-
-INTEGERS { output.state before.all mid.sentence after.sentence after.block after.slash }
-
-INTEGERS { lang.zh lang.ja lang.en lang.ru lang.other }
-
-INTEGERS { charptr len }
-
-FUNCTION {init.state.consts}
-{ #0 'before.all :=
- #1 'mid.sentence :=
- #2 'after.sentence :=
- #3 'after.block :=
- #4 'after.slash :=
- #3 'lang.zh :=
- #4 'lang.ja :=
- #1 'lang.en :=
- #2 'lang.ru :=
- #0 'lang.other :=
-}
-
-FUNCTION {bbl.anonymous}
-{ lang.zh entry.lang =
- { "佚名" }
- { "Anon" }
- if$
-}
-
-FUNCTION {bbl.space} { "\ " }
-
-FUNCTION {bbl.et.al}
-{ lang.zh entry.lang =
- { "等" }
- { lang.ja entry.lang =
- { "他" }
- { lang.ru entry.lang =
- { "идр" }
- { "et~al." }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {bbl.colon} { ": " }
-
-FUNCTION {bbl.wide.space} { "\ " }
-
-FUNCTION {bbl.slash} { "//\allowbreak{}" }
-
-FUNCTION {bbl.sine.loco}
-{ lang.zh entry.lang =
- { "[出版地不详]" }
- { "[S.l.]" }
- if$
-}
-
-FUNCTION {bbl.sine.nomine}
-{ lang.zh entry.lang =
- { "[出版者不详]" }
- { "[s.n.]" }
- if$
-}
-
-FUNCTION {bbl.sine.loco.sine.nomine}
-{ lang.zh entry.lang =
- { "[出版地不详: 出版者不详]" }
- { "[S.l.: s.n.]" }
- if$
-}
-
-FUNCTION {not}
-{ { #0 }
- { #1 }
- if$
-}
-
-FUNCTION {and}
-{ 'skip$
- { pop$ #0 }
- if$
-}
-
-FUNCTION {or}
-{ { pop$ #1 }
- 'skip$
- if$
-}
-
-STRINGS { s t }
-
-FUNCTION {output.nonnull}
-{ 's :=
- output.state mid.sentence =
- { ", " * write$ }
- { output.state after.block =
- { add.period$ write$
- newline$
- "\newblock " write$
- }
- { output.state before.all =
- 'write$
- { output.state after.slash =
- { bbl.slash * write$ }
- { add.period$ " " * write$ }
- if$
- }
- if$
- }
- if$
- mid.sentence 'output.state :=
- }
- if$
- s
-}
-
-FUNCTION {output}
-{ duplicate$ empty$
- 'pop$
- 'output.nonnull
- if$
-}
-
-FUNCTION {output.after}
-{ 't :=
- duplicate$ empty$
- 'pop$
- { 's :=
- output.state mid.sentence =
- { t * write$ }
- { output.state after.block =
- { add.period$ write$
- newline$
- "\newblock " write$
- }
- { output.state before.all =
- 'write$
- { output.state after.slash =
- { bbl.slash * write$ }
- { add.period$ " " * write$ }
- if$
- }
- if$
- }
- if$
- mid.sentence 'output.state :=
- }
- if$
- s
- }
- if$
-}
-
-FUNCTION {output.check}
-{ 't :=
- duplicate$ empty$
- { pop$ "empty " t * " in " * cite$ * warning$ }
- 'output.nonnull
- if$
-}
-
-FUNCTION {fin.entry}
-{ add.period$
- write$
- newline$
-}
-
-FUNCTION {new.block}
-{ output.state before.all =
- 'skip$
- { output.state after.slash =
- 'skip$
- { after.block 'output.state := }
- if$
- }
- if$
-}
-
-FUNCTION {new.sentence}
-{ output.state after.block =
- 'skip$
- { output.state before.all =
- 'skip$
- { output.state after.slash =
- 'skip$
- { after.sentence 'output.state := }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {new.slash}
-{ output.state before.all =
- 'skip$
- { after.slash 'output.state := }
- if$
-}
-
-FUNCTION {new.block.checka}
-{ empty$
- 'skip$
- 'new.block
- if$
-}
-
-FUNCTION {new.block.checkb}
-{ empty$
- swap$ empty$
- and
- 'skip$
- 'new.block
- if$
-}
-
-FUNCTION {new.sentence.checka}
-{ empty$
- 'skip$
- 'new.sentence
- if$
-}
-
-FUNCTION {new.sentence.checkb}
-{ empty$
- swap$ empty$
- and
- 'skip$
- 'new.sentence
- if$
-}
-
-FUNCTION {field.or.null}
-{ duplicate$ empty$
- { pop$ "" }
- 'skip$
- if$
-}
-
-FUNCTION {italicize}
-{ duplicate$ empty$
- { pop$ "" }
- { "\textit{" swap$ * "}" * }
- if$
-}
-
-INTEGERS { byte second.byte }
-
-INTEGERS { char.lang tmp.lang }
-
-STRINGS { tmp.str }
-
-FUNCTION {get.str.lang}
-{ 'tmp.str :=
- lang.other 'tmp.lang :=
- #1 'charptr :=
- tmp.str text.length$ #1 + 'len :=
- { charptr len < }
- { tmp.str charptr #1 substring$ chr.to.int$ 'byte :=
- byte #128 <
- { charptr #1 + 'charptr :=
- byte #64 > byte #91 < and byte #96 > byte #123 < and or
- { lang.en 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- { tmp.str charptr #1 + #1 substring$ chr.to.int$ 'second.byte :=
- byte #224 <
- { charptr #2 + 'charptr :=
- byte #207 > byte #212 < and
- byte #212 = second.byte #176 < and or
- { lang.ru 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- { byte #240 <
- { charptr #3 + 'charptr :=
- byte #227 > byte #234 < and
- { lang.zh 'char.lang := }
- { byte #227 =
- { second.byte #143 >
- { lang.zh 'char.lang := }
- { second.byte #128 > second.byte #132 < and
- { lang.ja 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- if$
- }
- { byte #239 =
- second.byte #163 > second.byte #172 < and and
- { lang.zh 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- if$
- }
- if$
- }
- { charptr #4 + 'charptr :=
- byte #240 = second.byte #159 > and
- { lang.zh 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- if$
- }
- if$
- }
- if$
- char.lang tmp.lang >
- { char.lang 'tmp.lang := }
- 'skip$
- if$
- }
- while$
- tmp.lang
-}
-
-FUNCTION {check.entry.lang}
-{ author field.or.null
- title field.or.null *
- get.str.lang
-}
-
-FUNCTION {set.entry.lang}
-{ language empty$
- { check.entry.lang }
- { language "english" = language "american" = or language "british" = or
- { lang.en }
- { language "chinese" =
- { lang.zh }
- { language "japanese" =
- { lang.ja }
- { language "russian" =
- { lang.ru }
- { check.entry.lang }
- if$
- }
- if$
- }
- if$
- }
- if$
- }
- if$
- 'entry.lang :=
-}
-
-INTEGERS { nameptr namesleft numnames name.lang }
-
-FUNCTION {format.names}
-{ 's :=
- #1 'nameptr :=
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
- nameptr max.num.authors >
- { bbl.et.al
- #1 'namesleft :=
- }
- { t "others" =
- { bbl.et.al }
- { t get.str.lang 'name.lang :=
- name.lang lang.en =
- { t #1 "{vv~}{ll}{~f{~}}" format.name$
- uppercase.name
- { "u" change.case$ }
- 'skip$
- if$
- t #1 "{, jj}" format.name$ *
- }
- { t #1 "{ll}{ff}" format.name$ }
- if$
- }
- if$
- }
- if$
- nameptr #1 >
- { ", " swap$ * * }
- 'skip$
- if$
- nameptr #1 + 'nameptr :=
- namesleft #1 - 'namesleft :=
- }
- while$
-}
-
-FUNCTION {format.key}
-{ empty$
- { key field.or.null }
- { "" }
- if$
-}
-
-FUNCTION {format.authors}
-{ author empty$
- { bbl.anonymous }
- { author format.names }
- if$
-}
-
-FUNCTION {format.editors}
-{ editor empty$
- { "" }
- { editor format.names }
- if$
-}
-
-FUNCTION {format.translators}
-{ translator empty$
- { "" }
- { translator format.names
- lang.zh entry.lang =
- { translator num.names$ #3 >
- { "译" * }
- { ", 译" * }
- if$
- }
- 'skip$
- if$
- }
- if$
-}
-
-FUNCTION {format.full.names}
-{'s :=
- #1 'nameptr :=
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
- t get.str.lang 'name.lang :=
- name.lang lang.en =
- { t #1 "{vv~}{ll}" format.name$ 't := }
- { t #1 "{ll}{ff}" format.name$ 't := }
- if$
- nameptr #1 >
- {
- namesleft #1 >
- { ", " * t * }
- {
- numnames #2 >
- { "," * }
- 'skip$
- if$
- t "others" =
- { " et~al." * }
- { " and " * t * }
- if$
- }
- if$
- }
- 't
- if$
- nameptr #1 + 'nameptr :=
- namesleft #1 - 'namesleft :=
- }
- while$
-}
-
-FUNCTION {author.editor.full}
-{ author empty$
- { editor empty$
- { "" }
- { editor format.full.names }
- if$
- }
- { author format.full.names }
- if$
-}
-
-FUNCTION {author.full}
-{ author empty$
- { "" }
- { author format.full.names }
- if$
-}
-
-FUNCTION {editor.full}
-{ editor empty$
- { "" }
- { editor format.full.names }
- if$
-}
-
-FUNCTION {make.full.names}
-{ type$ "book" =
- type$ "inbook" =
- or
- 'author.editor.full
- { type$ "collection" =
- type$ "proceedings" =
- or
- 'editor.full
- 'author.full
- if$
- }
- if$
-}
-
-FUNCTION {output.bibitem}
-{ newline$
- "\bibitem[" write$
- label write$
- ")" make.full.names duplicate$ short.list =
- { pop$ }
- { * }
- if$
- "]{" * write$
- cite$ write$
- "}" write$
- newline$
- ""
- before.all 'output.state :=
-}
-
-FUNCTION {change.sentence.case}
-{ entry.lang lang.en =
- { "t" change.case$ }
- 'skip$
- if$
-}
-
-FUNCTION {add.link}
- { url empty$ not
- { "\href{" url * "}{" * swap$ * "}" * }
- { doi empty$ not
- { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
- 'skip$
- if$
- }
- if$
- }
-
-FUNCTION {format.title}
-{ title empty$
- { "" }
- { title
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- link.title
- 'add.link
- 'skip$
- if$
- }
- if$
-}
-
-FUNCTION {tie.or.space.connect}
-{ duplicate$ text.length$ #3 <
- { "~" }
- { " " }
- if$
- swap$ * *
-}
-
-FUNCTION {either.or.check}
-{ empty$
- 'pop$
- { "can't use both " swap$ * " fields in " * cite$ * warning$ }
- if$
-}
-
-FUNCTION {is.digit}
-{ duplicate$ empty$
- { pop$ #0 }
- { chr.to.int$
- duplicate$ "0" chr.to.int$ <
- { pop$ #0 }
- { "9" chr.to.int$ >
- { #0 }
- { #1 }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {is.number}
-{ 's :=
- s empty$
- { #0 }
- { s text.length$ 'charptr :=
- { charptr #0 >
- s charptr #1 substring$ is.digit
- and
- }
- { charptr #1 - 'charptr := }
- while$
- charptr not
- }
- if$
-}
-
-FUNCTION {format.volume}
-{ volume empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " volume * " 卷" * }
- { "volume" volume tie.or.space.connect }
- if$
- }
- if$
-}
-
-FUNCTION {format.number}
-{ number empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " number * " 册" * }
- { "number" number tie.or.space.connect }
- if$
- }
- if$
-}
-
-FUNCTION {format.volume.number}
-{ volume empty$ not
- { format.volume }
- { format.number }
- if$
-}
-
-FUNCTION {format.series.vol.num.title}
-{ format.volume.number 's :=
- series empty$ not
- { series
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- bbl.colon *
- s empty$ not
- { s * bbl.wide.space * }
- 'skip$
- if$
- title
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- *
- }
- { title
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- s empty$ not
- { bbl.colon * s * }
- 'skip$
- if$
- }
- if$
- link.title
- 'add.link
- 'skip$
- if$
-}
-
-FUNCTION {format.series.vol.num.booktitle}
-{ format.volume.number 's :=
- series empty$ not
- { series bbl.colon *
- s empty$ not
- { s * bbl.wide.space * }
- 'skip$
- if$
- booktitle *
- }
- { booktitle
- s empty$ not
- { bbl.colon * s * }
- 'skip$
- if$
- }
- if$
-}
-
-FUNCTION {format.journal}
-{ journal
- italic.jounal
- 'italicize
- 'skip$
- if$
-}
-
-FUNCTION {set.entry.mark}
-{ entry.mark empty$ not
- 'pop$
- { mark empty$ not
- { pop$ mark 'entry.mark := }
- { 'entry.mark := }
- if$
- }
- if$
-}
-
-FUNCTION {format.mark}
-{ show.mark
- { medium empty$ not
- { entry.mark "/" * medium * 'entry.mark := }
- { entry.is.electronic
- { entry.mark "/OL" * 'entry.mark := }
- 'skip$
- if$
- }
- if$
- "\allowbreak[" entry.mark * "]" *
- }
- { "" }
- if$
-}
-
-FUNCTION {num.to.ordinal}
-{ duplicate$ text.length$ 'charptr :=
- duplicate$ charptr #1 substring$ 's :=
- s "1" =
- { "st" * }
- { s "2" =
- { "nd" * }
- { s "3" =
- { "rd" * }
- { "th" * }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.edition}
-{ edition empty$
- { "" }
- { edition is.number
- { lang.zh entry.lang =
- { edition " 版" * }
- { edition num.to.ordinal " ed." * }
- if$
- }
- { entry.lang lang.en =
- { edition change.sentence.case 's :=
- s "Revised" = s "Revised edition" = or
- { "Rev. ed." }
- { s " ed." *}
- if$
- }
- { edition }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.publisher}
-{ publisher empty$ not
- { publisher }
- { school empty$ not
- { school }
- { organization empty$ not
- { organization }
- { institution empty$ not
- { institution }
- { "" }
- if$
- }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.address.publisher}
-{ address empty$ not
- { address
- format.publisher empty$ not
- { bbl.colon * format.publisher * }
- { entry.is.electronic not show.missing.address.publisher and
- { bbl.colon * bbl.sine.nomine * }
- 'skip$
- if$
- }
- if$
- }
- { entry.is.electronic not show.missing.address.publisher and
- { format.publisher empty$ not
- { bbl.sine.loco bbl.colon * format.publisher * }
- { bbl.sine.loco.sine.nomine }
- if$
- }
- { format.publisher empty$ not
- { format.publisher }
- { "" }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {extract.before.dash}
-{ duplicate$ empty$
- { pop$ "" }
- { 's :=
- #1 'charptr :=
- s text.length$ #1 + 'len :=
- { charptr len <
- s charptr #1 substring$ "-" = not
- and
- }
- { charptr #1 + 'charptr := }
- while$
- s #1 charptr #1 - substring$
- }
- if$
-}
-
-FUNCTION {extract.after.dash}
-{ duplicate$ empty$
- { pop$ "" }
- { 's :=
- #1 'charptr :=
- s text.length$ #1 + 'len :=
- { charptr len <
- s charptr #1 substring$ "-" = not
- and
- }
- { charptr #1 + 'charptr := }
- while$
- { charptr len <
- s charptr #1 substring$ "-" =
- and
- }
- { charptr #1 + 'charptr := }
- while$
- s charptr global.max$ substring$
- }
- if$
-}
-
-FUNCTION {contains.dash}
-{ duplicate$ empty$
- { pop$ #0 }
- { 's :=
- { s empty$ not
- s #1 #1 substring$ "-" = not
- and
- }
- { s #2 global.max$ substring$ 's := }
- while$
- s empty$ not
- }
- if$
-}
-
-FUNCTION {format.year}
-{ year empty$ not
- { year extract.before.dash }
- { date empty$ not
- { date extract.before.dash }
- { "empty year in " cite$ * warning$
- ""
- }
- if$
- }
- if$
- extra.label *
-}
-
-FUNCTION {format.date}
-{ type$ "patent" = type$ "newspaper" = or
- date empty$ not and
- { date }
- { year }
- if$
-}
-
-FUNCTION {format.editdate}
-{ date empty$ not
- { "\allowbreak(" date * ")" * }
- { "" }
- if$
-}
-
-FUNCTION {format.urldate}
-{ urldate empty$ not entry.is.electronic and
- { "\allowbreak[" urldate * "]" * }
- { "" }
- if$
-}
-
-FUNCTION {hyphenate}
-{ 't :=
- ""
- { t empty$ not }
- { t #1 #1 substring$ "-" =
- { "-" *
- { t #1 #1 substring$ "-" = }
- { t #2 global.max$ substring$ 't := }
- while$
- }
- { t #1 #1 substring$ *
- t #2 global.max$ substring$ 't :=
- }
- if$
- }
- while$
-}
-
-FUNCTION {format.pages}
-{ pages empty$
- { "" }
- { pages hyphenate }
- if$
-}
-
-FUNCTION {format.journal.number}
-{ number empty$ not
- { "\penalty0 (" number * ")" * }
- { "" }
- if$
-}
-
-FUNCTION {format.journal.pages}
-{ pages empty$
- { "" }
- { ":\penalty0 " pages hyphenate * }
- if$
-}
-
-FUNCTION {format.periodical.year.volume.number}
-{ year empty$ not
- { year extract.before.dash }
- { "empty year in periodical " cite$ * warning$ }
- if$
- volume empty$ not
- { ", " * volume extract.before.dash * }
- 'skip$
- if$
- number empty$ not
- { "\penalty0 (" * number extract.before.dash * ")" * }
- 'skip$
- if$
- year contains.dash
- { "--" *
- year extract.after.dash empty$
- volume extract.after.dash empty$ and
- number extract.after.dash empty$ and not
- { year extract.after.dash empty$ not
- { year extract.after.dash * }
- { year extract.before.dash * }
- if$
- volume empty$ not
- { ", " * volume extract.after.dash * }
- 'skip$
- if$
- number empty$ not
- { "\penalty0 (" * number extract.after.dash * ")" * }
- 'skip$
- if$
- }
- 'skip$
- if$
- }
- 'skip$
- if$
-}
-
-FUNCTION {check.url}
-{ url empty$ not
- { "\url{" url * "}" * 'entry.url :=
- #1 'entry.is.electronic :=
- }
- { howpublished empty$ not
- { howpublished #1 #5 substring$ "\url{" =
- { howpublished 'entry.url :=
- #1 'entry.is.electronic :=
- }
- 'skip$
- if$
- }
- { note empty$ not
- { note #1 #5 substring$ "\url{" =
- { note 'entry.url :=
- #1 'entry.is.electronic :=
- }
- 'skip$
- if$
- }
- 'skip$
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.url}
-{ entry.url empty$ not
- { new.block entry.url }
- { "" }
- if$
-}
-
-FUNCTION {check.doi}
-{ doi empty$ not
- { #1 'entry.is.electronic := }
- 'skip$
- if$
-}
-
-FUNCTION {is.in.url}
-{ 's :=
- s empty$
- { #1 }
- { entry.url empty$
- { #0 }
- { s text.length$ 'len :=
- entry.url text.length$ 'charptr :=
- { entry.url charptr len substring$ s = not
- charptr #0 >
- and
- }
- { charptr #1 - 'charptr := }
- while$
- charptr
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.doi}
-{ ""
- doi empty$ not show.doi and
- { "" 's :=
- doi 't :=
- #0 'numnames :=
- { t empty$ not}
- { t #1 #1 substring$ 'tmp.str :=
- tmp.str "," = tmp.str " " = or t #2 #1 substring$ empty$ or
- { t #2 #1 substring$ empty$
- { s tmp.str * 's := }
- 'skip$
- if$
- s empty$ s is.in.url or
- 'skip$
- { numnames #1 + 'numnames :=
- numnames #1 >
- { ", " * }
- { "DOI: " * }
- if$
- "\doi{" s * "}" * *
- }
- if$
- "" 's :=
- }
- { s tmp.str * 's := }
- if$
- t #2 global.max$ substring$ 't :=
- }
- while$
- 's :=
- s empty$ not
- { new.block s }
- { "" }
- if$
- }
- 'skip$
- if$
-}
-
-FUNCTION {check.electronic}
-{ "" 'entry.url :=
- #0 'entry.is.electronic :=
- 'check.doi
- 'skip$
- if$
- 'check.url
- 'skip$
- if$
- medium empty$ not
- { medium "MT" = medium "DK" = or medium "CD" = or medium "OL" = or
- { #1 'entry.is.electronic := }
- 'skip$
- if$
- }
- 'skip$
- if$
-}
-
-FUNCTION {format.note}
-{ note empty$ not show.note and
- { note }
- { "" }
- if$
-}
-
-FUNCTION {empty.misc.check}
-{ author empty$ title empty$
- year empty$
- and and
- key empty$ not and
- { "all relevant fields are empty in " cite$ * warning$ }
- 'skip$
- if$
-}
-
-FUNCTION {monograph}
-{ output.bibitem
- author empty$ not
- { format.authors }
- { editor empty$ not
- { format.editors }
- { bbl.anonymous }
- if$
- }
- if$
- output
- period.between.author.year
- 'new.sentence
- 'skip$
- if$
- format.year "year" output.check
- new.block
- format.series.vol.num.title "title" output.check
- "M" set.entry.mark
- format.mark "" output.after
- new.block
- format.translators output
- new.sentence
- format.edition output
- new.block
- format.address.publisher output
- format.pages bbl.colon output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {incollection}
-{ output.bibitem
- format.authors "author" output.check
- author format.key output
- period.between.author.year
- 'new.sentence
- 'skip$
- if$
- format.year "year" output.check
- new.block
- format.title "title" output.check
- "M" set.entry.mark
- format.mark "" output.after
- new.block
- format.translators output
- new.slash
- format.editors output
- new.block
- format.series.vol.num.booktitle "booktitle" output.check
- new.block
- format.edition output
- new.block
- format.address.publisher output
- format.pages bbl.colon output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {periodical}
-{ output.bibitem
- format.authors "author" output.check
- author format.key output
- period.between.author.year
- 'new.sentence
- 'skip$
- if$
- format.year "year" output.check
- new.block
- format.title "title" output.check
- "J" set.entry.mark
- format.mark "" output.after
- new.block
- format.periodical.year.volume.number output
- new.block
- format.address.publisher output
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {article}
-{ output.bibitem
- format.authors "author" output.check
- author format.key output
- period.between.author.year
- 'new.sentence
- 'skip$
- if$
- format.year "year" output.check
- new.block
- format.title "title" output.check
- "J" set.entry.mark
- format.mark "" output.after
- new.block
- format.journal "journal" output.check
- volume output
- format.journal.number "" output.after
- format.journal.pages "" output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {patent}
-{ output.bibitem
- format.authors output
- author format.key output
- period.between.author.year
- 'new.sentence
- 'skip$
- if$
- format.year "year" output.check
- new.block
- format.title
- number empty$ not
- { bbl.colon * number * }
- 'skip$
- if$
- "title" output.check
- "P" set.entry.mark
- format.mark "" output.after
- new.block
- format.date "year" output.check
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {electronic}
-{ #1 #1 check.electronic
- #1 'entry.is.electronic :=
- output.bibitem
- format.authors output
- author format.key output
- period.between.author.year
- 'new.sentence
- 'skip$
- if$
- format.year "year" output.check
- new.block
- format.series.vol.num.title "title" output.check
- "EB" set.entry.mark
- format.mark "" output.after
- new.block
- format.address.publisher output
- format.pages bbl.colon output.after
- format.editdate "" output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {misc}
-{ journal empty$ not
- 'article
- { booktitle empty$ not
- 'incollection
- { publisher empty$ not
- 'monograph
- { entry.is.electronic
- 'electronic
- { "Z" set.entry.mark
- monograph
- }
- if$
- }
- if$
- }
- if$
- }
- if$
- empty.misc.check
-}
-
-FUNCTION {archive}
-{ "A" set.entry.mark
- misc
-}
-
-FUNCTION {book} { monograph }
-
-FUNCTION {booklet} { book }
-
-FUNCTION {collection}
-{ "G" set.entry.mark
- monograph
-}
-
-FUNCTION {database}
-{ "DB" set.entry.mark
- electronic
-}
-
-FUNCTION {dataset}
-{ "DS" set.entry.mark
- electronic
-}
-
-FUNCTION {inbook} { book }
-
-FUNCTION {inproceedings}
-{ "C" set.entry.mark
- incollection
-}
-
-FUNCTION {conference} { inproceedings }
-
-FUNCTION {map}
-{ "CM" set.entry.mark
- misc
-}
-
-FUNCTION {manual} { monograph }
-
-FUNCTION {mastersthesis}
-{ "D" set.entry.mark
- monograph
-}
-
-FUNCTION {newspaper}
-{ "N" set.entry.mark
- article
-}
-
-FUNCTION {online}
-{ "EB" set.entry.mark
- electronic
-}
-
-FUNCTION {phdthesis} { mastersthesis }
-
-FUNCTION {proceedings}
-{ "C" set.entry.mark
- monograph
-}
-
-FUNCTION {software}
-{ "CP" set.entry.mark
- electronic
-}
-
-FUNCTION {standard}
-{ "S" set.entry.mark
- misc
-}
-
-FUNCTION {techreport}
-{ "R" set.entry.mark
- misc
-}
-
-FUNCTION {unpublished}
-{ "Z" set.entry.mark
- misc
-}
-
-FUNCTION {default.type} { misc }
-
-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 {sortify}
-{ purify$
- "l" change.case$
-}
-
-FUNCTION {chop.word}
-{ 's :=
- 'len :=
- s #1 len substring$ =
- { s len #1 + global.max$ substring$ }
- 's
- if$
-}
-
-FUNCTION {format.lab.names}
-{ 's :=
- s #1 "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
- t get.str.lang 'name.lang :=
- name.lang lang.en =
- { t #1 "{vv~}{ll}" format.name$}
- { t #1 "{ll}{ff}" format.name$}
- if$
- s num.names$ #1 >
- { bbl.space * bbl.et.al * }
- 'skip$
- 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 {author.key.organization.label}
-{ author empty$
- { key empty$
- { organization empty$
- { cite$ #1 #3 substring$ }
- { "The " #4 organization chop.word #3 text.prefix$ }
- if$
- }
- 'key
- if$
- }
- { author format.lab.names }
- if$
-}
-
-FUNCTION {editor.key.organization.label}
-{ editor empty$
- { key empty$
- { organization empty$
- { cite$ #1 #3 substring$ }
- { "The " #4 organization chop.word #3 text.prefix$ }
- if$
- }
- 'key
- if$
- }
- { editor format.lab.names }
- if$
-}
-
-FUNCTION {calc.short.authors}
-{ type$ "book" =
- type$ "inbook" =
- or
- 'author.editor.key.label
- { type$ "collection" =
- type$ "proceedings" =
- or
- { editor empty$ not
- 'editor.key.organization.label
- 'author.key.organization.label
- if$
- }
- 'author.key.label
- if$
- }
- if$
- 'short.list :=
-}
-
-FUNCTION {calc.label}
-{ calc.short.authors
- short.list
- "("
- *
- format.year duplicate$ empty$
- short.list key field.or.null = or
- { pop$ "" }
- 'skip$
- if$
- *
- 'label :=
-}
-
-FUNCTION {sort.language.label}
-{ entry.lang lang.zh =
- { "a zh " }
- { entry.lang lang.ja =
- { "b ja " }
- { entry.lang lang.en =
- { "c en " }
- { entry.lang lang.ru =
- { "d ru " }
- { "e other " }
- if$
- }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {sort.format.names}
-{ 's :=
- #1 'nameptr :=
- ""
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- {
- s nameptr "{vv{ } }{ll{ }}{ ff{ }}{ jj{ }}" format.name$ 't :=
- nameptr #1 >
- {
- " " *
- namesleft #1 = t "others" = and
- { "zzzzz" * }
- { numnames #2 > nameptr #2 = and
- { "zz" * year field.or.null * " " * }
- 'skip$
- if$
- 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 {anonymous.sort}
-{ lang.zh entry.lang =
- { "yi4 ming2" }
- { "anon" }
- if$
-}
-
-FUNCTION {author.sort}
-{ key empty$
- { entry.lang lang.zh =
- { "empty key in " cite$ * warning$ }
- 'skip$
- if$
- author empty$
- { anonymous.sort }
- { author sort.format.names }
- if$
- }
- { key sortify }
- if$
-}
-
-FUNCTION {author.editor.sort}
-{ key empty$
- { author empty$
- { editor empty$
- { anonymous.sort }
- { editor sort.format.names }
- if$
- }
- { author sort.format.names }
- if$
- }
- { key sortify }
- if$
-}
-
-FUNCTION {author.organization.sort}
-{ key empty$
- { author empty$
- { organization empty$
- { anonymous.sort }
- { "The " #4 organization chop.word sortify }
- if$
- }
- { author sort.format.names }
- if$
- }
- { key sortify }
- if$
-}
-
-FUNCTION {editor.organization.sort}
-{ key empty$
- { editor empty$
- { organization empty$
- { anonymous.sort }
- { "The " #4 organization chop.word sortify }
- if$
- }
- { editor sort.format.names }
- if$
- }
- { key sortify }
- if$
-}
-
-FUNCTION {presort}
-{ set.entry.lang
- show.url show.doi check.electronic
- calc.label
- label sortify
- " "
- *
- sort.language.label
- type$ "book" =
- type$ "inbook" =
- or
- 'author.editor.sort
- { type$ "collection" =
- type$ "proceedings" =
- or
- 'editor.organization.sort
- 'author.sort
- if$
- }
- if$
- *
- " "
- *
- year field.or.null sortify
- *
- " "
- *
- cite$
- *
- #1 entry.max$ substring$
- 'sort.label :=
- sort.label *
- #1 entry.max$ substring$
- 'sort.key$ :=
-}
-
-STRINGS { longest.label last.label next.extra }
-
-INTEGERS { longest.label.width last.extra.num number.label }
-
-FUNCTION {initialize.longest.label}
-{ "" 'longest.label :=
- #0 int.to.chr$ 'last.label :=
- "" 'next.extra :=
- #0 'longest.label.width :=
- #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$
- { "{\natexlab{" swap$ * "}}" * }
- if$
- 'extra.label :=
- label extra.label * 'label :=
-}
-
-FUNCTION {bib.sort.order}
-{ sort.label 'sort.key$ :=
-}
-
-FUNCTION {begin.bib}
-{ preamble$ empty$
- 'skip$
- { preamble$ write$ newline$ }
- if$
- "\begin{thebibliography}{" number.label int.to.str$ * "}" *
- write$ newline$
- "\providecommand{\natexlab}[1]{#1}"
- write$ newline$
- show.url show.doi or
- { "\providecommand{\url}[1]{#1}"
- write$ newline$
- "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
- write$ newline$
- " \urlstyle{same}\fi"
- write$ newline$
- }
- 'skip$
- if$
- show.doi
- { "\providecommand{\href}[2]{\url{#2}}"
- write$ newline$
- "\providecommand{\doi}[1]{\href{https://doi.org/#1}{#1}}"
- write$ newline$
- }
- 'skip$
- if$
-}
-
-FUNCTION {end.bib}
-{ newline$
- "\end{thebibliography}" write$ newline$
-}
-
-READ
-
-EXECUTE {init.state.consts}
-
-EXECUTE {load.config}
-
-ITERATE {presort}
-
-SORT
-
-EXECUTE {initialize.longest.label}
-
-ITERATE {forward.pass}
-
-REVERSE {reverse.pass}
-
-ITERATE {bib.sort.order}
-
-SORT
-
-EXECUTE {begin.bib}
-
-ITERATE {call.type$}
-
-EXECUTE {end.bib}
Deleted: trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-unsrt.bst
===================================================================
--- trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-unsrt.bst 2019-03-21 20:24:13 UTC (rev 50503)
+++ trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-2005-unsrt.bst 2019-03-21 20:45:44 UTC (rev 50504)
@@ -1,1766 +0,0 @@
-%%
-%% This is file `gbt7714-2005-unsrt.bst',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% gbt7714.dtx (with options: `2005,numerical')
-%% Version: 2018/08/05 v1.0.9
-%%
-%% Copyright (C) 2016-2018 by Zeping Lee <zepinglee AT gmail.com>
-%%
-%% This file may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% https://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2005/12/01 or later.
-%%
-
-INTEGERS {
- uppercase.name
- max.num.authors
- period.between.author.year
- sentence.case.title
- link.title
- show.mark
- italic.jounal
- show.missing.address.publisher
- show.url
- show.doi
- show.note
-}
-
-FUNCTION {load.config}
-{
- #1 'uppercase.name :=
- #3 'max.num.authors :=
- #0 'period.between.author.year :=
- #1 'sentence.case.title :=
- #0 'link.title :=
- #1 'show.mark :=
- #0 'italic.jounal :=
- #1 'show.missing.address.publisher :=
- #1 'show.url :=
- #0 'show.doi :=
- #0 'show.note :=
-}
-
-ENTRY
- { address
- author
- booktitle
- date
- doi
- edition
- editor
- howpublished
- institution
- journal
- key
- language
- mark
- medium
- note
- number
- organization
- pages
- publisher
- school
- series
- title
- translator
- url
- urldate
- volume
- year
- }
- { entry.lang entry.is.electronic }
- { label extra.label sort.label short.list entry.mark entry.url }
-
-INTEGERS { output.state before.all mid.sentence after.sentence after.block after.slash }
-
-INTEGERS { lang.zh lang.ja lang.en lang.ru lang.other }
-
-INTEGERS { charptr len }
-
-FUNCTION {init.state.consts}
-{ #0 'before.all :=
- #1 'mid.sentence :=
- #2 'after.sentence :=
- #3 'after.block :=
- #4 'after.slash :=
- #3 'lang.zh :=
- #4 'lang.ja :=
- #1 'lang.en :=
- #2 'lang.ru :=
- #0 'lang.other :=
-}
-
-FUNCTION {bbl.anonymous}
-{ lang.zh entry.lang =
- { "佚名" }
- { "Anon" }
- if$
-}
-
-FUNCTION {bbl.space} { "\ " }
-
-FUNCTION {bbl.et.al}
-{ lang.zh entry.lang =
- { "等" }
- { lang.ja entry.lang =
- { "他" }
- { lang.ru entry.lang =
- { "идр" }
- { "et~al." }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {bbl.colon} { ": " }
-
-FUNCTION {bbl.wide.space} { "\ " }
-
-FUNCTION {bbl.slash} { "//\allowbreak{}" }
-
-FUNCTION {bbl.sine.loco}
-{ lang.zh entry.lang =
- { "[出版地不详]" }
- { "[S.l.]" }
- if$
-}
-
-FUNCTION {bbl.sine.nomine}
-{ lang.zh entry.lang =
- { "[出版者不详]" }
- { "[s.n.]" }
- if$
-}
-
-FUNCTION {bbl.sine.loco.sine.nomine}
-{ lang.zh entry.lang =
- { "[出版地不详: 出版者不详]" }
- { "[S.l.: s.n.]" }
- if$
-}
-
-FUNCTION {not}
-{ { #0 }
- { #1 }
- if$
-}
-
-FUNCTION {and}
-{ 'skip$
- { pop$ #0 }
- if$
-}
-
-FUNCTION {or}
-{ { pop$ #1 }
- 'skip$
- if$
-}
-
-STRINGS { s t }
-
-FUNCTION {output.nonnull}
-{ 's :=
- output.state mid.sentence =
- { ", " * write$ }
- { output.state after.block =
- { add.period$ write$
- newline$
- "\newblock " write$
- }
- { output.state before.all =
- 'write$
- { output.state after.slash =
- { bbl.slash * write$ }
- { add.period$ " " * write$ }
- if$
- }
- if$
- }
- if$
- mid.sentence 'output.state :=
- }
- if$
- s
-}
-
-FUNCTION {output}
-{ duplicate$ empty$
- 'pop$
- 'output.nonnull
- if$
-}
-
-FUNCTION {output.after}
-{ 't :=
- duplicate$ empty$
- 'pop$
- { 's :=
- output.state mid.sentence =
- { t * write$ }
- { output.state after.block =
- { add.period$ write$
- newline$
- "\newblock " write$
- }
- { output.state before.all =
- 'write$
- { output.state after.slash =
- { bbl.slash * write$ }
- { add.period$ " " * write$ }
- if$
- }
- if$
- }
- if$
- mid.sentence 'output.state :=
- }
- if$
- s
- }
- if$
-}
-
-FUNCTION {output.check}
-{ 't :=
- duplicate$ empty$
- { pop$ "empty " t * " in " * cite$ * warning$ }
- 'output.nonnull
- if$
-}
-
-FUNCTION {fin.entry}
-{ add.period$
- write$
- newline$
-}
-
-FUNCTION {new.block}
-{ output.state before.all =
- 'skip$
- { output.state after.slash =
- 'skip$
- { after.block 'output.state := }
- if$
- }
- if$
-}
-
-FUNCTION {new.sentence}
-{ output.state after.block =
- 'skip$
- { output.state before.all =
- 'skip$
- { output.state after.slash =
- 'skip$
- { after.sentence 'output.state := }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {new.slash}
-{ output.state before.all =
- 'skip$
- { after.slash 'output.state := }
- if$
-}
-
-FUNCTION {new.block.checka}
-{ empty$
- 'skip$
- 'new.block
- if$
-}
-
-FUNCTION {new.block.checkb}
-{ empty$
- swap$ empty$
- and
- 'skip$
- 'new.block
- if$
-}
-
-FUNCTION {new.sentence.checka}
-{ empty$
- 'skip$
- 'new.sentence
- if$
-}
-
-FUNCTION {new.sentence.checkb}
-{ empty$
- swap$ empty$
- and
- 'skip$
- 'new.sentence
- if$
-}
-
-FUNCTION {field.or.null}
-{ duplicate$ empty$
- { pop$ "" }
- 'skip$
- if$
-}
-
-FUNCTION {italicize}
-{ duplicate$ empty$
- { pop$ "" }
- { "\textit{" swap$ * "}" * }
- if$
-}
-
-INTEGERS { byte second.byte }
-
-INTEGERS { char.lang tmp.lang }
-
-STRINGS { tmp.str }
-
-FUNCTION {get.str.lang}
-{ 'tmp.str :=
- lang.other 'tmp.lang :=
- #1 'charptr :=
- tmp.str text.length$ #1 + 'len :=
- { charptr len < }
- { tmp.str charptr #1 substring$ chr.to.int$ 'byte :=
- byte #128 <
- { charptr #1 + 'charptr :=
- byte #64 > byte #91 < and byte #96 > byte #123 < and or
- { lang.en 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- { tmp.str charptr #1 + #1 substring$ chr.to.int$ 'second.byte :=
- byte #224 <
- { charptr #2 + 'charptr :=
- byte #207 > byte #212 < and
- byte #212 = second.byte #176 < and or
- { lang.ru 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- { byte #240 <
- { charptr #3 + 'charptr :=
- byte #227 > byte #234 < and
- { lang.zh 'char.lang := }
- { byte #227 =
- { second.byte #143 >
- { lang.zh 'char.lang := }
- { second.byte #128 > second.byte #132 < and
- { lang.ja 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- if$
- }
- { byte #239 =
- second.byte #163 > second.byte #172 < and and
- { lang.zh 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- if$
- }
- if$
- }
- { charptr #4 + 'charptr :=
- byte #240 = second.byte #159 > and
- { lang.zh 'char.lang := }
- { lang.other 'char.lang := }
- if$
- }
- if$
- }
- if$
- }
- if$
- char.lang tmp.lang >
- { char.lang 'tmp.lang := }
- 'skip$
- if$
- }
- while$
- tmp.lang
-}
-
-FUNCTION {check.entry.lang}
-{ author field.or.null
- title field.or.null *
- get.str.lang
-}
-
-FUNCTION {set.entry.lang}
-{ language empty$
- { check.entry.lang }
- { language "english" = language "american" = or language "british" = or
- { lang.en }
- { language "chinese" =
- { lang.zh }
- { language "japanese" =
- { lang.ja }
- { language "russian" =
- { lang.ru }
- { check.entry.lang }
- if$
- }
- if$
- }
- if$
- }
- if$
- }
- if$
- 'entry.lang :=
-}
-
-INTEGERS { nameptr namesleft numnames name.lang }
-
-FUNCTION {format.names}
-{ 's :=
- #1 'nameptr :=
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
- nameptr max.num.authors >
- { bbl.et.al
- #1 'namesleft :=
- }
- { t "others" =
- { bbl.et.al }
- { t get.str.lang 'name.lang :=
- name.lang lang.en =
- { t #1 "{vv~}{ll}{~f{~}}" format.name$
- uppercase.name
- { "u" change.case$ }
- 'skip$
- if$
- t #1 "{, jj}" format.name$ *
- }
- { t #1 "{ll}{ff}" format.name$ }
- if$
- }
- if$
- }
- if$
- nameptr #1 >
- { ", " swap$ * * }
- 'skip$
- if$
- nameptr #1 + 'nameptr :=
- namesleft #1 - 'namesleft :=
- }
- while$
-}
-
-FUNCTION {format.key}
-{ empty$
- { key field.or.null }
- { "" }
- if$
-}
-
-FUNCTION {format.authors}
-{ author empty$
- { "" }
- { author format.names }
- if$
-}
-
-FUNCTION {format.editors}
-{ editor empty$
- { "" }
- { editor format.names }
- if$
-}
-
-FUNCTION {format.translators}
-{ translator empty$
- { "" }
- { translator format.names
- lang.zh entry.lang =
- { translator num.names$ #3 >
- { "译" * }
- { ", 译" * }
- if$
- }
- 'skip$
- if$
- }
- if$
-}
-
-FUNCTION {format.full.names}
-{'s :=
- #1 'nameptr :=
- s num.names$ 'numnames :=
- numnames 'namesleft :=
- { namesleft #0 > }
- { s nameptr "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
- t get.str.lang 'name.lang :=
- name.lang lang.en =
- { t #1 "{vv~}{ll}" format.name$ 't := }
- { t #1 "{ll}{ff}" format.name$ 't := }
- if$
- nameptr #1 >
- {
- namesleft #1 >
- { ", " * t * }
- {
- numnames #2 >
- { "," * }
- 'skip$
- if$
- t "others" =
- { " et~al." * }
- { " and " * t * }
- if$
- }
- if$
- }
- 't
- if$
- nameptr #1 + 'nameptr :=
- namesleft #1 - 'namesleft :=
- }
- while$
-}
-
-FUNCTION {author.editor.full}
-{ author empty$
- { editor empty$
- { "" }
- { editor format.full.names }
- if$
- }
- { author format.full.names }
- if$
-}
-
-FUNCTION {author.full}
-{ author empty$
- { "" }
- { author format.full.names }
- if$
-}
-
-FUNCTION {editor.full}
-{ editor empty$
- { "" }
- { editor format.full.names }
- if$
-}
-
-FUNCTION {make.full.names}
-{ type$ "book" =
- type$ "inbook" =
- or
- 'author.editor.full
- { type$ "collection" =
- type$ "proceedings" =
- or
- 'editor.full
- 'author.full
- if$
- }
- if$
-}
-
-FUNCTION {output.bibitem}
-{ newline$
- "\bibitem[" write$
- label write$
- ")" make.full.names duplicate$ short.list =
- { pop$ }
- { * }
- if$
- "]{" * write$
- cite$ write$
- "}" write$
- newline$
- ""
- before.all 'output.state :=
-}
-
-FUNCTION {change.sentence.case}
-{ entry.lang lang.en =
- { "t" change.case$ }
- 'skip$
- if$
-}
-
-FUNCTION {add.link}
- { url empty$ not
- { "\href{" url * "}{" * swap$ * "}" * }
- { doi empty$ not
- { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
- 'skip$
- if$
- }
- if$
- }
-
-FUNCTION {format.title}
-{ title empty$
- { "" }
- { title
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- link.title
- 'add.link
- 'skip$
- if$
- }
- if$
-}
-
-FUNCTION {tie.or.space.connect}
-{ duplicate$ text.length$ #3 <
- { "~" }
- { " " }
- if$
- swap$ * *
-}
-
-FUNCTION {either.or.check}
-{ empty$
- 'pop$
- { "can't use both " swap$ * " fields in " * cite$ * warning$ }
- if$
-}
-
-FUNCTION {is.digit}
-{ duplicate$ empty$
- { pop$ #0 }
- { chr.to.int$
- duplicate$ "0" chr.to.int$ <
- { pop$ #0 }
- { "9" chr.to.int$ >
- { #0 }
- { #1 }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {is.number}
-{ 's :=
- s empty$
- { #0 }
- { s text.length$ 'charptr :=
- { charptr #0 >
- s charptr #1 substring$ is.digit
- and
- }
- { charptr #1 - 'charptr := }
- while$
- charptr not
- }
- if$
-}
-
-FUNCTION {format.volume}
-{ volume empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " volume * " 卷" * }
- { "volume" volume tie.or.space.connect }
- if$
- }
- if$
-}
-
-FUNCTION {format.number}
-{ number empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " number * " 册" * }
- { "number" number tie.or.space.connect }
- if$
- }
- if$
-}
-
-FUNCTION {format.volume.number}
-{ volume empty$ not
- { format.volume }
- { format.number }
- if$
-}
-
-FUNCTION {format.series.vol.num.title}
-{ format.volume.number 's :=
- series empty$ not
- { series
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- bbl.colon *
- s empty$ not
- { s * bbl.wide.space * }
- 'skip$
- if$
- title
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- *
- }
- { title
- sentence.case.title
- 'change.sentence.case
- 'skip$
- if$
- s empty$ not
- { bbl.colon * s * }
- 'skip$
- if$
- }
- if$
- link.title
- 'add.link
- 'skip$
- if$
-}
-
-FUNCTION {format.series.vol.num.booktitle}
-{ format.volume.number 's :=
- series empty$ not
- { series bbl.colon *
- s empty$ not
- { s * bbl.wide.space * }
- 'skip$
- if$
- booktitle *
- }
- { booktitle
- s empty$ not
- { bbl.colon * s * }
- 'skip$
- if$
- }
- if$
-}
-
-FUNCTION {format.journal}
-{ journal
- italic.jounal
- 'italicize
- 'skip$
- if$
-}
-
-FUNCTION {set.entry.mark}
-{ entry.mark empty$ not
- 'pop$
- { mark empty$ not
- { pop$ mark 'entry.mark := }
- { 'entry.mark := }
- if$
- }
- if$
-}
-
-FUNCTION {format.mark}
-{ show.mark
- { medium empty$ not
- { entry.mark "/" * medium * 'entry.mark := }
- { entry.is.electronic
- { entry.mark "/OL" * 'entry.mark := }
- 'skip$
- if$
- }
- if$
- "\allowbreak[" entry.mark * "]" *
- }
- { "" }
- if$
-}
-
-FUNCTION {num.to.ordinal}
-{ duplicate$ text.length$ 'charptr :=
- duplicate$ charptr #1 substring$ 's :=
- s "1" =
- { "st" * }
- { s "2" =
- { "nd" * }
- { s "3" =
- { "rd" * }
- { "th" * }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.edition}
-{ edition empty$
- { "" }
- { edition is.number
- { lang.zh entry.lang =
- { edition " 版" * }
- { edition num.to.ordinal " ed." * }
- if$
- }
- { entry.lang lang.en =
- { edition change.sentence.case 's :=
- s "Revised" = s "Revised edition" = or
- { "Rev. ed." }
- { s " ed." *}
- if$
- }
- { edition }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.publisher}
-{ publisher empty$ not
- { publisher }
- { school empty$ not
- { school }
- { organization empty$ not
- { organization }
- { institution empty$ not
- { institution }
- { "" }
- if$
- }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.address.publisher}
-{ address empty$ not
- { address
- format.publisher empty$ not
- { bbl.colon * format.publisher * }
- { entry.is.electronic not show.missing.address.publisher and
- { bbl.colon * bbl.sine.nomine * }
- 'skip$
- if$
- }
- if$
- }
- { entry.is.electronic not show.missing.address.publisher and
- { format.publisher empty$ not
- { bbl.sine.loco bbl.colon * format.publisher * }
- { bbl.sine.loco.sine.nomine }
- if$
- }
- { format.publisher empty$ not
- { format.publisher }
- { "" }
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {extract.before.dash}
-{ duplicate$ empty$
- { pop$ "" }
- { 's :=
- #1 'charptr :=
- s text.length$ #1 + 'len :=
- { charptr len <
- s charptr #1 substring$ "-" = not
- and
- }
- { charptr #1 + 'charptr := }
- while$
- s #1 charptr #1 - substring$
- }
- if$
-}
-
-FUNCTION {extract.after.dash}
-{ duplicate$ empty$
- { pop$ "" }
- { 's :=
- #1 'charptr :=
- s text.length$ #1 + 'len :=
- { charptr len <
- s charptr #1 substring$ "-" = not
- and
- }
- { charptr #1 + 'charptr := }
- while$
- { charptr len <
- s charptr #1 substring$ "-" =
- and
- }
- { charptr #1 + 'charptr := }
- while$
- s charptr global.max$ substring$
- }
- if$
-}
-
-FUNCTION {contains.dash}
-{ duplicate$ empty$
- { pop$ #0 }
- { 's :=
- { s empty$ not
- s #1 #1 substring$ "-" = not
- and
- }
- { s #2 global.max$ substring$ 's := }
- while$
- s empty$ not
- }
- if$
-}
-
-FUNCTION {format.year}
-{ year empty$ not
- { year extract.before.dash }
- { date empty$ not
- { date extract.before.dash }
- { "empty year in " cite$ * warning$
- ""
- }
- if$
- }
- if$
- extra.label *
-}
-
-FUNCTION {format.date}
-{ type$ "patent" = type$ "newspaper" = or
- date empty$ not and
- { date }
- { year }
- if$
-}
-
-FUNCTION {format.editdate}
-{ date empty$ not
- { "\allowbreak(" date * ")" * }
- { "" }
- if$
-}
-
-FUNCTION {format.urldate}
-{ urldate empty$ not entry.is.electronic and
- { "\allowbreak[" urldate * "]" * }
- { "" }
- if$
-}
-
-FUNCTION {hyphenate}
-{ 't :=
- ""
- { t empty$ not }
- { t #1 #1 substring$ "-" =
- { "-" *
- { t #1 #1 substring$ "-" = }
- { t #2 global.max$ substring$ 't := }
- while$
- }
- { t #1 #1 substring$ *
- t #2 global.max$ substring$ 't :=
- }
- if$
- }
- while$
-}
-
-FUNCTION {format.pages}
-{ pages empty$
- { "" }
- { pages hyphenate }
- if$
-}
-
-FUNCTION {format.journal.number}
-{ number empty$ not
- { "\penalty0 (" number * ")" * }
- { "" }
- if$
-}
-
-FUNCTION {format.journal.pages}
-{ pages empty$
- { "" }
- { ":\penalty0 " pages hyphenate * }
- if$
-}
-
-FUNCTION {format.periodical.year.volume.number}
-{ year empty$ not
- { year extract.before.dash }
- { "empty year in periodical " cite$ * warning$ }
- if$
- volume empty$ not
- { ", " * volume extract.before.dash * }
- 'skip$
- if$
- number empty$ not
- { "\penalty0 (" * number extract.before.dash * ")" * }
- 'skip$
- if$
- year contains.dash
- { "--" *
- year extract.after.dash empty$
- volume extract.after.dash empty$ and
- number extract.after.dash empty$ and not
- { year extract.after.dash empty$ not
- { year extract.after.dash * }
- { year extract.before.dash * }
- if$
- volume empty$ not
- { ", " * volume extract.after.dash * }
- 'skip$
- if$
- number empty$ not
- { "\penalty0 (" * number extract.after.dash * ")" * }
- 'skip$
- if$
- }
- 'skip$
- if$
- }
- 'skip$
- if$
-}
-
-FUNCTION {check.url}
-{ url empty$ not
- { "\url{" url * "}" * 'entry.url :=
- #1 'entry.is.electronic :=
- }
- { howpublished empty$ not
- { howpublished #1 #5 substring$ "\url{" =
- { howpublished 'entry.url :=
- #1 'entry.is.electronic :=
- }
- 'skip$
- if$
- }
- { note empty$ not
- { note #1 #5 substring$ "\url{" =
- { note 'entry.url :=
- #1 'entry.is.electronic :=
- }
- 'skip$
- if$
- }
- 'skip$
- if$
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.url}
-{ entry.url empty$ not
- { new.block entry.url }
- { "" }
- if$
-}
-
-FUNCTION {check.doi}
-{ doi empty$ not
- { #1 'entry.is.electronic := }
- 'skip$
- if$
-}
-
-FUNCTION {is.in.url}
-{ 's :=
- s empty$
- { #1 }
- { entry.url empty$
- { #0 }
- { s text.length$ 'len :=
- entry.url text.length$ 'charptr :=
- { entry.url charptr len substring$ s = not
- charptr #0 >
- and
- }
- { charptr #1 - 'charptr := }
- while$
- charptr
- }
- if$
- }
- if$
-}
-
-FUNCTION {format.doi}
-{ ""
- doi empty$ not show.doi and
- { "" 's :=
- doi 't :=
- #0 'numnames :=
- { t empty$ not}
- { t #1 #1 substring$ 'tmp.str :=
- tmp.str "," = tmp.str " " = or t #2 #1 substring$ empty$ or
- { t #2 #1 substring$ empty$
- { s tmp.str * 's := }
- 'skip$
- if$
- s empty$ s is.in.url or
- 'skip$
- { numnames #1 + 'numnames :=
- numnames #1 >
- { ", " * }
- { "DOI: " * }
- if$
- "\doi{" s * "}" * *
- }
- if$
- "" 's :=
- }
- { s tmp.str * 's := }
- if$
- t #2 global.max$ substring$ 't :=
- }
- while$
- 's :=
- s empty$ not
- { new.block s }
- { "" }
- if$
- }
- 'skip$
- if$
-}
-
-FUNCTION {check.electronic}
-{ "" 'entry.url :=
- #0 'entry.is.electronic :=
- 'check.doi
- 'skip$
- if$
- 'check.url
- 'skip$
- if$
- medium empty$ not
- { medium "MT" = medium "DK" = or medium "CD" = or medium "OL" = or
- { #1 'entry.is.electronic := }
- 'skip$
- if$
- }
- 'skip$
- if$
-}
-
-FUNCTION {format.note}
-{ note empty$ not show.note and
- { note }
- { "" }
- if$
-}
-
-FUNCTION {empty.misc.check}
-{ author empty$ title empty$
- year empty$
- and and
- key empty$ not and
- { "all relevant fields are empty in " cite$ * warning$ }
- 'skip$
- if$
-}
-
-FUNCTION {monograph}
-{ output.bibitem
- author empty$ not
- { format.authors }
- { editor empty$ not
- { format.editors }
- { "" }
- if$
- }
- if$
- output
- new.block
- format.series.vol.num.title "title" output.check
- "M" set.entry.mark
- format.mark "" output.after
- new.block
- format.translators output
- new.sentence
- format.edition output
- new.block
- format.address.publisher output
- format.year "year" output.check
- format.pages bbl.colon output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {incollection}
-{ output.bibitem
- format.authors "author" output.check
- author format.key output
- new.block
- format.title "title" output.check
- "M" set.entry.mark
- format.mark "" output.after
- new.block
- format.translators output
- new.slash
- format.editors output
- new.block
- format.series.vol.num.booktitle "booktitle" output.check
- new.block
- format.edition output
- new.block
- format.address.publisher output
- format.year "year" output.check
- format.pages bbl.colon output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {periodical}
-{ output.bibitem
- format.authors "author" output.check
- author format.key output
- new.block
- format.title "title" output.check
- "J" set.entry.mark
- format.mark "" output.after
- new.block
- format.periodical.year.volume.number output
- new.block
- format.address.publisher output
- format.date "year" output.check
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {article}
-{ output.bibitem
- format.authors "author" output.check
- author format.key output
- new.block
- format.title "title" output.check
- "J" set.entry.mark
- format.mark "" output.after
- new.block
- format.journal "journal" output.check
- format.date "year" output.check
- volume output
- format.journal.number "" output.after
- format.journal.pages "" output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {patent}
-{ output.bibitem
- format.authors output
- author format.key output
- new.block
- format.title
- number empty$ not
- { bbl.colon * number * }
- 'skip$
- if$
- "title" output.check
- "P" set.entry.mark
- format.mark "" output.after
- new.block
- format.date "year" output.check
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {electronic}
-{ #1 #1 check.electronic
- #1 'entry.is.electronic :=
- output.bibitem
- format.authors output
- author format.key output
- new.block
- format.series.vol.num.title "title" output.check
- "EB" set.entry.mark
- format.mark "" output.after
- new.block
- format.address.publisher output
- date empty$
- { format.date output }
- 'skip$
- if$
- format.pages bbl.colon output.after
- format.editdate "" output.after
- format.urldate "" output.after
- format.url output
- format.doi output
- new.block
- format.note output
- fin.entry
-}
-
-FUNCTION {misc}
-{ journal empty$ not
- 'article
- { booktitle empty$ not
- 'incollection
- { publisher empty$ not
- 'monograph
- { entry.is.electronic
- 'electronic
- { "Z" set.entry.mark
- monograph
- }
- if$
- }
- if$
- }
- if$
- }
- if$
- empty.misc.check
-}
-
-FUNCTION {archive}
-{ "A" set.entry.mark
- misc
-}
-
-FUNCTION {book} { monograph }
-
-FUNCTION {booklet} { book }
-
-FUNCTION {collection}
-{ "G" set.entry.mark
- monograph
-}
-
-FUNCTION {database}
-{ "DB" set.entry.mark
- electronic
-}
-
-FUNCTION {dataset}
-{ "DS" set.entry.mark
- electronic
-}
-
-FUNCTION {inbook} { book }
-
-FUNCTION {inproceedings}
-{ "C" set.entry.mark
- incollection
-}
-
-FUNCTION {conference} { inproceedings }
-
-FUNCTION {map}
-{ "CM" set.entry.mark
- misc
-}
-
-FUNCTION {manual} { monograph }
-
-FUNCTION {mastersthesis}
-{ "D" set.entry.mark
- monograph
-}
-
-FUNCTION {newspaper}
-{ "N" set.entry.mark
- article
-}
-
-FUNCTION {online}
-{ "EB" set.entry.mark
- electronic
-}
-
-FUNCTION {phdthesis} { mastersthesis }
-
-FUNCTION {proceedings}
-{ "C" set.entry.mark
- monograph
-}
-
-FUNCTION {software}
-{ "CP" set.entry.mark
- electronic
-}
-
-FUNCTION {standard}
-{ "S" set.entry.mark
- misc
-}
-
-FUNCTION {techreport}
-{ "R" set.entry.mark
- misc
-}
-
-FUNCTION {unpublished}
-{ "Z" set.entry.mark
- misc
-}
-
-FUNCTION {default.type} { misc }
-
-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 {sortify}
-{ purify$
- "l" change.case$
-}
-
-FUNCTION {chop.word}
-{ 's :=
- 'len :=
- s #1 len substring$ =
- { s len #1 + global.max$ substring$ }
- 's
- if$
-}
-
-FUNCTION {format.lab.names}
-{ 's :=
- s #1 "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
- t get.str.lang 'name.lang :=
- name.lang lang.en =
- { t #1 "{vv~}{ll}" format.name$}
- { t #1 "{ll}{ff}" format.name$}
- if$
- s num.names$ #1 >
- { bbl.space * bbl.et.al * }
- 'skip$
- 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 {author.key.organization.label}
-{ author empty$
- { key empty$
- { organization empty$
- { cite$ #1 #3 substring$ }
- { "The " #4 organization chop.word #3 text.prefix$ }
- if$
- }
- 'key
- if$
- }
- { author format.lab.names }
- if$
-}
-
-FUNCTION {editor.key.organization.label}
-{ editor empty$
- { key empty$
- { organization empty$
- { cite$ #1 #3 substring$ }
- { "The " #4 organization chop.word #3 text.prefix$ }
- if$
- }
- 'key
- if$
- }
- { editor format.lab.names }
- if$
-}
-
-FUNCTION {calc.short.authors}
-{ type$ "book" =
- type$ "inbook" =
- or
- 'author.editor.key.label
- { type$ "collection" =
- type$ "proceedings" =
- or
- { editor empty$ not
- 'editor.key.organization.label
- 'author.key.organization.label
- if$
- }
- 'author.key.label
- if$
- }
- if$
- 'short.list :=
-}
-
-FUNCTION {calc.label}
-{ calc.short.authors
- short.list
- "("
- *
- format.year duplicate$ empty$
- short.list key field.or.null = or
- { pop$ "" }
- 'skip$
- if$
- *
- 'label :=
-}
-
-INTEGERS { seq.num }
-
-FUNCTION {init.seq}
-{ #0 'seq.num :=}
-
-FUNCTION {int.to.fix}
-{ "000000000" swap$ int.to.str$ *
- #-1 #10 substring$
-}
-
-FUNCTION {presort}
-{ set.entry.lang
- show.url show.doi check.electronic
- calc.label
- label sortify
- " "
- *
- seq.num #1 + 'seq.num :=
- seq.num int.to.fix
- 'sort.label :=
- sort.label *
- #1 entry.max$ substring$
- 'sort.key$ :=
-}
-
-STRINGS { longest.label last.label next.extra }
-
-INTEGERS { longest.label.width last.extra.num number.label }
-
-FUNCTION {initialize.longest.label}
-{ "" 'longest.label :=
- #0 int.to.chr$ 'last.label :=
- "" 'next.extra :=
- #0 'longest.label.width :=
- #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$
- { "{\natexlab{" swap$ * "}}" * }
- if$
- 'extra.label :=
- label extra.label * 'label :=
-}
-
-FUNCTION {bib.sort.order}
-{ sort.label 'sort.key$ :=
-}
-
-FUNCTION {begin.bib}
-{ preamble$ empty$
- 'skip$
- { preamble$ write$ newline$ }
- if$
- "\begin{thebibliography}{" number.label int.to.str$ * "}" *
- write$ newline$
- "\providecommand{\natexlab}[1]{#1}"
- write$ newline$
- show.url show.doi or
- { "\providecommand{\url}[1]{#1}"
- write$ newline$
- "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
- write$ newline$
- " \urlstyle{same}\fi"
- write$ newline$
- }
- 'skip$
- if$
- show.doi
- { "\providecommand{\href}[2]{\url{#2}}"
- write$ newline$
- "\providecommand{\doi}[1]{\href{https://doi.org/#1}{#1}}"
- write$ newline$
- }
- 'skip$
- if$
-}
-
-FUNCTION {end.bib}
-{ newline$
- "\end{thebibliography}" write$ newline$
-}
-
-READ
-
-EXECUTE {init.state.consts}
-
-EXECUTE {load.config}
-
-EXECUTE {init.seq}
-
-ITERATE {presort}
-
-SORT
-
-EXECUTE {initialize.longest.label}
-
-ITERATE {forward.pass}
-
-REVERSE {reverse.pass}
-
-ITERATE {bib.sort.order}
-
-SORT
-
-EXECUTE {begin.bib}
-
-ITERATE {call.type$}
-
-EXECUTE {end.bib}
Modified: trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-plain.bst
===================================================================
--- trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-plain.bst 2019-03-21 20:24:13 UTC (rev 50503)
+++ trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-plain.bst 2019-03-21 20:45:44 UTC (rev 50504)
@@ -5,10 +5,13 @@
%% The original source files were:
%%
%% gbt7714.dtx (with options: `2015,authoryear')
-%% Version: 2018/08/05 v1.0.9
-%%
-%% Copyright (C) 2016-2018 by Zeping Lee <zepinglee AT gmail.com>
-%%
+%% -------------------------------------------------------------------
+%% GB/T 7714-2015 BibTeX Style
+%% https://github.com/CTeX-org/gbt7714-bibtex-style
+%% Version: 2019/03/21 v1.1.1
+%% -------------------------------------------------------------------
+%% Copyright (C) 2016-2019 by Zeping Lee <zepinglee AT gmail.com>
+%% -------------------------------------------------------------------
%% This file may be distributed and/or modified under the
%% conditions of the LaTeX Project Public License, either version 1.3c
%% of this license or (at your option) any later version.
@@ -16,8 +19,7 @@
%% https://www.latex-project.org/lppl.txt
%% and version 1.3c or later is part of all distributions of LaTeX
%% version 2005/12/01 or later.
-%%
-
+%% -------------------------------------------------------------------
INTEGERS {
uppercase.name
max.num.authors
@@ -25,11 +27,19 @@
sentence.case.title
link.title
show.mark
+ slash.for.extraction
+ in.booktitle
italic.jounal
+ bold.journal.volume
show.missing.address.publisher
show.url
show.doi
show.note
+ lang.zh.order
+ lang.ja.order
+ lang.en.order
+ lang.ru.order
+ lang.other.order
}
FUNCTION {load.config}
@@ -40,11 +50,19 @@
#1 'sentence.case.title :=
#0 'link.title :=
#1 'show.mark :=
+ #1 'slash.for.extraction :=
+ #0 'in.booktitle :=
#0 'italic.jounal :=
+ #0 'bold.journal.volume :=
#1 'show.missing.address.publisher :=
#1 'show.url :=
#1 'show.doi :=
#0 'show.note :=
+ #1 'lang.zh.order :=
+ #2 'lang.ja.order :=
+ #3 'lang.en.order :=
+ #4 'lang.ru.order :=
+ #5 'lang.other.order :=
}
ENTRY
@@ -76,7 +94,7 @@
volume
year
}
- { entry.lang entry.is.electronic }
+ { entry.lang entry.is.electronic entry.numbered }
{ label extra.label sort.label short.list entry.mark entry.url }
INTEGERS { output.state before.all mid.sentence after.sentence after.block after.slash }
@@ -99,20 +117,25 @@
}
FUNCTION {bbl.anonymous}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "佚名" }
{ "Anon" }
if$
}
-FUNCTION {bbl.space} { "\ " }
+FUNCTION {bbl.space}
+{ entry.lang lang.zh =
+ { "\ " }
+ { " " }
+ if$
+}
FUNCTION {bbl.et.al}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "等" }
- { lang.ja entry.lang =
+ { entry.lang lang.ja =
{ "他" }
- { lang.ru entry.lang =
+ { entry.lang lang.ru =
{ "идр" }
{ "et~al." }
if$
@@ -122,14 +145,17 @@
if$
}
+FUNCTION {citation.et.al}
+{ bbl.et.al }
+
FUNCTION {bbl.colon} { ": " }
FUNCTION {bbl.wide.space} { "\quad " }
-FUNCTION {bbl.slash} { "//\allowbreak{}" }
+FUNCTION {bbl.slash} { "//\allowbreak " }
FUNCTION {bbl.sine.loco}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版地不详]" }
{ "[S.l.]" }
if$
@@ -136,7 +162,7 @@
}
FUNCTION {bbl.sine.nomine}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版者不详]" }
{ "[s.n.]" }
if$
@@ -143,7 +169,7 @@
}
FUNCTION {bbl.sine.loco.sine.nomine}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版地不详: 出版者不详]" }
{ "[S.l.: s.n.]" }
if$
@@ -181,7 +207,9 @@
{ output.state before.all =
'write$
{ output.state after.slash =
- { bbl.slash * write$ }
+ { bbl.slash * write$
+ newline$
+ }
{ add.period$ " " * write$ }
if$
}
@@ -274,7 +302,11 @@
FUNCTION {new.slash}
{ output.state before.all =
'skip$
- { after.slash 'output.state := }
+ { slash.for.extraction
+ { after.slash 'output.state := }
+ { after.block 'output.state := }
+ if$
+ }
if$
}
@@ -427,6 +459,15 @@
'entry.lang :=
}
+FUNCTION {set.entry.numbered}
+{ type$ "patent" =
+ type$ "standard" = or
+ type$ "techreport" = or
+ { #1 'entry.numbered := }
+ { #0 'entry.numbered := }
+ if$
+}
+
INTEGERS { nameptr namesleft numnames name.lang }
FUNCTION {format.names}
@@ -475,9 +516,11 @@
}
FUNCTION {format.authors}
-{ author empty$
- { bbl.anonymous }
+{ author empty$ not
{ author format.names }
+ { "empty author in " cite$ * warning$
+ bbl.anonymous
+ }
if$
}
@@ -492,7 +535,7 @@
{ translator empty$
{ "" }
{ translator format.names
- lang.zh entry.lang =
+ entry.lang lang.zh =
{ translator num.names$ #3 >
{ "译" * }
{ ", 译" * }
@@ -587,7 +630,20 @@
")" make.full.names duplicate$ short.list =
{ pop$ }
{ * }
- if$
+ if$
+ 's :=
+ s text.length$ 'charptr :=
+ { charptr #0 > }
+ { s charptr #1 substring$ "]" =
+ { #0 'charptr := }
+ { charptr #1 - 'charptr := }
+ if$
+ }
+ while$
+ charptr #0 >
+ { "{" s * "}" * }
+ { s }
+ if$
"]{" * write$
cite$ write$
"}" write$
@@ -604,15 +660,15 @@
}
FUNCTION {add.link}
- { url empty$ not
- { "\href{" url * "}{" * swap$ * "}" * }
- { doi empty$ not
- { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
- 'skip$
- if$
- }
- if$
- }
+{ url empty$ not
+ { "\href{" url * "}{" * swap$ * "}" * }
+ { doi empty$ not
+ { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
+ 'skip$
+ if$
+ }
+ if$
+}
FUNCTION {format.title}
{ title empty$
@@ -622,6 +678,10 @@
'change.sentence.case
'skip$
if$
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
+ 'skip$
+ if$
link.title
'add.link
'skip$
@@ -678,24 +738,32 @@
}
FUNCTION {format.volume}
-{ volume empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " volume * " 卷" * }
- { "volume" volume tie.or.space.connect }
+{ volume empty$ not
+ { volume is.number
+ { entry.lang lang.zh =
+ { "第 " volume * " 卷" * }
+ { "volume" volume tie.or.space.connect }
+ if$
+ }
+ { volume }
if$
}
+ { "" }
if$
}
FUNCTION {format.number}
-{ number empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " number * " 册" * }
- { "number" number tie.or.space.connect }
+{ number empty$ not
+ { number is.number
+ { entry.lang lang.zh =
+ { "第 " number * " 册" * }
+ { "number" number tie.or.space.connect }
+ if$
+ }
+ { number }
if$
}
+ { "" }
if$
}
@@ -706,6 +774,27 @@
if$
}
+FUNCTION {format.title.vol.num}
+{ title
+ sentence.case.title
+ 'change.sentence.case
+ 'skip$
+ if$
+ entry.numbered
+ { number empty$ not
+ { bbl.colon * number * }
+ 'skip$
+ if$
+ }
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
FUNCTION {format.series.vol.num.title}
{ format.volume.number 's :=
series empty$ not
@@ -714,28 +803,26 @@
'change.sentence.case
'skip$
if$
- bbl.colon *
- s empty$ not
- { s * bbl.wide.space * }
- 'skip$
+ entry.numbered
+ { bbl.wide.space * }
+ { bbl.colon *
+ s empty$ not
+ { s * bbl.wide.space * }
+ 'skip$
+ if$
+ }
if$
- title
+ title *
sentence.case.title
'change.sentence.case
'skip$
if$
- *
- }
- { title
- sentence.case.title
- 'change.sentence.case
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
'skip$
if$
- s empty$ not
- { bbl.colon * s * }
- 'skip$
- if$
}
+ { format.title.vol.num }
if$
link.title
'add.link
@@ -743,28 +830,44 @@
if$
}
+FUNCTION {format.booktitle.vol.num}
+{ booktitle
+ entry.numbered
+ 'skip$
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
FUNCTION {format.series.vol.num.booktitle}
{ format.volume.number 's :=
series empty$ not
{ series bbl.colon *
- s empty$ not
+ entry.numbered not s empty$ not and
{ s * bbl.wide.space * }
'skip$
if$
booktitle *
}
- { booktitle
- s empty$ not
- { bbl.colon * s * }
+ { format.booktitle.vol.num }
+ if$
+ in.booktitle
+ { duplicate$ empty$ not entry.lang lang.en = and
+ { "In: " swap$ * }
'skip$
if$
}
+ 'skip$
if$
}
FUNCTION {format.journal}
{ journal
- italic.jounal
+ italic.jounal entry.lang lang.en = and
'italicize
'skip$
if$
@@ -818,7 +921,7 @@
{ edition empty$
{ "" }
{ edition is.number
- { lang.zh entry.lang =
+ { entry.lang lang.zh =
{ edition " 版" * }
{ edition num.to.ordinal " ed." * }
if$
@@ -946,7 +1049,10 @@
{ date empty$ not
{ date extract.before.dash }
{ "empty year in " cite$ * warning$
- ""
+ urldate empty$ not
+ { "[" urldate extract.before.dash * "]" * }
+ { "" }
+ if$
}
if$
}
@@ -1001,6 +1107,17 @@
if$
}
+FUNCTION {format.journal.volume}
+{ volume empty$ not
+ { bold.journal.volume
+ { "\textbf{" volume * "}" * }
+ { volume }
+ if$
+ }
+ { "" }
+ if$
+}
+
FUNCTION {format.journal.number}
{ number empty$ not
{ "\penalty0 (" number * ")" * }
@@ -1199,7 +1316,9 @@
{ format.authors }
{ editor empty$ not
{ format.editors }
- { bbl.anonymous }
+ { "empty author and editor in " cite$ * warning$
+ bbl.anonymous
+ }
if$
}
if$
@@ -1230,7 +1349,7 @@
FUNCTION {incollection}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
period.between.author.year
'new.sentence
@@ -1262,7 +1381,7 @@
FUNCTION {periodical}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
period.between.author.year
'new.sentence
@@ -1287,7 +1406,7 @@
FUNCTION {article}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
period.between.author.year
'new.sentence
@@ -1300,7 +1419,7 @@
format.mark "" output.after
new.block
format.journal "journal" output.check
- volume output
+ format.journal.volume output
format.journal.number "" output.after
format.journal.pages "" output.after
format.urldate "" output.after
@@ -1321,12 +1440,7 @@
if$
format.year "year" output.check
new.block
- format.title
- number empty$ not
- { bbl.colon * number * }
- 'skip$
- if$
- "title" output.check
+ format.title "title" output.check
"P" set.entry.mark
format.mark "" output.after
new.block
@@ -1560,7 +1674,7 @@
{ t #1 "{ll}{ff}" format.name$}
if$
s num.names$ #1 >
- { bbl.space * bbl.et.al * }
+ { bbl.space * citation.et.al * }
'skip$
if$
}
@@ -1657,14 +1771,14 @@
FUNCTION {sort.language.label}
{ entry.lang lang.zh =
- { "a zh " }
+ { lang.zh.order }
{ entry.lang lang.ja =
- { "b ja " }
+ { lang.ja.order }
{ entry.lang lang.en =
- { "c en " }
+ { lang.en.order }
{ entry.lang lang.ru =
- { "d ru " }
- { "e other " }
+ { lang.ru.order }
+ { lang.other.order }
if$
}
if$
@@ -1672,6 +1786,7 @@
if$
}
if$
+ int.to.chr$
}
FUNCTION {sort.format.names}
@@ -1716,18 +1831,22 @@
}
FUNCTION {anonymous.sort}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "yi4 ming2" }
{ "anon" }
if$
}
+FUNCTION {warn.empty.key}
+{ entry.lang lang.zh =
+ { "empty key in " cite$ * warning$ }
+ 'skip$
+ if$
+}
+
FUNCTION {author.sort}
{ key empty$
- { entry.lang lang.zh =
- { "empty key in " cite$ * warning$ }
- 'skip$
- if$
+ { warn.empty.key
author empty$
{ anonymous.sort }
{ author sort.format.names }
@@ -1739,7 +1858,8 @@
FUNCTION {author.editor.sort}
{ key empty$
- { author empty$
+ { warn.empty.key
+ author empty$
{ editor empty$
{ anonymous.sort }
{ editor sort.format.names }
@@ -1754,7 +1874,8 @@
FUNCTION {author.organization.sort}
{ key empty$
- { author empty$
+ { warn.empty.key
+ author empty$
{ organization empty$
{ anonymous.sort }
{ "The " #4 organization chop.word sortify }
@@ -1769,7 +1890,8 @@
FUNCTION {editor.organization.sort}
{ key empty$
- { editor empty$
+ { warn.empty.key
+ editor empty$
{ organization empty$
{ anonymous.sort }
{ "The " #4 organization chop.word sortify }
@@ -1784,6 +1906,7 @@
FUNCTION {presort}
{ set.entry.lang
+ set.entry.numbered
show.url show.doi check.electronic
calc.label
label sortify
@@ -1872,16 +1995,12 @@
write$ newline$
"\providecommand{\natexlab}[1]{#1}"
write$ newline$
- show.url show.doi or
- { "\providecommand{\url}[1]{#1}"
- write$ newline$
- "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
- write$ newline$
- " \urlstyle{same}\fi"
- write$ newline$
- }
- 'skip$
- if$
+ "\providecommand{\url}[1]{#1}"
+ write$ newline$
+ "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
+ write$ newline$
+ " \urlstyle{same}\fi"
+ write$ newline$
show.doi
{ "\providecommand{\href}[2]{\url{#2}}"
write$ newline$
Modified: trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-unsrt.bst
===================================================================
--- trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-unsrt.bst 2019-03-21 20:24:13 UTC (rev 50503)
+++ trunk/Master/texmf-dist/bibtex/bst/gbt7714/gbt7714-unsrt.bst 2019-03-21 20:45:44 UTC (rev 50504)
@@ -5,10 +5,13 @@
%% The original source files were:
%%
%% gbt7714.dtx (with options: `2015,numerical')
-%% Version: 2018/08/05 v1.0.9
-%%
-%% Copyright (C) 2016-2018 by Zeping Lee <zepinglee AT gmail.com>
-%%
+%% -------------------------------------------------------------------
+%% GB/T 7714-2015 BibTeX Style
+%% https://github.com/CTeX-org/gbt7714-bibtex-style
+%% Version: 2019/03/21 v1.1.1
+%% -------------------------------------------------------------------
+%% Copyright (C) 2016-2019 by Zeping Lee <zepinglee AT gmail.com>
+%% -------------------------------------------------------------------
%% This file may be distributed and/or modified under the
%% conditions of the LaTeX Project Public License, either version 1.3c
%% of this license or (at your option) any later version.
@@ -16,8 +19,7 @@
%% https://www.latex-project.org/lppl.txt
%% and version 1.3c or later is part of all distributions of LaTeX
%% version 2005/12/01 or later.
-%%
-
+%% -------------------------------------------------------------------
INTEGERS {
uppercase.name
max.num.authors
@@ -25,7 +27,10 @@
sentence.case.title
link.title
show.mark
+ slash.for.extraction
+ in.booktitle
italic.jounal
+ bold.journal.volume
show.missing.address.publisher
show.url
show.doi
@@ -36,11 +41,13 @@
{
#1 'uppercase.name :=
#3 'max.num.authors :=
- #0 'period.between.author.year :=
#1 'sentence.case.title :=
#0 'link.title :=
#1 'show.mark :=
+ #1 'slash.for.extraction :=
+ #0 'in.booktitle :=
#0 'italic.jounal :=
+ #0 'bold.journal.volume :=
#1 'show.missing.address.publisher :=
#1 'show.url :=
#1 'show.doi :=
@@ -76,7 +83,7 @@
volume
year
}
- { entry.lang entry.is.electronic }
+ { entry.lang entry.is.electronic entry.numbered }
{ label extra.label sort.label short.list entry.mark entry.url }
INTEGERS { output.state before.all mid.sentence after.sentence after.block after.slash }
@@ -99,20 +106,25 @@
}
FUNCTION {bbl.anonymous}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "佚名" }
{ "Anon" }
if$
}
-FUNCTION {bbl.space} { "\ " }
+FUNCTION {bbl.space}
+{ entry.lang lang.zh =
+ { "\ " }
+ { " " }
+ if$
+}
FUNCTION {bbl.et.al}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "等" }
- { lang.ja entry.lang =
+ { entry.lang lang.ja =
{ "他" }
- { lang.ru entry.lang =
+ { entry.lang lang.ru =
{ "идр" }
{ "et~al." }
if$
@@ -122,14 +134,17 @@
if$
}
+FUNCTION {citation.et.al}
+{ bbl.et.al }
+
FUNCTION {bbl.colon} { ": " }
FUNCTION {bbl.wide.space} { "\quad " }
-FUNCTION {bbl.slash} { "//\allowbreak{}" }
+FUNCTION {bbl.slash} { "//\allowbreak " }
FUNCTION {bbl.sine.loco}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版地不详]" }
{ "[S.l.]" }
if$
@@ -136,7 +151,7 @@
}
FUNCTION {bbl.sine.nomine}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版者不详]" }
{ "[s.n.]" }
if$
@@ -143,7 +158,7 @@
}
FUNCTION {bbl.sine.loco.sine.nomine}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版地不详: 出版者不详]" }
{ "[S.l.: s.n.]" }
if$
@@ -181,7 +196,9 @@
{ output.state before.all =
'write$
{ output.state after.slash =
- { bbl.slash * write$ }
+ { bbl.slash * write$
+ newline$
+ }
{ add.period$ " " * write$ }
if$
}
@@ -274,7 +291,11 @@
FUNCTION {new.slash}
{ output.state before.all =
'skip$
- { after.slash 'output.state := }
+ { slash.for.extraction
+ { after.slash 'output.state := }
+ { after.block 'output.state := }
+ if$
+ }
if$
}
@@ -427,6 +448,15 @@
'entry.lang :=
}
+FUNCTION {set.entry.numbered}
+{ type$ "patent" =
+ type$ "standard" = or
+ type$ "techreport" = or
+ { #1 'entry.numbered := }
+ { #0 'entry.numbered := }
+ if$
+}
+
INTEGERS { nameptr namesleft numnames name.lang }
FUNCTION {format.names}
@@ -475,9 +505,11 @@
}
FUNCTION {format.authors}
-{ author empty$
- { "" }
+{ author empty$ not
{ author format.names }
+ { "empty author in " cite$ * warning$
+ ""
+ }
if$
}
@@ -492,7 +524,7 @@
{ translator empty$
{ "" }
{ translator format.names
- lang.zh entry.lang =
+ entry.lang lang.zh =
{ translator num.names$ #3 >
{ "译" * }
{ ", 译" * }
@@ -587,7 +619,20 @@
")" make.full.names duplicate$ short.list =
{ pop$ }
{ * }
- if$
+ if$
+ 's :=
+ s text.length$ 'charptr :=
+ { charptr #0 > }
+ { s charptr #1 substring$ "]" =
+ { #0 'charptr := }
+ { charptr #1 - 'charptr := }
+ if$
+ }
+ while$
+ charptr #0 >
+ { "{" s * "}" * }
+ { s }
+ if$
"]{" * write$
cite$ write$
"}" write$
@@ -604,15 +649,15 @@
}
FUNCTION {add.link}
- { url empty$ not
- { "\href{" url * "}{" * swap$ * "}" * }
- { doi empty$ not
- { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
- 'skip$
- if$
- }
- if$
- }
+{ url empty$ not
+ { "\href{" url * "}{" * swap$ * "}" * }
+ { doi empty$ not
+ { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
+ 'skip$
+ if$
+ }
+ if$
+}
FUNCTION {format.title}
{ title empty$
@@ -622,6 +667,10 @@
'change.sentence.case
'skip$
if$
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
+ 'skip$
+ if$
link.title
'add.link
'skip$
@@ -678,24 +727,32 @@
}
FUNCTION {format.volume}
-{ volume empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " volume * " 卷" * }
- { "volume" volume tie.or.space.connect }
+{ volume empty$ not
+ { volume is.number
+ { entry.lang lang.zh =
+ { "第 " volume * " 卷" * }
+ { "volume" volume tie.or.space.connect }
+ if$
+ }
+ { volume }
if$
}
+ { "" }
if$
}
FUNCTION {format.number}
-{ number empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " number * " 册" * }
- { "number" number tie.or.space.connect }
+{ number empty$ not
+ { number is.number
+ { entry.lang lang.zh =
+ { "第 " number * " 册" * }
+ { "number" number tie.or.space.connect }
+ if$
+ }
+ { number }
if$
}
+ { "" }
if$
}
@@ -706,6 +763,27 @@
if$
}
+FUNCTION {format.title.vol.num}
+{ title
+ sentence.case.title
+ 'change.sentence.case
+ 'skip$
+ if$
+ entry.numbered
+ { number empty$ not
+ { bbl.colon * number * }
+ 'skip$
+ if$
+ }
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
FUNCTION {format.series.vol.num.title}
{ format.volume.number 's :=
series empty$ not
@@ -714,28 +792,26 @@
'change.sentence.case
'skip$
if$
- bbl.colon *
- s empty$ not
- { s * bbl.wide.space * }
- 'skip$
+ entry.numbered
+ { bbl.wide.space * }
+ { bbl.colon *
+ s empty$ not
+ { s * bbl.wide.space * }
+ 'skip$
+ if$
+ }
if$
- title
+ title *
sentence.case.title
'change.sentence.case
'skip$
if$
- *
- }
- { title
- sentence.case.title
- 'change.sentence.case
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
'skip$
if$
- s empty$ not
- { bbl.colon * s * }
- 'skip$
- if$
}
+ { format.title.vol.num }
if$
link.title
'add.link
@@ -743,28 +819,44 @@
if$
}
+FUNCTION {format.booktitle.vol.num}
+{ booktitle
+ entry.numbered
+ 'skip$
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
FUNCTION {format.series.vol.num.booktitle}
{ format.volume.number 's :=
series empty$ not
{ series bbl.colon *
- s empty$ not
+ entry.numbered not s empty$ not and
{ s * bbl.wide.space * }
'skip$
if$
booktitle *
}
- { booktitle
- s empty$ not
- { bbl.colon * s * }
+ { format.booktitle.vol.num }
+ if$
+ in.booktitle
+ { duplicate$ empty$ not entry.lang lang.en = and
+ { "In: " swap$ * }
'skip$
if$
}
+ 'skip$
if$
}
FUNCTION {format.journal}
{ journal
- italic.jounal
+ italic.jounal entry.lang lang.en = and
'italicize
'skip$
if$
@@ -818,7 +910,7 @@
{ edition empty$
{ "" }
{ edition is.number
- { lang.zh entry.lang =
+ { entry.lang lang.zh =
{ edition " 版" * }
{ edition num.to.ordinal " ed." * }
if$
@@ -946,7 +1038,10 @@
{ date empty$ not
{ date extract.before.dash }
{ "empty year in " cite$ * warning$
- ""
+ urldate empty$ not
+ { "[" urldate extract.before.dash * "]" * }
+ { "" }
+ if$
}
if$
}
@@ -1001,6 +1096,17 @@
if$
}
+FUNCTION {format.journal.volume}
+{ volume empty$ not
+ { bold.journal.volume
+ { "\textbf{" volume * "}" * }
+ { volume }
+ if$
+ }
+ { "" }
+ if$
+}
+
FUNCTION {format.journal.number}
{ number empty$ not
{ "\penalty0 (" number * ")" * }
@@ -1199,7 +1305,9 @@
{ format.authors }
{ editor empty$ not
{ format.editors }
- { "" }
+ { "empty author and editor in " cite$ * warning$
+ ""
+ }
if$
}
if$
@@ -1226,7 +1334,7 @@
FUNCTION {incollection}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
new.block
format.title "title" output.check
@@ -1254,7 +1362,7 @@
FUNCTION {periodical}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
new.block
format.title "title" output.check
@@ -1275,7 +1383,7 @@
FUNCTION {article}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
new.block
format.title "title" output.check
@@ -1284,7 +1392,7 @@
new.block
format.journal "journal" output.check
format.date "year" output.check
- volume output
+ format.journal.volume output
format.journal.number "" output.after
format.journal.pages "" output.after
format.urldate "" output.after
@@ -1300,12 +1408,7 @@
format.authors output
author format.key output
new.block
- format.title
- number empty$ not
- { bbl.colon * number * }
- 'skip$
- if$
- "title" output.check
+ format.title "title" output.check
"P" set.entry.mark
format.mark "" output.after
new.block
@@ -1538,7 +1641,7 @@
{ t #1 "{ll}{ff}" format.name$}
if$
s num.names$ #1 >
- { bbl.space * bbl.et.al * }
+ { bbl.space * citation.et.al * }
'skip$
if$
}
@@ -1645,6 +1748,7 @@
FUNCTION {presort}
{ set.entry.lang
+ set.entry.numbered
show.url show.doi check.electronic
calc.label
label sortify
@@ -1712,16 +1816,12 @@
write$ newline$
"\providecommand{\natexlab}[1]{#1}"
write$ newline$
- show.url show.doi or
- { "\providecommand{\url}[1]{#1}"
- write$ newline$
- "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
- write$ newline$
- " \urlstyle{same}\fi"
- write$ newline$
- }
- 'skip$
- if$
+ "\providecommand{\url}[1]{#1}"
+ write$ newline$
+ "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
+ write$ newline$
+ " \urlstyle{same}\fi"
+ write$ newline$
show.doi
{ "\providecommand{\href}[2]{\url{#2}}"
write$ newline$
Modified: trunk/Master/texmf-dist/doc/bibtex/gbt7714/README.md
===================================================================
--- trunk/Master/texmf-dist/doc/bibtex/gbt7714/README.md 2019-03-21 20:24:13 UTC (rev 50503)
+++ trunk/Master/texmf-dist/doc/bibtex/gbt7714/README.md 2019-03-21 20:45:44 UTC (rev 50504)
@@ -2,20 +2,24 @@
[![CTAN](https://img.shields.io/ctan/v/gbt7714.svg)](https://ctan.org/pkg/gbt7714)
-[![GitHub release](https://img.shields.io/github/release/zepinglee/gbt7714-bibtex-style/all.svg)](https://github.com/zepinglee/gbt7714-bibtex-style/releases/latest)
-[![GitHub commits](https://img.shields.io/github/commits-since/zepinglee/gbt7714-bibtex-style/latest.svg)](https://github.com/zepinglee/gbt7714-bibtex-style/commits/master)
-[![Travis build](https://travis-ci.org/zepinglee/gbt7714-bibtex-style.svg?branch=master)](https://travis-ci.org/zepinglee/gbt7714-bibtex-style)
+[![GitHub release](https://img.shields.io/github/release/CTeX-org/gbt7714-bibtex-style/all.svg)](https://github.com/CTeX-org/gbt7714-bibtex-style/releases/latest)
+[![GitHub commits](https://img.shields.io/github/commits-since/CTeX-org/gbt7714-bibtex-style/latest.svg)](https://github.com/CTeX-org/gbt7714-bibtex-style/commits/master)
+[![Travis build](https://travis-ci.org/CTeX-org/gbt7714-bibtex-style.svg?branch=master)](https://travis-ci.org/CTeX-org/gbt7714-bibtex-style)
## Introduction
-The `gbt7714` package provides a BibTEX implementation for the China's
+The `gbt7714` package provides a BibTeX implementation for the China's
bibliography style standard GB/T 7714-2015.
-It consists of two bst files for numerical and authoryear styles as well as a
+It consists of two `bst` files for numerical and authoryear styles as well as a
LaTeX package which provides the citation style defined in the standard.
It is compatible with `natbib` and supports language detection (Chinese
and English) for each biblilography entry.
+- Homepage: https://github.com/CTeX-org/gbt7714-bibtex-style
+- Maintainer: Zeping Lee
+- Email: zeinglee AT gmail DOT com
+- License: LaTeX Project Public License 1.3c or later
## 新特性
@@ -49,8 +53,8 @@
## 注意事项
-2. **不再**需要调用 `\bibliographystyle` 命令。
-1. `bib` 数据库应使用 UTF-8 编码。
+1. **不再**需要调用 `\bibliographystyle` 命令。
+2. `bib` 数据库应使用 UTF-8 编码。
3. 使用著者-出版年制参考文献表时,中文的文献**必须**在 `key` 域填写
著者姓名的拼音,才能按照拼音排序,比如:
```
Modified: trunk/Master/texmf-dist/doc/bibtex/gbt7714/gbt7714.pdf
===================================================================
(Binary files differ)
Added: trunk/Master/texmf-dist/doc/bibtex/gbt7714/y.tex
===================================================================
--- trunk/Master/texmf-dist/doc/bibtex/gbt7714/y.tex (rev 0)
+++ trunk/Master/texmf-dist/doc/bibtex/gbt7714/y.tex 2019-03-21 20:45:44 UTC (rev 50504)
@@ -0,0 +1,2092 @@
+%%
+%% This is file `versions/thu/thuthesis-bachelor.bst',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% gbt7714.dtx (with options: `2015,numerical')
+%% -------------------------------------------------------------------
+%% GB/T 7714-2015 BibTeX Style
+%% https://github.com/CTeX-org/gbt7714-bibtex-style
+%% Version: 2019/03/21 v1.1.1
+%% -------------------------------------------------------------------
+%% Copyright (C) 2016-2019 by Zeping Lee <zepinglee AT gmail.com>
+%% -------------------------------------------------------------------
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either version 1.3c
+%% of this license or (at your option) any later version.
+%% The latest version of this license is in
+%% https://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of LaTeX
+%% version 2005/12/01 or later.
+%% -------------------------------------------------------------------
+INTEGERS {
+ uppercase.name
+ max.num.authors
+ period.between.author.year
+ sentence.case.title
+ link.title
+ show.mark
+ slash.for.extraction
+ in.booktitle
+ italic.jounal
+ bold.journal.volume
+ show.missing.address.publisher
+ show.url
+ show.doi
+ show.note
+}
+
+FUNCTION {load.config}
+{
+ #1 'uppercase.name :=
+ #3 'max.num.authors :=
+ #1 'sentence.case.title :=
+ #0 'link.title :=
+ #1 'show.mark :=
+ #1 'slash.for.extraction :=
+ #0 'in.booktitle :=
+ #0 'italic.jounal :=
+ #0 'bold.journal.volume :=
+ #1 'show.missing.address.publisher :=
+ #1 'show.url :=
+ #1 'show.doi :=
+ #0 'show.note :=
+}
+
+ENTRY
+ { address
+ author
+ booktitle
+ date
+ doi
+ edition
+ editor
+ howpublished
+ institution
+ journal
+ key
+ language
+ mark
+ medium
+ note
+ number
+ organization
+ pages
+ publisher
+ school
+ series
+ title
+ translator
+ url
+ urldate
+ volume
+ year
+ }
+ { entry.lang entry.is.electronic entry.numbered }
+ { label extra.label sort.label short.list entry.mark entry.url }
+
+INTEGERS { output.state before.all mid.sentence after.sentence after.block after.slash }
+
+INTEGERS { lang.zh lang.ja lang.en lang.ru lang.other }
+
+INTEGERS { charptr len }
+
+FUNCTION {init.state.consts}
+{ #0 'before.all :=
+ #1 'mid.sentence :=
+ #2 'after.sentence :=
+ #3 'after.block :=
+ #4 'after.slash :=
+ #3 'lang.zh :=
+ #4 'lang.ja :=
+ #1 'lang.en :=
+ #2 'lang.ru :=
+ #0 'lang.other :=
+}
+
+FUNCTION {bbl.anonymous}
+{ entry.lang lang.zh =
+ { "佚名" }
+ { "Anon" }
+ if$
+}
+
+FUNCTION {bbl.space}
+{ entry.lang lang.zh =
+ { "\ " }
+ { " " }
+ if$
+}
+
+FUNCTION {bbl.et.al}
+{ entry.lang lang.zh =
+ { "等" }
+ { entry.lang lang.ja =
+ { "他" }
+ { entry.lang lang.ru =
+ { "идр" }
+ { "et~al." }
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {citation.et.al}
+{ bbl.et.al }
+
+FUNCTION {bbl.colon} { ": " }
+
+FUNCTION {bbl.wide.space} { "\quad " }
+
+FUNCTION {bbl.slash} { "//\allowbreak " }
+
+FUNCTION {bbl.sine.loco}
+{ entry.lang lang.zh =
+ { "[出版地不详]" }
+ { "[S.l.]" }
+ if$
+}
+
+FUNCTION {bbl.sine.nomine}
+{ entry.lang lang.zh =
+ { "[出版者不详]" }
+ { "[s.n.]" }
+ if$
+}
+
+FUNCTION {bbl.sine.loco.sine.nomine}
+{ entry.lang lang.zh =
+ { "[出版地不详: 出版者不详]" }
+ { "[S.l.: s.n.]" }
+ if$
+}
+
+FUNCTION {not}
+{ { #0 }
+ { #1 }
+ if$
+}
+
+FUNCTION {and}
+{ 'skip$
+ { pop$ #0 }
+ if$
+}
+
+FUNCTION {or}
+{ { pop$ #1 }
+ 'skip$
+ if$
+}
+
+STRINGS { s t }
+
+FUNCTION {output.nonnull}
+{ 's :=
+ output.state mid.sentence =
+ { ", " * write$ }
+ { output.state after.block =
+ { add.period$ write$
+ newline$
+ "\newblock " write$
+ }
+ { output.state before.all =
+ 'write$
+ { output.state after.slash =
+ { bbl.slash * write$
+ newline$
+ }
+ { add.period$ " " * write$ }
+ if$
+ }
+ if$
+ }
+ if$
+ mid.sentence 'output.state :=
+ }
+ if$
+ s
+}
+
+FUNCTION {output}
+{ duplicate$ empty$
+ 'pop$
+ 'output.nonnull
+ if$
+}
+
+FUNCTION {output.after}
+{ 't :=
+ duplicate$ empty$
+ 'pop$
+ { 's :=
+ output.state mid.sentence =
+ { t * write$ }
+ { output.state after.block =
+ { add.period$ write$
+ newline$
+ "\newblock " write$
+ }
+ { output.state before.all =
+ 'write$
+ { output.state after.slash =
+ { bbl.slash * write$ }
+ { add.period$ " " * write$ }
+ if$
+ }
+ if$
+ }
+ if$
+ mid.sentence 'output.state :=
+ }
+ if$
+ s
+ }
+ if$
+}
+
+FUNCTION {output.check}
+{ 't :=
+ duplicate$ empty$
+ { pop$ "empty " t * " in " * cite$ * warning$ }
+ 'output.nonnull
+ if$
+}
+
+FUNCTION {fin.entry}
+{ add.period$
+ write$
+ newline$
+}
+
+FUNCTION {new.block}
+{ output.state before.all =
+ 'skip$
+ { output.state after.slash =
+ 'skip$
+ { after.block 'output.state := }
+ if$
+ }
+ if$
+}
+
+FUNCTION {new.sentence}
+{ output.state after.block =
+ 'skip$
+ { output.state before.all =
+ 'skip$
+ { output.state after.slash =
+ 'skip$
+ { after.sentence 'output.state := }
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {new.slash}
+{ output.state before.all =
+ 'skip$
+ { slash.for.extraction
+ { after.slash 'output.state := }
+ { after.block 'output.state := }
+ if$
+ }
+ if$
+}
+
+FUNCTION {new.block.checka}
+{ empty$
+ 'skip$
+ 'new.block
+ if$
+}
+
+FUNCTION {new.block.checkb}
+{ empty$
+ swap$ empty$
+ and
+ 'skip$
+ 'new.block
+ if$
+}
+
+FUNCTION {new.sentence.checka}
+{ empty$
+ 'skip$
+ 'new.sentence
+ if$
+}
+
+FUNCTION {new.sentence.checkb}
+{ empty$
+ swap$ empty$
+ and
+ 'skip$
+ 'new.sentence
+ if$
+}
+
+FUNCTION {field.or.null}
+{ duplicate$ empty$
+ { pop$ "" }
+ 'skip$
+ if$
+}
+
+FUNCTION {italicize}
+{ duplicate$ empty$
+ { pop$ "" }
+ { "\textit{" swap$ * "}" * }
+ if$
+}
+
+INTEGERS { byte second.byte }
+
+INTEGERS { char.lang tmp.lang }
+
+STRINGS { tmp.str }
+
+FUNCTION {get.str.lang}
+{ 'tmp.str :=
+ lang.other 'tmp.lang :=
+ #1 'charptr :=
+ tmp.str text.length$ #1 + 'len :=
+ { charptr len < }
+ { tmp.str charptr #1 substring$ chr.to.int$ 'byte :=
+ byte #128 <
+ { charptr #1 + 'charptr :=
+ byte #64 > byte #91 < and byte #96 > byte #123 < and or
+ { lang.en 'char.lang := }
+ { lang.other 'char.lang := }
+ if$
+ }
+ { tmp.str charptr #1 + #1 substring$ chr.to.int$ 'second.byte :=
+ byte #224 <
+ { charptr #2 + 'charptr :=
+ byte #207 > byte #212 < and
+ byte #212 = second.byte #176 < and or
+ { lang.ru 'char.lang := }
+ { lang.other 'char.lang := }
+ if$
+ }
+ { byte #240 <
+ { charptr #3 + 'charptr :=
+ byte #227 > byte #234 < and
+ { lang.zh 'char.lang := }
+ { byte #227 =
+ { second.byte #143 >
+ { lang.zh 'char.lang := }
+ { second.byte #128 > second.byte #132 < and
+ { lang.ja 'char.lang := }
+ { lang.other 'char.lang := }
+ if$
+ }
+ if$
+ }
+ { byte #239 =
+ second.byte #163 > second.byte #172 < and and
+ { lang.zh 'char.lang := }
+ { lang.other 'char.lang := }
+ if$
+ }
+ if$
+ }
+ if$
+ }
+ { charptr #4 + 'charptr :=
+ byte #240 = second.byte #159 > and
+ { lang.zh 'char.lang := }
+ { lang.other 'char.lang := }
+ if$
+ }
+ if$
+ }
+ if$
+ }
+ if$
+ char.lang tmp.lang >
+ { char.lang 'tmp.lang := }
+ 'skip$
+ if$
+ }
+ while$
+ tmp.lang
+}
+
+FUNCTION {check.entry.lang}
+{ author field.or.null
+ title field.or.null *
+ get.str.lang
+}
+
+FUNCTION {set.entry.lang}
+{ language empty$
+ { check.entry.lang }
+ { language "english" = language "american" = or language "british" = or
+ { lang.en }
+ { language "chinese" =
+ { lang.zh }
+ { language "japanese" =
+ { lang.ja }
+ { language "russian" =
+ { lang.ru }
+ { check.entry.lang }
+ if$
+ }
+ if$
+ }
+ if$
+ }
+ if$
+ }
+ if$
+ 'entry.lang :=
+}
+
+FUNCTION {set.entry.numbered}
+{ type$ "patent" =
+ type$ "standard" = or
+ type$ "techreport" = or
+ { #1 'entry.numbered := }
+ { #0 'entry.numbered := }
+ if$
+}
+
+INTEGERS { nameptr namesleft numnames name.lang }
+
+FUNCTION {format.names}
+{ 's :=
+ #1 'nameptr :=
+ s num.names$ 'numnames :=
+ numnames 'namesleft :=
+ { namesleft #0 > }
+ { s nameptr "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
+ nameptr max.num.authors >
+ { bbl.et.al
+ #1 'namesleft :=
+ }
+ { t "others" =
+ { bbl.et.al }
+ { t get.str.lang 'name.lang :=
+ name.lang lang.en =
+ { t #1 "{vv~}{ll}{~f{~}}" format.name$
+ uppercase.name
+ { "u" change.case$ }
+ 'skip$
+ if$
+ t #1 "{, jj}" format.name$ *
+ }
+ { t #1 "{ll}{ff}" format.name$ }
+ if$
+ }
+ if$
+ }
+ if$
+ nameptr #1 >
+ { ", " swap$ * * }
+ 'skip$
+ if$
+ nameptr #1 + 'nameptr :=
+ namesleft #1 - 'namesleft :=
+ }
+ while$
+}
+
+FUNCTION {format.key}
+{ empty$
+ { key field.or.null }
+ { "" }
+ if$
+}
+
+FUNCTION {format.authors}
+{ author empty$ not
+ { author format.names }
+ { "empty author in " cite$ * warning$
+ ""
+ }
+ if$
+}
+
+FUNCTION {format.editors}
+{ editor empty$
+ { "" }
+ { editor format.names }
+ if$
+}
+
+FUNCTION {format.translators}
+{ translator empty$
+ { "" }
+ { translator format.names
+ entry.lang lang.zh =
+ { translator num.names$ #3 >
+ { "译" * }
+ { ", 译" * }
+ if$
+ }
+ 'skip$
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.full.names}
+{'s :=
+ #1 'nameptr :=
+ s num.names$ 'numnames :=
+ numnames 'namesleft :=
+ { namesleft #0 > }
+ { s nameptr "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
+ t get.str.lang 'name.lang :=
+ name.lang lang.en =
+ { t #1 "{vv~}{ll}" format.name$ 't := }
+ { t #1 "{ll}{ff}" format.name$ 't := }
+ if$
+ nameptr #1 >
+ {
+ namesleft #1 >
+ { ", " * t * }
+ {
+ numnames #2 >
+ { "," * }
+ 'skip$
+ if$
+ t "others" =
+ { " et~al." * }
+ { " and " * t * }
+ if$
+ }
+ if$
+ }
+ 't
+ if$
+ nameptr #1 + 'nameptr :=
+ namesleft #1 - 'namesleft :=
+ }
+ while$
+}
+
+FUNCTION {author.editor.full}
+{ author empty$
+ { editor empty$
+ { "" }
+ { editor format.full.names }
+ if$
+ }
+ { author format.full.names }
+ if$
+}
+
+FUNCTION {author.full}
+{ author empty$
+ { "" }
+ { author format.full.names }
+ if$
+}
+
+FUNCTION {editor.full}
+{ editor empty$
+ { "" }
+ { editor format.full.names }
+ if$
+}
+
+FUNCTION {make.full.names}
+{ type$ "book" =
+ type$ "inbook" =
+ or
+ 'author.editor.full
+ { type$ "collection" =
+ type$ "proceedings" =
+ or
+ 'editor.full
+ 'author.full
+ if$
+ }
+ if$
+}
+
+FUNCTION {output.bibitem}
+{ newline$
+ "\bibitem[" write$
+ label write$
+ ")" make.full.names duplicate$ short.list =
+ { pop$ }
+ { * }
+ if$
+ 's :=
+ s text.length$ 'charptr :=
+ { charptr #0 > }
+ { s charptr #1 substring$ "]" =
+ { #0 'charptr := }
+ { charptr #1 - 'charptr := }
+ if$
+ }
+ while$
+ charptr #0 >
+ { "{" s * "}" * }
+ { s }
+ if$
+ "]{" * write$
+ cite$ write$
+ "}" write$
+ newline$
+ ""
+ before.all 'output.state :=
+}
+
+FUNCTION {change.sentence.case}
+{ entry.lang lang.en =
+ { "t" change.case$ }
+ 'skip$
+ if$
+}
+
+FUNCTION {add.link}
+{ url empty$ not
+ { "\href{" url * "}{" * swap$ * "}" * }
+ { doi empty$ not
+ { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.title}
+{ title empty$
+ { "" }
+ { title
+ sentence.case.title
+ 'change.sentence.case
+ 'skip$
+ if$
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
+ 'skip$
+ if$
+ link.title
+ 'add.link
+ 'skip$
+ if$
+ }
+ if$
+}
+
+FUNCTION {tie.or.space.connect}
+{ duplicate$ text.length$ #3 <
+ { "~" }
+ { " " }
+ if$
+ swap$ * *
+}
+
+FUNCTION {either.or.check}
+{ empty$
+ 'pop$
+ { "can't use both " swap$ * " fields in " * cite$ * warning$ }
+ if$
+}
+
+FUNCTION {is.digit}
+{ duplicate$ empty$
+ { pop$ #0 }
+ { chr.to.int$
+ duplicate$ "0" chr.to.int$ <
+ { pop$ #0 }
+ { "9" chr.to.int$ >
+ { #0 }
+ { #1 }
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {is.number}
+{ 's :=
+ s empty$
+ { #0 }
+ { s text.length$ 'charptr :=
+ { charptr #0 >
+ s charptr #1 substring$ is.digit
+ and
+ }
+ { charptr #1 - 'charptr := }
+ while$
+ charptr not
+ }
+ if$
+}
+
+FUNCTION {format.volume}
+{ volume empty$ not
+ { volume is.number
+ { entry.lang lang.zh =
+ { "第 " volume * " 卷" * }
+ { "volume" volume tie.or.space.connect }
+ if$
+ }
+ { volume }
+ if$
+ }
+ { "" }
+ if$
+}
+
+FUNCTION {format.number}
+{ number empty$ not
+ { number is.number
+ { entry.lang lang.zh =
+ { "第 " number * " 册" * }
+ { "number" number tie.or.space.connect }
+ if$
+ }
+ { number }
+ if$
+ }
+ { "" }
+ if$
+}
+
+FUNCTION {format.volume.number}
+{ volume empty$ not
+ { format.volume }
+ { format.number }
+ if$
+}
+
+FUNCTION {format.title.vol.num}
+{ title
+ sentence.case.title
+ 'change.sentence.case
+ 'skip$
+ if$
+ entry.numbered
+ { number empty$ not
+ { bbl.colon * number * }
+ 'skip$
+ if$
+ }
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.series.vol.num.title}
+{ format.volume.number 's :=
+ series empty$ not
+ { series
+ sentence.case.title
+ 'change.sentence.case
+ 'skip$
+ if$
+ entry.numbered
+ { bbl.wide.space * }
+ { bbl.colon *
+ s empty$ not
+ { s * bbl.wide.space * }
+ 'skip$
+ if$
+ }
+ if$
+ title *
+ sentence.case.title
+ 'change.sentence.case
+ 'skip$
+ if$
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
+ 'skip$
+ if$
+ }
+ { format.title.vol.num }
+ if$
+ link.title
+ 'add.link
+ 'skip$
+ if$
+}
+
+FUNCTION {format.booktitle.vol.num}
+{ booktitle
+ entry.numbered
+ 'skip$
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.series.vol.num.booktitle}
+{ format.volume.number 's :=
+ series empty$ not
+ { series bbl.colon *
+ entry.numbered not s empty$ not and
+ { s * bbl.wide.space * }
+ 'skip$
+ if$
+ booktitle *
+ }
+ { format.booktitle.vol.num }
+ if$
+ in.booktitle
+ { duplicate$ empty$ not entry.lang lang.en = and
+ { "In: " swap$ * }
+ 'skip$
+ if$
+ }
+ 'skip$
+ if$
+}
+
+FUNCTION {format.journal}
+{ journal
+ italic.jounal entry.lang lang.en = and
+ 'italicize
+ 'skip$
+ if$
+}
+
+FUNCTION {set.entry.mark}
+{ entry.mark empty$ not
+ 'pop$
+ { mark empty$ not
+ { pop$ mark 'entry.mark := }
+ { 'entry.mark := }
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.mark}
+{ show.mark
+ { medium empty$ not
+ { entry.mark "/" * medium * 'entry.mark := }
+ { entry.is.electronic
+ { entry.mark "/OL" * 'entry.mark := }
+ 'skip$
+ if$
+ }
+ if$
+ "\allowbreak[" entry.mark * "]" *
+ }
+ { "" }
+ if$
+}
+
+FUNCTION {num.to.ordinal}
+{ duplicate$ text.length$ 'charptr :=
+ duplicate$ charptr #1 substring$ 's :=
+ s "1" =
+ { "st" * }
+ { s "2" =
+ { "nd" * }
+ { s "3" =
+ { "rd" * }
+ { "th" * }
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.edition}
+{ edition empty$
+ { "" }
+ { edition is.number
+ { entry.lang lang.zh =
+ { edition " 版" * }
+ { edition num.to.ordinal " ed." * }
+ if$
+ }
+ { entry.lang lang.en =
+ { edition change.sentence.case 's :=
+ s "Revised" = s "Revised edition" = or
+ { "Rev. ed." }
+ { s " ed." *}
+ if$
+ }
+ { edition }
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.publisher}
+{ publisher empty$ not
+ { publisher }
+ { school empty$ not
+ { school }
+ { organization empty$ not
+ { organization }
+ { institution empty$ not
+ { institution }
+ { "" }
+ if$
+ }
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.address.publisher}
+{ address empty$ not
+ { address
+ format.publisher empty$ not
+ { bbl.colon * format.publisher * }
+ { entry.is.electronic not show.missing.address.publisher and
+ { bbl.colon * bbl.sine.nomine * }
+ 'skip$
+ if$
+ }
+ if$
+ }
+ { entry.is.electronic not show.missing.address.publisher and
+ { format.publisher empty$ not
+ { bbl.sine.loco bbl.colon * format.publisher * }
+ { bbl.sine.loco.sine.nomine }
+ if$
+ }
+ { format.publisher empty$ not
+ { format.publisher }
+ { "" }
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {extract.before.dash}
+{ duplicate$ empty$
+ { pop$ "" }
+ { 's :=
+ #1 'charptr :=
+ s text.length$ #1 + 'len :=
+ { charptr len <
+ s charptr #1 substring$ "-" = not
+ and
+ }
+ { charptr #1 + 'charptr := }
+ while$
+ s #1 charptr #1 - substring$
+ }
+ if$
+}
+
+FUNCTION {extract.after.dash}
+{ duplicate$ empty$
+ { pop$ "" }
+ { 's :=
+ #1 'charptr :=
+ s text.length$ #1 + 'len :=
+ { charptr len <
+ s charptr #1 substring$ "-" = not
+ and
+ }
+ { charptr #1 + 'charptr := }
+ while$
+ { charptr len <
+ s charptr #1 substring$ "-" =
+ and
+ }
+ { charptr #1 + 'charptr := }
+ while$
+ s charptr global.max$ substring$
+ }
+ if$
+}
+
+FUNCTION {contains.dash}
+{ duplicate$ empty$
+ { pop$ #0 }
+ { 's :=
+ { s empty$ not
+ s #1 #1 substring$ "-" = not
+ and
+ }
+ { s #2 global.max$ substring$ 's := }
+ while$
+ s empty$ not
+ }
+ if$
+}
+
+FUNCTION {format.year}
+{ year empty$ not
+ { year extract.before.dash }
+ { date empty$ not
+ { date extract.before.dash }
+ { "empty year in " cite$ * warning$
+ urldate empty$ not
+ { "[" urldate extract.before.dash * "]" * }
+ { "" }
+ if$
+ }
+ if$
+ }
+ if$
+ extra.label *
+}
+
+FUNCTION {format.date}
+{ type$ "patent" = type$ "newspaper" = or
+ date empty$ not and
+ { date }
+ { year }
+ if$
+}
+
+FUNCTION {format.editdate}
+{ date empty$ not
+ { "\allowbreak(" date * ")" * }
+ { "" }
+ if$
+}
+
+FUNCTION {format.urldate}
+{ urldate empty$ not entry.is.electronic and
+ { "\allowbreak[" urldate * "]" * }
+ { "" }
+ if$
+}
+
+FUNCTION {hyphenate}
+{ 't :=
+ ""
+ { t empty$ not }
+ { t #1 #1 substring$ "-" =
+ { "-" *
+ { t #1 #1 substring$ "-" = }
+ { t #2 global.max$ substring$ 't := }
+ while$
+ }
+ { t #1 #1 substring$ *
+ t #2 global.max$ substring$ 't :=
+ }
+ if$
+ }
+ while$
+}
+
+FUNCTION {format.pages}
+{ pages empty$
+ { "" }
+ { pages hyphenate }
+ if$
+}
+
+FUNCTION {format.journal.volume}
+{ volume empty$ not
+ { bold.journal.volume
+ { "\textbf{" volume * "}" * }
+ { volume }
+ if$
+ }
+ { "" }
+ if$
+}
+
+FUNCTION {format.journal.number}
+{ number empty$ not
+ { "\penalty0 (" number * ")" * }
+ { "" }
+ if$
+}
+
+FUNCTION {format.journal.pages}
+{ pages empty$
+ { "" }
+ { ":\penalty0 " pages hyphenate * }
+ if$
+}
+
+FUNCTION {format.periodical.year.volume.number}
+{ year empty$ not
+ { year extract.before.dash }
+ { "empty year in periodical " cite$ * warning$ }
+ if$
+ volume empty$ not
+ { ", " * volume extract.before.dash * }
+ 'skip$
+ if$
+ number empty$ not
+ { "\penalty0 (" * number extract.before.dash * ")" * }
+ 'skip$
+ if$
+ year contains.dash
+ { "--" *
+ year extract.after.dash empty$
+ volume extract.after.dash empty$ and
+ number extract.after.dash empty$ and not
+ { year extract.after.dash empty$ not
+ { year extract.after.dash * }
+ { year extract.before.dash * }
+ if$
+ volume empty$ not
+ { ", " * volume extract.after.dash * }
+ 'skip$
+ if$
+ number empty$ not
+ { "\penalty0 (" * number extract.after.dash * ")" * }
+ 'skip$
+ if$
+ }
+ 'skip$
+ if$
+ }
+ 'skip$
+ if$
+}
+
+FUNCTION {check.url}
+{ url empty$ not
+ { "\url{" url * "}" * 'entry.url :=
+ #1 'entry.is.electronic :=
+ }
+ { howpublished empty$ not
+ { howpublished #1 #5 substring$ "\url{" =
+ { howpublished 'entry.url :=
+ #1 'entry.is.electronic :=
+ }
+ 'skip$
+ if$
+ }
+ { note empty$ not
+ { note #1 #5 substring$ "\url{" =
+ { note 'entry.url :=
+ #1 'entry.is.electronic :=
+ }
+ 'skip$
+ if$
+ }
+ 'skip$
+ if$
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.url}
+{ entry.url empty$ not
+ { new.block entry.url }
+ { "" }
+ if$
+}
+
+FUNCTION {check.doi}
+{ doi empty$ not
+ { #1 'entry.is.electronic := }
+ 'skip$
+ if$
+}
+
+FUNCTION {is.in.url}
+{ 's :=
+ s empty$
+ { #1 }
+ { entry.url empty$
+ { #0 }
+ { s text.length$ 'len :=
+ entry.url text.length$ 'charptr :=
+ { entry.url charptr len substring$ s = not
+ charptr #0 >
+ and
+ }
+ { charptr #1 - 'charptr := }
+ while$
+ charptr
+ }
+ if$
+ }
+ if$
+}
+
+FUNCTION {format.doi}
+{ ""
+ doi empty$ not show.doi and
+ { "" 's :=
+ doi 't :=
+ #0 'numnames :=
+ { t empty$ not}
+ { t #1 #1 substring$ 'tmp.str :=
+ tmp.str "," = tmp.str " " = or t #2 #1 substring$ empty$ or
+ { t #2 #1 substring$ empty$
+ { s tmp.str * 's := }
+ 'skip$
+ if$
+ s empty$ s is.in.url or
+ 'skip$
+ { numnames #1 + 'numnames :=
+ numnames #1 >
+ { ", " * }
+ { "DOI: " * }
+ if$
+ "\doi{" s * "}" * *
+ }
+ if$
+ "" 's :=
+ }
+ { s tmp.str * 's := }
+ if$
+ t #2 global.max$ substring$ 't :=
+ }
+ while$
+ 's :=
+ s empty$ not
+ { new.block s }
+ { "" }
+ if$
+ }
+ 'skip$
+ if$
+}
+
+FUNCTION {check.electronic}
+{ "" 'entry.url :=
+ #0 'entry.is.electronic :=
+ 'check.doi
+ 'skip$
+ if$
+ 'check.url
+ 'skip$
+ if$
+ medium empty$ not
+ { medium "MT" = medium "DK" = or medium "CD" = or medium "OL" = or
+ { #1 'entry.is.electronic := }
+ 'skip$
+ if$
+ }
+ 'skip$
+ if$
+}
+
+FUNCTION {format.note}
+{ note empty$ not show.note and
+ { note }
+ { "" }
+ if$
+}
+
+FUNCTION {empty.misc.check}
+{ author empty$ title empty$
+ year empty$
+ and and
+ key empty$ not and
+ { "all relevant fields are empty in " cite$ * warning$ }
+ 'skip$
+ if$
+}
+
+FUNCTION {monograph}
+{ output.bibitem
+ author empty$ not
+ { format.authors }
+ { editor empty$ not
+ { format.editors }
+ { "empty author and editor in " cite$ * warning$
+ ""
+ }
+ if$
+ }
+ if$
+ output
+ new.block
+ format.series.vol.num.title "title" output.check
+ "M" set.entry.mark
+ format.mark "" output.after
+ new.block
+ format.translators output
+ new.sentence
+ format.edition output
+ new.block
+ format.address.publisher output
+ format.year "year" output.check
+ format.pages bbl.colon output.after
+ format.urldate "" output.after
+ format.url output
+ format.doi output
+ new.block
+ format.note output
+ fin.entry
+}
+
+FUNCTION {incollection}
+{ output.bibitem
+ format.authors output
+ author format.key output
+ new.block
+ format.title "title" output.check
+ "M" set.entry.mark
+ format.mark "" output.after
+ new.block
+ format.translators output
+ new.slash
+ format.editors output
+ new.block
+ format.series.vol.num.booktitle "booktitle" output.check
+ new.block
+ format.edition output
+ new.block
+ format.address.publisher output
+ format.year "year" output.check
+ format.pages bbl.colon output.after
+ format.urldate "" output.after
+ format.url output
+ format.doi output
+ new.block
+ format.note output
+ fin.entry
+}
+
+FUNCTION {periodical}
+{ output.bibitem
+ format.authors output
+ author format.key output
+ new.block
+ format.title "title" output.check
+ "J" set.entry.mark
+ format.mark "" output.after
+ new.block
+ format.periodical.year.volume.number output
+ new.block
+ format.address.publisher output
+ format.date "year" output.check
+ format.urldate "" output.after
+ format.url output
+ format.doi output
+ new.block
+ format.note output
+ fin.entry
+}
+
+FUNCTION {article}
+{ output.bibitem
+ format.authors output
+ author format.key output
+ new.block
+ format.title "title" output.check
+ "J" set.entry.mark
+ format.mark "" output.after
+ new.block
+ format.journal "journal" output.check
+ format.date "year" output.check
+ format.journal.volume output
+ format.journal.number "" output.after
+ format.journal.pages "" output.after
+ format.urldate "" output.after
+ format.url output
+ format.doi output
+ new.block
+ format.note output
+ fin.entry
+}
+
+FUNCTION {patent}
+{ output.bibitem
+ format.authors output
+ author format.key output
+ new.block
+ format.title "title" output.check
+ "P" set.entry.mark
+ format.mark "" output.after
+ new.block
+ format.date "year" output.check
+ format.urldate "" output.after
+ format.url output
+ format.doi output
+ new.block
+ format.note output
+ fin.entry
+}
+
+FUNCTION {electronic}
+{ #1 #1 check.electronic
+ #1 'entry.is.electronic :=
+ output.bibitem
+ format.authors output
+ author format.key output
+ new.block
+ format.series.vol.num.title "title" output.check
+ "EB" set.entry.mark
+ format.mark "" output.after
+ new.block
+ format.address.publisher output
+ date empty$
+ { format.date output }
+ 'skip$
+ if$
+ format.pages bbl.colon output.after
+ format.editdate "" output.after
+ format.urldate "" output.after
+ format.url output
+ format.doi output
+ new.block
+ format.note output
+ fin.entry
+}
+
+FUNCTION {misc}
+{ journal empty$ not
+ 'article
+ { booktitle empty$ not
+ 'incollection
+ { publisher empty$ not
+ 'monograph
+ { entry.is.electronic
+ 'electronic
+ { "Z" set.entry.mark
+ monograph
+ }
+ if$
+ }
+ if$
+ }
+ if$
+ }
+ if$
+ empty.misc.check
+}
+
+FUNCTION {archive}
+{ "A" set.entry.mark
+ misc
+}
+
+FUNCTION {book} { monograph }
+
+FUNCTION {booklet} { book }
+
+FUNCTION {collection}
+{ "G" set.entry.mark
+ monograph
+}
+
+FUNCTION {database}
+{ "DB" set.entry.mark
+ electronic
+}
+
+FUNCTION {dataset}
+{ "DS" set.entry.mark
+ electronic
+}
+
+FUNCTION {inbook} { book }
+
+FUNCTION {inproceedings}
+{ "C" set.entry.mark
+ incollection
+}
+
+FUNCTION {conference} { inproceedings }
+
+FUNCTION {map}
+{ "CM" set.entry.mark
+ misc
+}
+
+FUNCTION {manual} { monograph }
+
+FUNCTION {mastersthesis}
+{ "D" set.entry.mark
+ monograph
+}
+
+FUNCTION {newspaper}
+{ "N" set.entry.mark
+ article
+}
+
+FUNCTION {online}
+{ "EB" set.entry.mark
+ electronic
+}
+
+FUNCTION {phdthesis} { mastersthesis }
+
+FUNCTION {proceedings}
+{ "C" set.entry.mark
+ monograph
+}
+
+FUNCTION {software}
+{ "CP" set.entry.mark
+ electronic
+}
+
+FUNCTION {standard}
+{ "S" set.entry.mark
+ misc
+}
+
+FUNCTION {techreport}
+{ "R" set.entry.mark
+ misc
+}
+
+FUNCTION {unpublished}
+{ "Z" set.entry.mark
+ misc
+}
+
+FUNCTION {default.type} { misc }
+
+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 {sortify}
+{ purify$
+ "l" change.case$
+}
+
+FUNCTION {chop.word}
+{ 's :=
+ 'len :=
+ s #1 len substring$ =
+ { s len #1 + global.max$ substring$ }
+ 's
+ if$
+}
+
+FUNCTION {format.lab.names}
+{ 's :=
+ s #1 "{vv~}{ll}{, jj}{, ff}" format.name$ 't :=
+ t get.str.lang 'name.lang :=
+ name.lang lang.en =
+ { t #1 "{vv~}{ll}" format.name$}
+ { t #1 "{ll}{ff}" format.name$}
+ if$
+ s num.names$ #1 >
+ { bbl.space * citation.et.al * }
+ 'skip$
+ 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 {author.key.organization.label}
+{ author empty$
+ { key empty$
+ { organization empty$
+ { cite$ #1 #3 substring$ }
+ { "The " #4 organization chop.word #3 text.prefix$ }
+ if$
+ }
+ 'key
+ if$
+ }
+ { author format.lab.names }
+ if$
+}
+
+FUNCTION {editor.key.organization.label}
+{ editor empty$
+ { key empty$
+ { organization empty$
+ { cite$ #1 #3 substring$ }
+ { "The " #4 organization chop.word #3 text.prefix$ }
+ if$
+ }
+ 'key
+ if$
+ }
+ { editor format.lab.names }
+ if$
+}
+
+FUNCTION {calc.short.authors}
+{ type$ "book" =
+ type$ "inbook" =
+ or
+ 'author.editor.key.label
+ { type$ "collection" =
+ type$ "proceedings" =
+ or
+ { editor empty$ not
+ 'editor.key.organization.label
+ 'author.key.organization.label
+ if$
+ }
+ 'author.key.label
+ if$
+ }
+ if$
+ 'short.list :=
+}
+
+FUNCTION {calc.label}
+{ calc.short.authors
+ short.list
+ "("
+ *
+ format.year duplicate$ empty$
+ short.list key field.or.null = or
+ { pop$ "" }
+ 'skip$
+ if$
+ calc.short.authors
+ short.list
+ "("
+ *
+ format.year duplicate$ empty$
+ short.list key field.or.null = or
+ { pop$ "" }
+ 'skip$
+ if$
+ *
+ 'label :=
+}
+
+INTEGERS { seq.num }
+
+FUNCTION {init.seq}
+{ #0 'seq.num :=}
+
+FUNCTION {int.to.fix}
+{ "000000000" swap$ int.to.str$ *
+ #-1 #10 substring$
+}
+
+FUNCTION {presort}
+{ set.entry.lang
+ set.entry.numbered
+ show.url show.doi check.electronic
+ calc.label
+ label sortify
+ " "
+ *
+ seq.num #1 + 'seq.num :=
+ seq.num int.to.fix
+ 'sort.label :=
+ sort.label *
+ #1 entry.max$ substring$
+ 'sort.key$ :=
+}
+
+STRINGS { longest.label last.label next.extra }
+
+INTEGERS { longest.label.width last.extra.num number.label }
+
+FUNCTION {initialize.longest.label}
+{ "" 'longest.label :=
+ #0 int.to.chr$ 'last.label :=
+ "" 'next.extra :=
+ #0 'longest.label.width :=
+ #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$
+ { "{\natexlab{" swap$ * "}}" * }
+ if$
+ 'extra.label :=
+ label extra.label * 'label :=
+}
+
+FUNCTION {bib.sort.order}
+{ sort.label 'sort.key$ :=
+}
+
+FUNCTION {begin.bib}
+{ preamble$ empty$
+ 'skip$
+ { preamble$ write$ newline$ }
+ if$
+ "\begin{thebibliography}{" number.label int.to.str$ * "}" *
+ write$ newline$
+ "\providecommand{\natexlab}[1]{#1}"
+ write$ newline$
+ "\providecommand{\url}[1]{#1}"
+ write$ newline$
+ "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
+ write$ newline$
+ " \urlstyle{same}\fi"
+ write$ newline$
+ show.doi
+ { "\providecommand{\href}[2]{\url{#2}}"
+ write$ newline$
+ "\providecommand{\doi}[1]{\href{https://doi.org/#1}{#1}}"
+ write$ newline$
+ }
+ 'skip$
+ if$
+}
+
+FUNCTION {end.bib}
+{ newline$
+ "\end{thebibliography}" write$ newline$
+}
+
+READ
+
+EXECUTE {init.state.consts}
+
+EXECUTE {load.config}
+
+EXECUTE {init.seq}
+
+ITERATE {presort}
+
+SORT
+
+EXECUTE {initialize.longest.label}
+
+ITERATE {forward.pass}
+
+REVERSE {reverse.pass}
+
+ITERATE {bib.sort.order}
+
+SORT
+
+EXECUTE {begin.bib}
+
+ITERATE {call.type$}
+
+EXECUTE {end.bib}
+longest.label}
+
+ITERATE {forward.pass}
+
+REVERSE {reverse.pass}
+
+ITERATE {bib.sort.order}
+
+SORT
+
+EXECUTE {begin.bib}
+
+ITERATE {call.type$}
+
+EXECUTE {end.bib}
+rtify }
+ if$
+}
+
+FUNCTION {author.organization.sort}
+{ key empty$
+ { warn.empty.key
+ author empty$
+ { organization empty$
+ { anonymous.sort }
+ { "The " #4 organization chop.word sortify }
+ if$
+ }
+ { author sort.format.names }
+ if$
+ }
+ { key sortify }
+ if$
+}
+
+FUNCTION {editor.organization.sort}
+{ key empty$
+ { warn.empty.key
+ editor empty$
+ { organization empty$
+ { anonymous.sort }
+ { "The " #4 organization chop.word sortify }
+ if$
+ }
+ { editor sort.format.names }
+ if$
+ }
+ { key sortify }
+ if$
+}
+
+FUNCTION {presort}
+{ set.entry.lang
+ set.entry.numbered
+ show.url show.doi check.electronic
+ calc.label
+ label sortify
+ " "
+ *
+ sort.language.label
+ type$ "book" =
+ type$ "inbook" =
+ or
+ 'author.editor.sort
+ { type$ "collection" =
+ type$ "proceedings" =
+ or
+ 'editor.organization.sort
+ 'author.sort
+ if$
+ }
+ if$
+ *
+ " "
+ *
+ year field.or.null sortify
+ *
+ " "
+ *
+ cite$
+ *
+ #1 entry.max$ substring$
+ 'sort.label :=
+ sort.label *
+ #1 entry.max$ substring$
+ 'sort.key$ :=
+}
+
+STRINGS { longest.label last.label next.extra }
+
+INTEGERS { longest.label.width last.extra.num number.label }
+
+FUNCTION {initialize.longest.label}
+{ "" 'longest.label :=
+ #0 int.to.chr$ 'last.label :=
+ "" 'next.extra :=
+ #0 'longest.label.width :=
+ #0 'last.extra.num :=
+ #0 'number.label :=
+}
+
+FUNCTION {forward.pass}
+{ l :=
+}
+
+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$
+ { "{\natexlab{" swap$ * "}}" * }
+ if$
+ 'extra.label :=
+ label extra.label * 'label :=
+}
+
+FUNCTION {bib.sort.order}
+{ sort.label 'sort.key$ :=
+}
+
+FUNCTION {begin.bib}
+{ preamble$ empty$
+ 'skip$
+ { preamble$ write$ newline$ }
+ if$
+ "\begin{thebibliography}{" number.label int.to.str$ * "}" *
+ write$ newline$
+ "\providecommand{\natexlab}[1]{#1}"
+ write$ newline$
+ "\providecommand{\url}[1]{#1}"
+ write$ newline$
+ "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
+ write$ newline$
+ " \urlstyle{same}\fi"
+ write$ newline$
+ show.doi
+ { "\providecommand{\href}[2]{\url{#2}}"
+ write$ newline$
+ "\providecommand{\doi}[1]{\href{https://doi.org/#1}{#1}}"
+ write$ newline$
+ }
+ 'skip$
+ if$
+}
+
+FUNCTION {end.bib}
+{ newline$
+ "\end{thebibliography}" write$ newline$
+}
+
+READ
+
+EXECUTE {init.state.consts}
+
+EXECUTE {load.config}
+
+ITERATE {presort}
+
+SORT
+
+EXECUTE {initialize.longest.label}
+
+ITERATE {forward.pass}
+
+REVERSE {reverse.pass}
+
+ITERATE {bib.sort.order}
+
+SORT
+
+EXECUTE {begin.bib}
+
+ITERATE {call.type$}
+
+EXECUTE {end.bib}
+AD
+
+EXECUTE {init.state.consts}
+
+EXECUTE {load.config}
+
+ITERATE {presort}
+
+SORT
+
+EXECUTE {initialize.longest.label}
+
+ITERATE {forward.pass}
+
+REVERSE {reverse.pass}
+
+ITERATE {bib.sort.order}
+
+SORT
+
+EXECUTE {begin.bib}
+
+ITERATE {call.type$}
+
+EXECUTE {end.bib}
Property changes on: trunk/Master/texmf-dist/doc/bibtex/gbt7714/y.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Master/texmf-dist/source/bibtex/gbt7714/gbt7714.dtx
===================================================================
--- trunk/Master/texmf-dist/source/bibtex/gbt7714/gbt7714.dtx 2019-03-21 20:24:13 UTC (rev 50503)
+++ trunk/Master/texmf-dist/source/bibtex/gbt7714/gbt7714.dtx 2019-03-21 20:45:44 UTC (rev 50504)
@@ -1,6 +1,8 @@
% \iffalse meta-comment
+% GB/T 7714-2015 BibTeX Style
+% https://github.com/CTeX-org/gbt7714-bibtex-style
%
-% Copyright (C) 2016-2018 by Zeping Lee <zepinglee AT gmail.com>
+% Copyright (C) 2016-2019 by Zeping Lee <zepinglee AT gmail.com>
%
% This file may be distributed and/or modified under the
% conditions of the LaTeX Project Public License, either version 1.3c
@@ -14,7 +16,7 @@
\iffalse
\fi
\begingroup
- \def\nameoflatex{LaTeX2e}
+ \def\nameoflatex{LaTeX2e}
\expandafter\endgroup\ifx\nameoflatex\fmtname\else
\csname fi\endcsname
%</internal>
@@ -21,10 +23,13 @@
%<*install>
\input docstrip.tex
\preamble
-Version: 2018/08/05 v1.0.9
-
+-------------------------------------------------------------------
+GB/T 7714-2015 BibTeX Style
+https://github.com/CTeX-org/gbt7714-bibtex-style
+Version: 2019/03/21 v1.1.1
+-------------------------------------------------------------------
Copyright (C) 2016-\the\year by Zeping Lee <zepinglee AT gmail.com>
-
+-------------------------------------------------------------------
This file may be distributed and/or modified under the
conditions of the LaTeX Project Public License, either version 1.3c
of this license or (at your option) any later version.
@@ -32,7 +37,7 @@
https://www.latex-project.org/lppl.txt
and version 1.3c or later is part of all distributions of LaTeX
version 2005/12/01 or later.
-
+-------------------------------------------------------------------
\endpreamble
\keepsilent
\askforoverwritefalse
@@ -41,8 +46,27 @@
\file{\jobname.sty}{\from{\jobname.dtx}{package}}
\file{\jobname-plain.bst}{\from{\jobname.dtx}{2015,authoryear}}
\file{\jobname-unsrt.bst}{\from{\jobname.dtx}{2015,numerical}}
- \file{\jobname-2005-plain.bst}{\from{\jobname.dtx}{2005,authoryear}}
- \file{\jobname-2005-unsrt.bst}{\from{\jobname.dtx}{2005,numerical}}
+ \file{versions/2005/\jobname-2005-plain.bst}{
+ \from{\jobname.dtx}{2005,authoryear}
+ }
+ \file{versions/2005/\jobname-2005-unsrt.bst}{
+ \from{\jobname.dtx}{2005,numerical}
+ }
+ \file{versions/thu/thuthesis-author-year.bst}{
+ \from{\jobname.dtx}{thu,2005,authoryear}}
+ \file{versions/thu/thuthesis-numeric.bst}{
+ \from{\jobname.dtx}{thu,2005,numerical}}
+ \file{versions/thu/thuthesis-bachelor.bst}{
+ \from{\jobname.dtx}{2015,numerical}}
+ \file{versions/ustc/ustcthesis-authoryear.bst}{
+ \from{\jobname.dtx}{ustc,2015,authoryear}
+ }
+ \file{versions/ustc/ustcthesis-numerical.bst}{
+ \from{\jobname.dtx}{ustc,2015,numerical}
+ }
+ \file{versions/ustc/ustcthesis-bachelor.bst}{
+ \from{\jobname.dtx}{ustc,2015,numerical,nouppercase,nomark,italicjournal}
+ }
}
\endbatchfile
%</install>
@@ -55,7 +79,7 @@
%<package>\NeedsTeXFormat{LaTeX2e}[1999/12/01]
%<package>\ProvidesPackage{gbt7714}
%<*package>
- [2018/08/05 v1.0.9 GB/T 7714-2015 BibTeX Style]
+ [2019/03/21 v1.1.1 GB/T 7714-2015 BibTeX Style]
%</package>
%
%<*driver>
@@ -154,7 +178,7 @@
% It is compatible with \pkg{natbib} and supports language detection (Chinese
% and English) for each biblilography entry.
% \end{abstract}
-
+%
% \section{简介}
%
% GB/T 7714-2015 《信息与文献\quad 参考文献著录规则》\cite{gbt77142015}
@@ -166,7 +190,7 @@
% \item 自动识别语言并进行相应处理
% \item 提供了简单的接口供用户修改样式
% \end{itemize}
-% 本宏包的主页:\url{https://github.com/zepinglee/gbt7714-bibtex-style}。
+% 本宏包的主页:\url{https://github.com/CTeX-org/gbt7714-bibtex-style}。
%
%
% \section{使用方法}
@@ -217,7 +241,7 @@
% 表~\ref{tab:entry-types} 列举了 \file{bib} 数据库中对应的文献类型。
% 这些尽可能兼容 \BibTeX{} 的标准类型,但是新增了若干文献类型(带 * 号)。
%
-% \begin{table}[htbp]
+% \begin{table}[htb]
% \centering\small
% \caption{全部文献类型}
% \label{tab:entry-types}
@@ -322,7 +346,7 @@
% 若变量被设为 |#1| 则表示该项被启用,设为 |#0| 则不启用。
% 默认的值是严格遵循国标的配置。
%
-% \begin{table}
+% \begin{table}[htb]
% \centering\small
% \caption{参考文献表样式的配置参数}
% \label{tab:config}
@@ -548,9 +572,7 @@
% Numerical 模式的 \cs{citet} 的页码:
% \begin{macrocode}
\newcommand\gbt at patchfailure[1]{%
- \ClassError{ustcthesis}{Failed to patch command \protect#1.\MessageBreak
- Please contact the template author.%
- }{}%
+ \PackageError{gbt7714}{Failed to patch command \protect#1}{}%
}
\patchcmd{\NAT at citexnum}{%
\@ifnum{\NAT at ctype=\z@}{%
@@ -655,11 +677,21 @@
sentence.case.title
link.title
show.mark
+ slash.for.extraction
+ in.booktitle
italic.jounal
+ bold.journal.volume
show.missing.address.publisher
show.url
show.doi
show.note
+%<*authoryear>
+ lang.zh.order
+ lang.ja.order
+ lang.en.order
+ lang.ru.order
+ lang.other.order
+%</authoryear>
}
% \end{macrocode}
@@ -674,6 +706,9 @@
% 英文姓名转为全大写:
% \begin{macrocode}
#1 'uppercase.name :=
+%<*nouppercase|thu>
+ #0 'uppercase.name :=
+%</nouppercase|thu>
% \end{macrocode}
%
% 最多显示的作者数量:
@@ -683,52 +718,103 @@
%
% 采用著者-出版年制时,作者姓名与年份之间使用句点连接:
% \begin{macrocode}
+%<*authoryear>
#0 'period.between.author.year :=
+%<*period|2005|ustc>
+ #1 'period.between.author.year :=
+%</period|2005|ustc>
+%</authoryear>
% \end{macrocode}
%
% 英文标题转为 sentence case (句首字母大写,其余小写):
% \begin{macrocode}
#1 'sentence.case.title :=
+%<*nosentencecase>
+ #0 'sentence.case.title :=
+%</nosentencecase>
% \end{macrocode}
%
% 在标题添加超链接:
% \begin{macrocode}
#0 'link.title :=
+%<*linktitle>
+ #1 'link.title :=
+%</linktitle>
% \end{macrocode}
%
% 著录文献类型标识(比如“[M/OL]“):
% \begin{macrocode}
#1 'show.mark :=
+%<*nomark>
+ #0 'show.mark :=
+%</nomark>
% \end{macrocode}
%
+% 使用“//”表示析出文献
+% \begin{macrocode}
+ #1 'slash.for.extraction :=
+%<*noslash>
+ #0 'slash.for.extraction :=
+%</noslash>
+% \end{macrocode}
+%
+% 使用“In:”表示析出文献
+% \begin{macrocode}
+ #0 'in.booktitle :=
+% \end{macrocode}
+%
% 期刊名使用斜体:
% \begin{macrocode}
#0 'italic.jounal :=
+%<*italicjournal>
+ #1 'italic.jounal :=
+%</italicjournal>
% \end{macrocode}
%
+% 期刊的卷使用粗体:
+% \begin{macrocode}
+ #0 'bold.journal.volume :=
+% \end{macrocode}
+%
% 无出版地或出版者时,著录“出版地不详”,“出版者不详”,“S.l.” 或 “s.n.”:
% \begin{macrocode}
#1 'show.missing.address.publisher :=
+%<*noslsn|ustc>
+ #0 'show.missing.address.publisher :=
+%</noslsn|ustc>
% \end{macrocode}
%
% 是否著录 URL:
% \begin{macrocode}
#1 'show.url :=
+%<*nourl>
+ #0 'show.url :=
+%</nourl>
% \end{macrocode}
%
% 是否著录 DOI:
% \begin{macrocode}
-%<*2015>
#1 'show.doi :=
-%</2015>
-%<*2005>
+%<*nodoi|2005>
#0 'show.doi :=
-%</2005>
+%</nodoi|2005>
% \end{macrocode}
%
% 在每一条文献最后输出注释(note)的内容:
% \begin{macrocode}
#0 'show.note :=
+% \end{macrocode}
+%
+% \changes{v1.1.1}{2019/03/21}{允许自定义文种的顺序}
+% 参考文献表按照“著者-出版年”组织时,各个文种的顺序:
+% \begin{macrocode}
+%<*authoryear>
+ #1 'lang.zh.order :=
+ #2 'lang.ja.order :=
+ #3 'lang.en.order :=
+ #4 'lang.ru.order :=
+ #5 'lang.other.order :=
+%</authoryear>
}
% \end{macrocode}
@@ -771,7 +857,7 @@
volume
year
}
- { entry.lang entry.is.electronic }
+ { entry.lang entry.is.electronic entry.numbered }
% \end{macrocode}
%
% These string entry variables are used to form the citation label.
@@ -961,22 +1047,28 @@
% \end{macrocode}
%
% 下面是一些常量的定义
+% \changes{v1.1}{2019/01/02}{允许自定义“et al”}
% \begin{macrocode}
FUNCTION {bbl.anonymous}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "佚名" }
{ "Anon" }
if$
}
-FUNCTION {bbl.space} { "\ " }
+FUNCTION {bbl.space}
+{ entry.lang lang.zh =
+ { "\ " }
+ { " " }
+ if$
+}
FUNCTION {bbl.et.al}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "等" }
- { lang.ja entry.lang =
+ { entry.lang lang.ja =
{ "他" }
- { lang.ru entry.lang =
+ { entry.lang lang.ru =
{ "идр" }
{ "et~al." }
if$
@@ -986,6 +1078,9 @@
if$
}
+FUNCTION {citation.et.al}
+{ bbl.et.al }
+
FUNCTION {bbl.colon} { ": " }
%<*2015>
@@ -995,10 +1090,10 @@
FUNCTION {bbl.wide.space} { "\ " }
%</2005>
-FUNCTION {bbl.slash} { "//\allowbreak{}" }
+FUNCTION {bbl.slash} { "//\allowbreak " }
FUNCTION {bbl.sine.loco}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版地不详]" }
{ "[S.l.]" }
if$
@@ -1005,7 +1100,7 @@
}
FUNCTION {bbl.sine.nomine}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版者不详]" }
{ "[s.n.]" }
if$
@@ -1012,7 +1107,7 @@
}
FUNCTION {bbl.sine.loco.sine.nomine}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "[出版地不详: 出版者不详]" }
{ "[S.l.: s.n.]" }
if$
@@ -1061,7 +1156,9 @@
{ output.state before.all =
'write$
{ output.state after.slash =
- { bbl.slash * write$ }
+ { bbl.slash * write$
+ newline$
+ }
{ add.period$ " " * write$ }
if$
}
@@ -1122,9 +1219,22 @@
% \end{macrocode}
%
% This function finishes all entries.
+%
+% Tsinghua requires no period at the end of book-like entries.
% \begin{macrocode}
FUNCTION {fin.entry}
+%<*!thu>
{ add.period$
+%</!thu>
+%<*thu>
+{ type$ "book" =
+ type$ "inbook" = or
+ type$ "incollection" = or
+ type$ "collection" = or
+ 'skip$
+ 'add.period$
+ if$
+%</thu>
write$
newline$
}
@@ -1158,7 +1268,11 @@
FUNCTION {new.slash}
{ output.state before.all =
'skip$
- { after.slash 'output.state := }
+ { slash.for.extraction
+ { after.slash 'output.state := }
+ { after.block 'output.state := }
+ if$
+ }
if$
}
@@ -1388,6 +1502,15 @@
'entry.lang :=
}
+FUNCTION {set.entry.numbered}
+{ type$ "patent" =
+ type$ "standard" = or
+ type$ "techreport" = or
+ { #1 'entry.numbered := }
+ { #0 'entry.numbered := }
+ if$
+}
+
% \end{macrocode}
%
% \subsubsection{Format names}
@@ -1514,14 +1637,16 @@
}
FUNCTION {format.authors}
-{ author empty$
+{ author empty$ not
+ { author format.names }
+ { "empty author in " cite$ * warning$
%<*authoryear>
- { bbl.anonymous }
+ bbl.anonymous
%</authoryear>
%<*numerical>
- { "" }
+ ""
%</numerical>
- { author format.names }
+ }
if$
}
@@ -1536,7 +1661,7 @@
{ translator empty$
{ "" }
{ translator format.names
- lang.zh entry.lang =
+ entry.lang lang.zh =
{ translator num.names$ #3 >
{ "译" * }
{ ", 译" * }
@@ -1631,7 +1756,20 @@
")" make.full.names duplicate$ short.list =
{ pop$ }
{ * }
- if$
+ if$
+ 's :=
+ s text.length$ 'charptr :=
+ { charptr #0 > }
+ { s charptr #1 substring$ "]" =
+ { #0 'charptr := }
+ { charptr #1 - 'charptr := }
+ if$
+ }
+ while$
+ charptr #0 >
+ { "{" s * "}" * }
+ { s }
+ if$
"]{" * write$
cite$ write$
"}" write$
@@ -1661,15 +1799,15 @@
}
FUNCTION {add.link}
- { url empty$ not
- { "\href{" url * "}{" * swap$ * "}" * }
- { doi empty$ not
- { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
- 'skip$
- if$
- }
- if$
- }
+{ url empty$ not
+ { "\href{" url * "}{" * swap$ * "}" * }
+ { doi empty$ not
+ { "\href{http://dx.doi.org/" doi * "}{" * swap$ * "}" * }
+ 'skip$
+ if$
+ }
+ if$
+}
FUNCTION {format.title}
{ title empty$
@@ -1679,6 +1817,10 @@
'change.sentence.case
'skip$
if$
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
+ 'skip$
+ if$
link.title
'add.link
'skip$
@@ -1784,24 +1926,32 @@
}
FUNCTION {format.volume}
-{ volume empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " volume * " 卷" * }
- { "volume" volume tie.or.space.connect }
+{ volume empty$ not
+ { volume is.number
+ { entry.lang lang.zh =
+ { "第 " volume * " 卷" * }
+ { "volume" volume tie.or.space.connect }
+ if$
+ }
+ { volume }
if$
}
+ { "" }
if$
}
FUNCTION {format.number}
-{ number empty$
- { "" }
- { lang.zh entry.lang =
- { "第 " number * " 册" * }
- { "number" number tie.or.space.connect }
+{ number empty$ not
+ { number is.number
+ { entry.lang lang.zh =
+ { "第 " number * " 册" * }
+ { "number" number tie.or.space.connect }
+ if$
+ }
+ { number }
if$
}
+ { "" }
if$
}
@@ -1812,6 +1962,27 @@
if$
}
+FUNCTION {format.title.vol.num}
+{ title
+ sentence.case.title
+ 'change.sentence.case
+ 'skip$
+ if$
+ entry.numbered
+ { number empty$ not
+ { bbl.colon * number * }
+ 'skip$
+ if$
+ }
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
FUNCTION {format.series.vol.num.title}
{ format.volume.number 's :=
series empty$ not
@@ -1820,28 +1991,26 @@
'change.sentence.case
'skip$
if$
- bbl.colon *
- s empty$ not
- { s * bbl.wide.space * }
- 'skip$
+ entry.numbered
+ { bbl.wide.space * }
+ { bbl.colon *
+ s empty$ not
+ { s * bbl.wide.space * }
+ 'skip$
+ if$
+ }
if$
- title
+ title *
sentence.case.title
'change.sentence.case
'skip$
if$
- *
- }
- { title
- sentence.case.title
- 'change.sentence.case
+ entry.numbered number empty$ not and
+ { bbl.colon * number * }
'skip$
if$
- s empty$ not
- { bbl.colon * s * }
- 'skip$
- if$
}
+ { format.title.vol.num }
if$
link.title
'add.link
@@ -1849,28 +2018,48 @@
if$
}
+FUNCTION {format.booktitle.vol.num}
+{ booktitle
+ entry.numbered
+ 'skip$
+ { format.volume.number 's :=
+ s empty$ not
+ { bbl.colon * s * }
+ 'skip$
+ if$
+ }
+ if$
+}
+
+% \end{macrocode}
+%
+% \changes{v1.1}{2019/01/02}{修正 series 的 bug}
+% \begin{macrocode}
FUNCTION {format.series.vol.num.booktitle}
{ format.volume.number 's :=
series empty$ not
{ series bbl.colon *
- s empty$ not
+ entry.numbered not s empty$ not and
{ s * bbl.wide.space * }
'skip$
if$
booktitle *
}
- { booktitle
- s empty$ not
- { bbl.colon * s * }
+ { format.booktitle.vol.num }
+ if$
+ in.booktitle
+ { duplicate$ empty$ not entry.lang lang.en = and
+ { "In: " swap$ * }
'skip$
if$
}
+ 'skip$
if$
}
FUNCTION {format.journal}
{ journal
- italic.jounal
+ italic.jounal entry.lang lang.en = and
'italicize
'skip$
if$
@@ -1937,7 +2126,7 @@
{ edition empty$
{ "" }
{ edition is.number
- { lang.zh entry.lang =
+ { entry.lang lang.zh =
{ edition " 版" * }
{ edition num.to.ordinal " ed." * }
if$
@@ -2086,7 +2275,10 @@
{ date empty$ not
{ date extract.before.dash }
{ "empty year in " cite$ * warning$
- ""
+ urldate empty$ not
+ { "[" urldate extract.before.dash * "]" * }
+ { "" }
+ if$
}
if$
}
@@ -2213,6 +2405,17 @@
%
% 报纸在卷号缺失时,期号与前面的日期直接相连,所以必须拆开输出。
% \begin{macrocode}
+FUNCTION {format.journal.volume}
+{ volume empty$ not
+ { bold.journal.volume
+ { "\textbf{" volume * "}" * }
+ { volume }
+ if$
+ }
+ { "" }
+ if$
+}
+
FUNCTION {format.journal.number}
{ number empty$ not
{ "\penalty0 (" number * ")" * }
@@ -2448,12 +2651,14 @@
{ format.authors }
{ editor empty$ not
{ format.editors }
+ { "empty author and editor in " cite$ * warning$
%<*authoryear>
- { bbl.anonymous }
+ bbl.anonymous
%</authoryear>
%<*numerical>
- { "" }
+ ""
%</numerical>
+ }
if$
}
if$
@@ -2502,7 +2707,7 @@
% \begin{macrocode}
FUNCTION {incollection}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
%<*authoryear>
period.between.author.year
@@ -2544,7 +2749,7 @@
% \begin{macrocode}
FUNCTION {periodical}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
%<*authoryear>
period.between.author.year
@@ -2588,7 +2793,7 @@
% \begin{macrocode}
FUNCTION {article}
{ output.bibitem
- format.authors "author" output.check
+ format.authors output
author format.key output
%<*authoryear>
period.between.author.year
@@ -2606,7 +2811,7 @@
%<*numerical>
format.date "year" output.check
%</numerical>
- volume output
+ format.journal.volume output
format.journal.number "" output.after
format.journal.pages "" output.after
format.urldate "" output.after
@@ -2635,12 +2840,7 @@
format.year "year" output.check
%</authoryear>
new.block
- format.title
- number empty$ not
- { bbl.colon * number * }
- 'skip$
- if$
- "title" output.check
+ format.title "title" output.check
"P" set.entry.mark
format.mark "" output.after
new.block
@@ -2829,7 +3029,16 @@
% Optional: type, address, month, note
% \begin{macrocode}
FUNCTION {mastersthesis}
+%<*!thu>
{ "D" set.entry.mark
+%</!thu>
+%<*thu>
+{ lang.zh entry.lang =
+ { "硕士学位论文" }
+ { "D" }
+ if$
+ set.entry.mark
+%</thu>
monograph
}
@@ -2851,7 +3060,19 @@
%
% Optional: type, address, month, note
% \begin{macrocode}
+%<*!thu>
FUNCTION {phdthesis} { mastersthesis }
+%</!thu>
+%<*thu>
+FUNCTION {phdthesis}
+{ lang.zh entry.lang =
+ { "博士学位论文" }
+ { "D" }
+ if$
+ set.entry.mark
+ monograph
+}
+%</thu>
% \end{macrocode}
%
@@ -3131,7 +3352,7 @@
{ t #1 "{ll}{ff}" format.name$}
if$
s num.names$ #1 >
- { bbl.space * bbl.et.al * }
+ { bbl.space * citation.et.al * }
'skip$
if$
}
@@ -3256,14 +3477,14 @@
%<*authoryear>
FUNCTION {sort.language.label}
{ entry.lang lang.zh =
- { "a zh " }
+ { lang.zh.order }
{ entry.lang lang.ja =
- { "b ja " }
+ { lang.ja.order }
{ entry.lang lang.en =
- { "c en " }
+ { lang.en.order }
{ entry.lang lang.ru =
- { "d ru " }
- { "e other " }
+ { lang.ru.order }
+ { lang.other.order }
if$
}
if$
@@ -3271,6 +3492,7 @@
if$
}
if$
+ int.to.chr$
}
FUNCTION {sort.format.names}
@@ -3328,18 +3550,22 @@
% purposes, we still remove a leading "The " from the organization field.
% \begin{macrocode}
FUNCTION {anonymous.sort}
-{ lang.zh entry.lang =
+{ entry.lang lang.zh =
{ "yi4 ming2" }
{ "anon" }
if$
}
+FUNCTION {warn.empty.key}
+{ entry.lang lang.zh =
+ { "empty key in " cite$ * warning$ }
+ 'skip$
+ if$
+}
+
FUNCTION {author.sort}
{ key empty$
- { entry.lang lang.zh =
- { "empty key in " cite$ * warning$ }
- 'skip$
- if$
+ { warn.empty.key
author empty$
{ anonymous.sort }
{ author sort.format.names }
@@ -3351,7 +3577,8 @@
FUNCTION {author.editor.sort}
{ key empty$
- { author empty$
+ { warn.empty.key
+ author empty$
{ editor empty$
{ anonymous.sort }
{ editor sort.format.names }
@@ -3366,7 +3593,8 @@
FUNCTION {author.organization.sort}
{ key empty$
- { author empty$
+ { warn.empty.key
+ author empty$
{ organization empty$
{ anonymous.sort }
{ "The " #4 organization chop.word sortify }
@@ -3381,7 +3609,8 @@
FUNCTION {editor.organization.sort}
{ key empty$
- { editor empty$
+ { warn.empty.key
+ editor empty$
{ organization empty$
{ anonymous.sort }
{ "The " #4 organization chop.word sortify }
@@ -3420,6 +3649,7 @@
% \begin{macrocode}
FUNCTION {presort}
{ set.entry.lang
+ set.entry.numbered
show.url show.doi check.electronic
calc.label
label sortify
@@ -3577,16 +3807,12 @@
write$ newline$
"\providecommand{\natexlab}[1]{#1}"
write$ newline$
- show.url show.doi or
- { "\providecommand{\url}[1]{#1}"
- write$ newline$
- "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
- write$ newline$
- " \urlstyle{same}\fi"
- write$ newline$
- }
- 'skip$
- if$
+ "\providecommand{\url}[1]{#1}"
+ write$ newline$
+ "\expandafter\ifx\csname urlstyle\endcsname\relax\relax\else"
+ write$ newline$
+ " \urlstyle{same}\fi"
+ write$ newline$
show.doi
{ "\providecommand{\href}[2]{\url{#2}}"
write$ newline$
@@ -3656,4 +3882,3 @@
%
% \Finale
\endinput
-所以只能在 bib 数据库中的 key 域手动录入作者姓名的拼音,如:
Modified: trunk/Master/texmf-dist/tex/latex/gbt7714/gbt7714.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/gbt7714/gbt7714.sty 2019-03-21 20:24:13 UTC (rev 50503)
+++ trunk/Master/texmf-dist/tex/latex/gbt7714/gbt7714.sty 2019-03-21 20:45:44 UTC (rev 50504)
@@ -5,10 +5,13 @@
%% The original source files were:
%%
%% gbt7714.dtx (with options: `package')
-%% Version: 2018/08/05 v1.0.9
-%%
-%% Copyright (C) 2016-2018 by Zeping Lee <zepinglee AT gmail.com>
-%%
+%% -------------------------------------------------------------------
+%% GB/T 7714-2015 BibTeX Style
+%% https://github.com/CTeX-org/gbt7714-bibtex-style
+%% Version: 2019/03/21 v1.1.1
+%% -------------------------------------------------------------------
+%% Copyright (C) 2016-2019 by Zeping Lee <zepinglee AT gmail.com>
+%% -------------------------------------------------------------------
%% This file may be distributed and/or modified under the
%% conditions of the LaTeX Project Public License, either version 1.3c
%% of this license or (at your option) any later version.
@@ -16,11 +19,10 @@
%% https://www.latex-project.org/lppl.txt
%% and version 1.3c or later is part of all distributions of LaTeX
%% version 2005/12/01 or later.
-%%
+%% -------------------------------------------------------------------
\NeedsTeXFormat{LaTeX2e}[1999/12/01]
\ProvidesPackage{gbt7714}
- [2018/08/05 v1.0.9 GB/T 7714-2015 BibTeX Style]
-
+ [2019/03/21 v1.1.1 GB/T 7714-2015 BibTeX Style]
\newif\if at gbt@mmxv
\newif\if at gbt@numerical
\newif\if at gbt@super
@@ -74,9 +76,7 @@
\gbtbibstyle{authoryear}%
\fi
\newcommand\gbt at patchfailure[1]{%
- \ClassError{ustcthesis}{Failed to patch command \protect#1.\MessageBreak
- Please contact the template author.%
- }{}%
+ \PackageError{gbt7714}{Failed to patch command \protect#1}{}%
}
\patchcmd{\NAT at citexnum}{%
\@ifnum{\NAT at ctype=\z@}{%
More information about the tex-live-commits
mailing list