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