chef-lctp/report/plaindin.bst

2039 lines
51 KiB
Plaintext
Raw Normal View History

2014-06-10 12:56:14 +00:00
%% PLAINDIN.BST Ausgabe [8.2] 2006-01-02
%% mit doi-, urn-, url-Funktionen fuer Internetressourcen
%% ersetzt PLAINDIN.BST Ausgabe [8.1b3] 22.2.2005
%%
%%
%% K.F.Lorenzen (Copyright 1994-2006) email: lorenzen.marxen@t-online.de
2014-01-22 09:39:06 +00:00
%% ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2014-06-10 12:56:14 +00:00
%% PLAINDIN.BST wurde entwickelt aus Oren Patashnik's BibTeX standard
%% bibliography style `plain'. Dadurch ist es moeglich, eine vorgegebene
%% Literaturdatenbank ohne Aenderungen beliebig nach Us- oder deutscher
%% Zitierkonvention zu verarbeiten.
%% Mit PLAINDIN.BST werden Literaturverzeichnisse gemaess der deutschen
2014-01-22 09:39:06 +00:00
%% Zitiernorm DIN 1505 Teil 2 formatiert.
2014-06-10 12:56:14 +00:00
%% Analog zu den 4 US standard styles wird ein vollstaendiger Satz von
2014-01-22 09:39:06 +00:00
%% 4 DIN-gerechten bst-style Dateien veroeffentlicht (alphadin.bst,
%% plaindin.bst, unsrtdin.bst, abbrvdin.bst). Die gueltige Version
%% ist am schnellsten aus dem WWW ueber folgende URL zu beziehen
2014-06-10 12:56:14 +00:00
%% http://www.haw-hamburg.de/pers/Lorenzen/bibtex/
%% Stand: 2006-01-02
2014-01-22 09:39:06 +00:00
%% ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
%% WAS IST PLAINDIN.BST ?
%% Dieser style produziert Literaturzitate in Literaturverzeichnissen
%% gemaess der deutschen Norm DIN 1505, Teil 2 vom Jan. 1984.
%% Die Literaturzitate werden alphabetisch nach Verfassern sortiert
2014-06-10 12:56:14 +00:00
%% und fortlaufend in eckigen Klammern gezaehlt. Die vorliegenden DIN-styles
%% gehen ueber die bibliographischen Beschraenkungen der Originalstyles hinaus.
%
%% Es werden nun auch Elektronische Online / Offline Ressourcen wie Internet-
%% quellen, CD-ROM usw. verarbeitet. Dazu kommen besondere Publikationsformen
%% wie Patente, Normen, Karten, Fernsehaufzeichnungen, Gesetzesstellen, Spiele.
%
%% Zur Gewaehrleistung der Allgemeingueltigkeit von bib-files gelten in den
%% DIN-styles die in der Tex-Literatur veroeffentlichten originalen
%% Definitionen und Regeln fuer die Publikationstypen (entry-types) und die
%% bibliographischen Felder (fields).
%% Treten kleinere "Schoenheitsfehler" im fertig gesetzten output auf,
%% lassen sich diese so gut wie immer durch eine veraenderte
%% Erfassung im bib-inputfile beseitigen. Oren Patashnik empfiehlt, die
%% Definition der Felder weit auszulegen. Last but not least koennen
2014-01-22 09:39:06 +00:00
%% Sie im output-file < *.bbl > noch letzte Hand zur Korrektur ansetzen.
%
2014-06-10 12:56:14 +00:00
%% WARN- UND FEHLERMELDUNGEN
%% Ursache von Warnmeldungen sind meistens fehlende Felder oder
%% Erfassungs-"Fehler". Letztere haengen teilweise mit den gegenueber US-
%% Gepflogenheiten andersartigen bibliographischen Regeln nach DIN 1505
%% zusammen. Sie sind also in Wahrheit keine "Fehler" und duerfen fast immer
%% ignoriert werden. Dennoch pruefen Sie diese Warnungen, um heraus zu finden,
%% ob Publikationstyp (=entry-type) und "fields" eventuell unzulaessig
%% kombiniert worden sind.
%% Echte Fehler ("errors") treten nur noch in Verbindung mit falscher
%% Erfassung auf (nach meinen Tests!). Pruefen Sie die Syntax, den entry-type
%% und die fields.
%% Zu guter letzt: Qualitaetsmasstab ist einzig der DIN-konforme output!
2014-01-22 09:39:06 +00:00
%%
%% DANKSAGUNG
2014-06-10 12:56:14 +00:00
%% Hartmut Lueddecke, HAW Hamburg, hat viele Verbesserungsvorschlaege
%% in die frueheren Versionen eingebracht. Ihm danke ich herzlich.
%% Patrick W. Daly, dem Entwickler des Natbib-Stils, verdanke ich viele
%% Anregungen und den steten Ansporn, die DIN-Stile zu verbessern.
%% Viele an dieser Stelle ungenannt bleibende Anwender haben mich in
%% den vergangenen Jahren auf Fehler oder Verbesserungsmoeglichkeiten
%% aufmerksam gemacht und so diesen Stil mitentwickelt. Ihnen gilt mein
%% besonderer Dank. Ihr Feedback ist immer willkommen und eine Ermunterung.
%%
%% Klaus F. Lorenzen
%%
%%
%%
%% HINWEIS: Neben den vier bibliographischen DIN 1505 Standard-Stilen
%% nach den Original-styles von Oren Patashnik
%% gibt es zusaetzlich vier DIN 1505 Modifikationen der style
%% Emulationen des NATBIB-Pakets von Patrick W.Daly.
%% In den NATBIB-Modifikationen werden jetzt alle von P.W. Daly
%% implementierten Zitierweisen des Autor-Jahr-Stils unterstuetzt.
%% Damit erhaelt der Anwender eine weit ueber die urspruenglichen
%% Standardstyles hinausreichende Flexibilitaet beim Zitieren.
%% Naeheres unter URL http://www.haw-hamburg.de/pers/Lorenzen/bibtex/
2014-01-22 09:39:06 +00:00
%%
%%
%% ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2014-06-10 12:56:14 +00:00
% version 0.99c for BibTeX versions 0.99c or later, LaTeX2e
% Copyright (C) 1985, all rights reserved.
% Copying of this file is authorized only if either
% (1) you make absolutely no changes to your copy, including name, or
% (2) if you do make changes, you name it something other than
% plaindin.bst, unsrtdin.bst, alphadin.bst, and abbrvdin.bst.
% This restriction helps ensure that all standard styles are identical.
% The file btxbst.doc has the original documentation for style 'alpha'.
2014-01-22 09:39:06 +00:00
%%
2014-06-10 12:56:14 +00:00
%% ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
%%
%% NEUE FELDER
%% Zur Erfassung der neuen digitalen Online-Medien z.B. Internetquellen, E-journals, E-books,
%% E-mail u.a. gibt es die zusaetzlichen Felder: doi, url, urn, lastchecked
%% Internetquellen werden vorzugsweise mit dem BOOKLET-Typ erfasst.
%% Normen, Patente, Schutzrechte sind mit dem MISC-Typ zu erfassen.
%
%
2014-01-22 09:39:06 +00:00
ENTRY
{ address %% Verlagsort
author %% persoenlicher Urheber eines Werkes
2014-06-10 12:56:14 +00:00
booktitle %% a) Gesamttitel eines mehrbaendigen Werkes
2014-01-22 09:39:06 +00:00
% %% b) Titel des Sammelwerks, das einzelne selbstaendige
% %% Beitraege mit eigenem Titel enthaelt (->incollection)
chapter %% Kapitel in einem Buch (Monographie)
2014-06-10 12:56:14 +00:00
doi %%% Digital Object Identifier
edition %% Auflagevermerk; bei selbst. elektron. Dok. == Version
2014-01-22 09:39:06 +00:00
editor %% Persoenl.Herausgeber oder Koerperschaftlicher Herausgeber
2014-06-10 12:56:14 +00:00
howpublished %% beliebiger Verlegervermerk: von wem, wo
2014-01-22 09:39:06 +00:00
institution %% Institution, die e.Verlagsfreie Veroeffentlichung betreibt
isbn %% Standardnr fuer Buecher
issn %% - " - : Zeitschriften u. Serien
journal %% Titel einer Zeitschrift
key %% Zusaetzlich vergebener Sortierschluessel, mitunter notwend.
2014-06-10 12:56:14 +00:00
lastchecked %% Online Abruf einer Internetquelle ( GRAY ); 22.1.2004
2014-01-22 09:39:06 +00:00
month %% naehere Bestimmung des Erscheinungsjahres (-> macro 's)
note %% freies Eingabefeld fuer zusaetzliche Informationen
number %% Mehrfachbedeutung in Abhaengigkeit vom Eingabetyp
organization %% a) Name der Organisation/des Organisators e. Tagung,Konferenz
% %% b) Name einer Firma/Gesellschaft, die ein ->manual herausgab
pages %% Umfangsangaben, meist Seitenzahlen
publisher %% Verlag
school %% Hochschule/Universitaet, die eine Dipl.-Arb./Dissertation veroeff.
series %% Titel e.Reihe, in der ein best. Buchtitel erschienen ist
title %% Titel einer (namentlich gekennzeichneten) Veroeffentlichung
type %% Zusatzfeld z.Kennzeichnung e.besonderen Publikationstyps
2014-06-10 12:56:14 +00:00
url %%% Internet-Adresse URL ( Uniform Resource Locator )
urn %% Persistent Identifier URN ( Uniform Resource Name )
2014-01-22 09:39:06 +00:00
volume %% a) Zaehlung bei einem mehrbaendigen Werk (-> book)
% %% b) Jahrgang einer Zeitschrift (-> article
year %% Erscheinungsjahr
}
{}
{ label extra.label sort.label }
2014-06-10 12:56:14 +00:00
%% Variablen-Vereinbarungen
2014-01-22 09:39:06 +00:00
2014-06-10 12:56:14 +00:00
INTEGERS { output.state before.all mid.sentence after.sentence after.block }
2014-01-22 09:39:06 +00:00
INTEGERS { colon.after period.dash }
2014-06-10 12:56:14 +00:00
INTEGERS { after.firstblock }
%% fuer die Namensbehandlung
INTEGERS { zahl lang }
INTEGERS { nameptr namesleft numnames }
INTEGERS { ptr collation collrest }
%% fuer die Sortierung bei der label-Produktion
INTEGERS { len }
INTEGERS { number.label longest.label.width }
%%----------------------------------------------------------------------
STRINGS { h s t u v w }
%% bei der Behandlung der Namen-Funktionsbezeichnung (Hrsg., Redakt., usw)
STRINGS { fkt }
%% fuer die label-Produktion
STRINGS { longest.label }
%%%----------------------------------------------------------------------------
% Einige Standardvorgaben, die vom Benutzer veraendert werden koennen.
%%%----------------------------------------------------------------------------
% Abkuerzung ("... und andere") bei Mehrverfasserquellen:
FUNCTION { ua.etal } { " u.\,a." } %% evtl. auch in eckigen Klammern " [u.\,a.]"
%% oder lateinisch: FUNCTION { ua.etal } { " et~al." }
FUNCTION { und } { " u. " }
%% oder ausgeschrieben: FUNCTION { und } { " und " }
%
% Einige elektronische Medien erhalten nach DIN 1505 eine "Ergaenzende Angabe"
% zusaetzlich zum materiellen Typ, z.B. CD ROM oder DVD u.a.:
FUNCTION { eress } { "Elektronische Ressource" }
%%%-----------------------------------------------------------------------------------
2014-01-22 09:39:06 +00:00
FUNCTION {init.state.consts}
{ #0 'before.all :=
#1 'mid.sentence :=
#2 'after.sentence :=
#3 'after.block :=
#4 'colon.after :=
#5 'period.dash :=
2014-06-10 12:56:14 +00:00
#6 'after.firstblock :=
2014-01-22 09:39:06 +00:00
}
FUNCTION {output.nonnull}
{ 's :=
output.state after.block =
{ add.period$ write$
newline$
"\newblock " write$
}
{ output.state before.all =
2014-06-10 12:56:14 +00:00
{ write$ }
2014-01-22 09:39:06 +00:00
{ output.state colon.after =
{ ": " * write$
newline$
"\newblock " write$
}
{ output.state period.dash =
{ ". -- " * write$
newline$
"\newblock " write$
}
{ output.state mid.sentence =
{ ", " * write$ }
2014-06-10 12:56:14 +00:00
{ output.state after.sentence =
{ " " * write$ }
{ output.state after.firstblock =
{ add.period$ write$
newline$
"\newblock " write$
}
{ write$
newline$
"\newblock " write$
}
if$
}
if$
2014-01-22 09:39:06 +00:00
}
if$
}
2014-06-10 12:56:14 +00:00
if$
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
if$
}
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
after.block 'output.state :=
}
if$
s
}
2014-01-22 09:39:06 +00:00
FUNCTION {output}
{ duplicate$ empty$
'pop$
'output.nonnull
if$
}
FUNCTION {output.check}
{ 't :=
duplicate$ empty$
{ pop$ "empty " t * " in " * cite$ * warning$ }
'output.nonnull
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {new.block}
{ output.state before.all =
'skip$
{ after.block 'output.state := }
if$
}
FUNCTION {not}
{ { #0 }
{ #1 }
if$
}
FUNCTION {and}
{ 'skip$
{ pop$ #0 }
if$
}
FUNCTION {or}
{ { pop$ #1 }
'skip$
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {output.bibitem}
{ newline$
"\bibitem[" write$
2014-06-10 12:56:14 +00:00
label write$%
2014-01-22 09:39:06 +00:00
"]{" write$
cite$ write$
"}" write$
newline$
""
before.all 'output.state :=
}
2014-06-10 12:56:14 +00:00
FUNCTION {fin.entry}
2014-01-22 09:39:06 +00:00
{ write$
newline$
}
FUNCTION {set.period.dash} %% Wenn ein ". - " die Satzteile trennen soll.!
{ output.state before.all =
'skip$
{ period.dash 'output.state := }
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {set.period.dash.check}
{ empty$
2014-01-22 09:39:06 +00:00
'skip$
2014-06-10 12:56:14 +00:00
'set.period.dash
2014-01-22 09:39:06 +00:00
if$
}
FUNCTION {set.colon.after} %%$$$ Wenn ein ": " d. Satzteile trennen soll!
{ output.state before.all =
'skip$
{ colon.after 'output.state := }
if$
}
2014-06-10 12:56:14 +00:00
%% Wenn ein " " die Satzteile trennen soll.!
2014-01-22 09:39:06 +00:00
FUNCTION {new.sentence}
{ output.state before.all =
'skip$
{ after.sentence 'output.state := }
if$
}
2014-06-10 12:56:14 +00:00
%% Wenn ein ", " die Satzteile trennen soll.!
2014-01-22 09:39:06 +00:00
FUNCTION { part.of.sentence }
{ output.state before.all =
'skip$
{ mid.sentence 'output.state := }
if$
}
FUNCTION {new.sentence.checka}
{ empty$
'skip$
'new.sentence
if$
}
FUNCTION {field.or.null}
{ duplicate$ empty$
{ pop$ "" }
'skip$
if$
}
FUNCTION {emphasize}
{ duplicate$ empty$
{ pop$ "" }
{ "\emph{" swap$ * "}" * }
if$
}
FUNCTION { capitalize }
{ duplicate$ empty$
{ pop$ "" }
{ "\textsc{" swap$ * "}" * }
if$
}
FUNCTION {article.in.journal}
{ duplicate$ empty$
{ pop$ "" }
2014-06-10 12:56:14 +00:00
{ author missing$ title missing$ and
{ emphasize }
{ emphasize "{In: }" swap$ * }
2014-01-22 09:39:06 +00:00
if$
}
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.doi}
{ doi empty$
{ "" }
{ new.block "\url{http://dx.doi.org/" doi * "}" *
%% { new.block "\url{http://dx.medra.org/" doi * "}" *
}
if$
}
FUNCTION {format.url}
{ urn missing$
{ doi missing$
{ url empty$
{ "" }
{ type empty$ NOT
{ type #-1 #4 substring$ "mail" =
type #1 #4 substring$ "Mail" =
OR
{ type$ "incollection" =
{ "" }
{ "\,Absenderadresse: \url{" url * "}" * }
if$
}
{ "\url{" url * "}" * }%% evtl. "URL" oder "<...>"
if$
}
{ "\url{" url * "}" * } %% evtl. "URL" oder "<...>"
if$
}
if$
}
{ format.doi }
if$
}
{ "\url{http://nbn-resolving.de/urn/resolver.pl?urn=" urn * "}" *
}
if$
}
FUNCTION {format.maillist.url}
{ url empty$
{ "" }
{ type empty$
{ "" }
{ type #-1 #4 substring$ "mail" =
type #1 #4 substring$ "Mail" =
OR
{ "\url{" url * "}" * }
{ "" }
if$
}
if$
}
if$
}
%% Adelspraedikate beim Sortieren nach den(m) Vornamen auffuehren
%% Abweichend v. DIN !!!
2014-01-22 09:39:06 +00:00
FUNCTION {format.names}
{ 's :=
"" 'u :=
#1 'nameptr :=
s num.names$ 'numnames :=
numnames 'namesleft :=
{ namesleft #0 > }
{
s nameptr "{ll}" format.name$ 't :=
t capitalize 't :=
2014-06-10 12:56:14 +00:00
s nameptr "{ jj}" format.name$ 'w :=
s nameptr "{, ff}{ vv}{ jj}" format.name$ 'u :=
u text.length$ 'lang :=
2014-01-22 09:39:06 +00:00
#1 'zahl :=
"" 'v :=
{ zahl lang < }
2014-06-10 12:56:14 +00:00
{ u zahl #1 substring$ "~" =
2014-01-22 09:39:06 +00:00
{ v "" =
{ u #1 zahl #1 - substring$ 'v := }
'skip$
if$
2014-06-10 12:56:14 +00:00
v u zahl #2 substring$ * "." * w * 'v :=
}
2014-01-22 09:39:06 +00:00
'skip$
if$
zahl #1 + 'zahl := }
while$
v "" =
{ u 'v := }
'skip$
if$
2014-06-10 12:56:14 +00:00
t v * fkt * 't :=
2014-01-22 09:39:06 +00:00
nameptr #1 >
{ namesleft #1 >
{ " ; " * t * }
{ numnames #2 >
{ " " * }
'skip$
if$
t "\textsc{others}" = t "\textsc{others} (Hrsg.)" = or
2014-06-10 12:56:14 +00:00
{ ua.etal * }
{ " ; " * t * }
2014-01-22 09:39:06 +00:00
if$
}
if$ %% Ende der namesleft-Pruefung
}
2014-06-10 12:56:14 +00:00
't
if$ %% Ende der nameptr-Pruefung
2014-01-22 09:39:06 +00:00
nameptr #1 + 'nameptr :=
namesleft #1 - 'namesleft :=
}
while$ %% Ende von { namesleft #0 > } ganz oben
"" 'fkt := %% fkt wird zurueckgesetzt
}
FUNCTION {format.authors}
{ author empty$
{ "" }
{ author format.names }
if$
}
FUNCTION {format.editors}
{ editor empty$
{ author empty$
2014-06-10 12:56:14 +00:00
{ "empty author and editor in " cite$ * warning$ "" }
'skip$
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
}
{ author empty$
{ " (Hrsg.)" 'fkt :=
editor format.names
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
{ " (Hrsg.)" 'fkt :=
2014-01-22 09:39:06 +00:00
" ; " * editor format.names *
}
if$
2014-06-10 12:56:14 +00:00
}
if$
}
FUNCTION { format.authors.organization }
{ type$ "misc" =
{ organization empty$
{ author empty$
{ "" }
{ author format.names " (Erfinder)" * }
if$
}
{ author empty$
{ organization }
{ author format.names " (Erfinder); " *
organization * " (Anmelder)" *
}
if$
}
if$
}
{ type$ "manual" =
{ organization empty$
{ format.authors }
{ author empty$
{ organization capitalize " (Hrsg.)" * }
{ author format.names }
if$
}
if$
}
'skip$
if$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION { format.editors.organization }
{ organization empty$
'skip$
{ type$ "misc" =
{ organization }
2014-06-10 12:56:14 +00:00
{ * " ; " * organization " (Veranst.)" *}
2014-01-22 09:39:06 +00:00
if$
}
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION { format.tr.institution }
{ institution empty$
'skip$
{ institution capitalize }
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.ed.incoll}
{ editor empty$
{ "" }
2014-06-10 12:56:14 +00:00
{ " (Hrsg.)" 'fkt :=
editor format.names
format.editors.organization
2014-01-22 09:39:06 +00:00
}
if$
2014-06-10 12:56:14 +00:00
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.title}
{ title empty$
{ "" }
{ title } %% Text so wie er dasteht im Feld title
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.number}
{ number empty$
{ "" }
{ number " " * } %% Text so wie er im Feld number steht plus " "
if$
}
FUNCTION {format.digital.type}%% nur in booklet
{ type empty$
{ "" }
{ type #-1 #4 substring$ "mail" =
type #1 #4 substring$ "Mail" =
OR
{ "" }
{ type } %% Typ einer digitalen Ressource in Form einer
%% "Ergaenzenden Angabe", so wie er dasteht;
%% Alternativ kann dieser Text auch in NOTE erfasst werden.
if$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {n.dashify}
{ 't :=
""
{ t empty$ not }
{ t #1 #1 substring$ "-" =
2014-06-10 12:56:14 +00:00
{ t #1 #2 substring$ "--" = not
{ "--" *
t #2 global.max$ substring$ 't :=
}
{ { t #1 #1 substring$ "-" = }
{ "-" *
t #2 global.max$ substring$ 't :=
}
while$
}
if$
}
{ t #1 #1 substring$ *
t #2 global.max$ substring$ 't :=
}
2014-01-22 09:39:06 +00:00
if$
}
while$
}
2014-06-10 12:56:14 +00:00
%% Auflagenvermerke gibt man komplett, einschliesslich Abkuerzungen in
%% das Feld edition ein: ---> EDITION= { 3., erw. und verb. Aufl. }
%% oder fremdsprachlich: EDITION= { 2nd edition }
FUNCTION {format.edition}
{ edition empty$
{ "" }
{ edition }
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.date}
2014-06-10 12:56:14 +00:00
{ year duplicate$ empty$
{ "empty year in " cite$ * warning$
pop$ "" }
'skip$
if$
month empty$
'skip$
{ type$ "book" =
type$ "inbook" =
OR
'skip$
{ month " " * swap$ * }
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
}
if$
}
FUNCTION {format.edition.or.date}
{ edition empty$ year empty$ and
{ "" }
{ edition empty$
{ type empty$ NOT
{ type #-1 #4 substring$ "mail" =
type #1 #4 substring$ "Mail" =
OR
{ " gesendet: " "-- " type * swap$ *
format.date *
}
{ "\,Version:\,"
format.date *
}
if$
}
{ "\,Version:\,"
format.date *
}
if$
}
{ year empty$
{ "\,Version:\," edition * }
{ "\,Version:\," edition * ", " *
format.date *
}
if$
}
2014-01-22 09:39:06 +00:00
if$
}
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.version.url}
{ url empty$ doi empty$ urn empty$ and and
{ type$ "techreport" =
{ format.edition }
{ "" }
if$
}
{ format.edition.or.date output format.url }
if$
}
FUNCTION {format.edition.or.version}
{ url empty$ doi empty$ urn empty$ and and
{ format.edition }
{ format.edition.or.date }
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.address.publisher.year}
{ publisher empty$
{ address empty$
2014-06-10 12:56:14 +00:00
{ year empty$
2014-01-22 09:39:06 +00:00
{ "" }
2014-06-10 12:56:14 +00:00
{ year }
2014-01-22 09:39:06 +00:00
if$
}
2014-06-10 12:56:14 +00:00
{ "there's an address but no publisher in " cite$ * warning$
address ", " * format.date *
2014-01-22 09:39:06 +00:00
}
if$
}
{ address empty$
{ year empty$
2014-06-10 12:56:14 +00:00
{ "neither address nor publication date in " cite$ * warning$
publisher
}
{ publisher ", " * format.date * }
2014-01-22 09:39:06 +00:00
if$
}
{ year empty$
{ address " : " * publisher * }
{ address " : " * publisher * ", " * format.date * }
if$
}
if$
2014-06-10 12:56:14 +00:00
}
if$
}
FUNCTION {format.address.publisher.year.alt}
{ publisher empty$
{ address empty$
{ year empty$
{ "" }
{ url empty$
{ year }
{ "" }
if$
}
if$
}
{ "there's an address but no publisher in " cite$ * warning$
address ", " * format.date *
}
if$
}
{ url empty$%%%% wenn es URL gibt wird nur die service-provider Adresse
%%% ausgegeben, die im publisher-Feld steht
{ address empty$
{ year empty$
{ "neither address nor publication date in " cite$ * warning$
publisher
}
{ publisher ", " * format.date * }
if$
}
{ year empty$
{ address " : " * publisher * }
{ address " : " * publisher * ", " * format.date * }
if$
}
if$
}
{ publisher }
if$
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
if$
}
FUNCTION {format.howpublished}
{ url missing$ urn missing$ doi missing$ AND AND
{ howpublished empty$
{ address empty$
{ type empty$
{ "" }
{ type #-1 #4 substring$ "mail" =
{ "(gesendet: " new.sentence
format.date * ")" *
}
{ "" }
if$
}
if$
format.date *
}
{ address ", " * format.date * }
if$
}
{ address empty$
{ howpublished ", " * format.date * }
{ address " : " * howpublished * ", " * format.date * }
if$
}
if$
}
{ howpublished empty$
{ "" }
{ howpublished }
if$
}
2014-01-22 09:39:06 +00:00
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.lastchecked.or.type}%% nur in misc-Funktion
{ lastchecked empty$
{ url empty$ doi empty$ urn empty$ and and
{ type empty$
{ skip$ }
{ type set.period.dash.check
type output
}
if$
}
{ type empty$
{ skip$ }
{ type #-1 #4 substring$ "mail" =
type #1 #4 substring$ "Mail" =
OR
{ skip$ }
{ type set.period.dash.check
type output }
if$
}
if$
}
if$
}
{ url empty$ doi empty$ urn empty$ and and
{ "there's a lastchecked date but no url, urn or doi in "
cite$ * warning$
}
{ type empty$
{ "there's a URL and a lastchecked date but no type in "
cite$ * warning$
}
{ type set.period.dash.check
type output
part.of.sentence
lastchecked "Abruf: " swap$ * output
}
if$
}
if$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.btitle}
{ title emphasize
}
FUNCTION {tie.or.space.connect}
{ duplicate$ text.length$ #3 <
{ "~" }
{ " " }
if$
swap$ * *
}
FUNCTION {format.btitle.vol}
{ number empty$
{ series empty$
{ volume empty$
{ title emphasize }
{ title emphasize ". Bd." * volume tie.or.space.connect }
if$
}
{ volume empty$
{ title emphasize }%% ein Buch, das zusaetzl. SERIES=Reihentitel besitzt
%% jetzt kommt d. Fall des mehrbaendigen Werkes mit Gesamttitel=SERIES
2014-06-10 12:56:14 +00:00
%% Zaehlung=VOLUME und Bandtitel=TITLE;
{ series emphasize ". Bd." * volume tie.or.space.connect
": " * "{\emph{" * title * "}}" * }
2014-01-22 09:39:06 +00:00
if$
}
if$%% series-test
}
{ title emphasize }%% wenn number ex., dann immer title-Feld
if$%% Ende number-test
}
FUNCTION {format.series.number.din}
{ volume empty$
{ number empty$
2014-06-10 12:56:14 +00:00
{ series empty$
{ "" }
{ "(" series * ")" * } %% d. Seriennr koennte auch gleich hier
2014-01-22 09:39:06 +00:00
%% im SERIES-Feld miterfasst werden
2014-06-10 12:56:14 +00:00
if$
}
2014-01-22 09:39:06 +00:00
{ series empty$
2014-06-10 12:56:14 +00:00
{ "(" number * ")" *
"there's a number but no series in " cite$ * warning$
2014-01-22 09:39:06 +00:00
}
{ "(" series * number tie.or.space.connect ")" * }
if$
}
if$
}
{ series empty$
{ "" }
{ type$ "proceedings" = %% Sonderfall, es darf VOLUME und NUMBER ex. !
2014-06-10 12:56:14 +00:00
type$ "inproceedings" = OR
{ number empty$
2014-01-22 09:39:06 +00:00
{ "(" series * ")" * }
{ "(" series * number tie.or.space.connect ")" * }
if$
}
{ "" }%% Ausstieg mit Nullstring, s. Kommentar
if$
}%% bei gezaehlten Reihen MUSS die Reihennr. im Feld NUMBER stehen!
2014-06-10 12:56:14 +00:00
if$ %% wenn also d. Feld VOLUME nicht leer ist, dann liegt ausser bei
2014-01-22 09:39:06 +00:00
%% Typ PROCEEDINGS falsche
} %% Erfassung vor und es erfolgt d. Ausstieg mit d. Nullstring!
2014-06-10 12:56:14 +00:00
if$
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.tr.series.or.number}
{ number empty$
{ series empty$
{ "" }
{ "(" series * ")" * }
if$
}
{ series empty$
{ "(" number * ")" * }
{ "(" series * number tie.or.space.connect ")" * }
if$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.misc.series}
{ series empty$
{ "" }
{ "(" series * ")" * }
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION { format.doi.urn }
{ urn empty$
{ doi empty$
{ "" }
{ "DOI" doi n.dashify tie.or.space.connect }
if$
}
{ "URN" urn n.dashify tie.or.space.connect }
2014-01-22 09:39:06 +00:00
if$
}
FUNCTION { format.isbn.issn }
{ isbn empty$
{ issn empty$
{ "" }
{ "ISSN" issn n.dashify tie.or.space.connect }
if$
}
{ "ISBN" isbn n.dashify tie.or.space.connect }
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.pages}
{ pages empty$
{ "" }
{ url empty$
{ "S." pages n.dashify tie.or.space.connect }
{ pages }
if$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.pages.book}
{ pages empty$
2014-06-10 12:56:14 +00:00
{ "" }
{ note empty$ isbn empty$ AND
{ "" pages n.dashify tie.or.space.connect " S" *
add.period$ }
{ "" pages n.dashify tie.or.space.connect " S" * }
if$
}
2014-01-22 09:39:06 +00:00
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.pages.bkcollation}
2014-01-22 09:39:06 +00:00
{ pages empty$
{ "" }
2014-06-10 12:56:14 +00:00
{ "" pages n.dashify tie.or.space.connect }
2014-01-22 09:39:06 +00:00
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.bkpages.collat.check}
{ 's :=
#1 'ptr :=
s text.length$ 'collation :=
collation #1 =
{ format.pages.book }
{
collation 'collrest :=
{ collrest #0 > }
{ s ptr #2 substring$ 't :=
t "S." =
{ format.pages.bkcollation
#0 'collrest := }
{ ptr #1 + 'ptr :=
collrest #1 - 'collrest :=
#1 collrest =
{ format.pages.book }
{ skip$ }
if$
}
if$
}
while$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.vol.year.num.pages}
{ volume field.or.null
year empty$
2014-06-10 12:56:14 +00:00
{ "there's no year in " cite$ * warning$ }
2014-01-22 09:39:06 +00:00
{ " (" year * ")" * * }
if$
month empty$
2014-06-10 12:56:14 +00:00
'skip$
{ ", " month * * }
2014-01-22 09:39:06 +00:00
if$
number empty$
'skip$
2014-06-10 12:56:14 +00:00
{ ", Nr. " number * * }
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
pages empty$
'skip$
{ duplicate$ empty$
{ pop$ "" }
{ title missing$
{ ", " pages format.bkpages.collat.check * *}
{ ", " format.pages * *}
if$
}
if$
}
if$
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.chapter.inbook}
{ duplicate$ empty$
{ pop$ "empty chapter in " cite$ * warning$ }
{ type empty$
{ "\emph{Kapitel\/} " swap$ tie.or.space.connect }
{ type " " * swap$ * }%% wenn keine bes. Abschnittsform gen. werden soll,
%% koennte e. kl. Zwischenraum gewaehlt werden, z.B. " \, "
if$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.chapter.pages}
{ chapter empty$
'format.pages
{ type empty$
2014-06-10 12:56:14 +00:00
{ "Kapitel " }
{ url empty$
{ type }
{ "Kapitel " }
if$
}
2014-01-22 09:39:06 +00:00
if$
chapter tie.or.space.connect
pages empty$
2014-06-10 12:56:14 +00:00
'skip$
{ ", " * format.pages * }
2014-01-22 09:39:06 +00:00
if$
}
if$
}
FUNCTION {format.in.ed.booktitle.din}
{ booktitle empty$
{ "" }
{ editor empty$
2014-06-10 12:56:14 +00:00
{ volume empty$
{ "{In: }" booktitle emphasize * }
{ "{In: }" booktitle emphasize *
" Bd." volume tie.or.space.connect *
2014-01-22 09:39:06 +00:00
}
if$
}
2014-06-10 12:56:14 +00:00
{ volume empty$
2014-01-22 09:39:06 +00:00
{ "{In: }" format.ed.incoll * ": " * booktitle emphasize * }
2014-06-10 12:56:14 +00:00
{ "{In: }" format.ed.incoll * ": " * booktitle emphasize *
" Bd." volume tie.or.space.connect *
2014-01-22 09:39:06 +00:00
}
if$
}
if$
}
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.thesis.tr.type}
2014-01-22 09:39:06 +00:00
{ type empty$
'skip$
2014-06-10 12:56:14 +00:00
{ pop$
type
}
if$
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.online.lastcheck}
{ lastchecked empty$
{ url empty$ doi empty$ urn empty$ and and
{ skip$ }
{ "" output }
if$
}
{ url empty$ doi empty$ urn empty$ and and
{ "there's a lastchecked date but no url, urn or doi in "
cite$ * warning$
}
{ part.of.sentence
lastchecked "Abruf: " swap$ * output
}
if$
}
if$
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.maillist.lastcheck}
{ type empty$ NOT
{ type #-1 #4 substring$ "mail" =
type #1 #4 substring$ "Mail" =
OR
{ format.online.lastcheck }
'skip$
if$
}
'skip$
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.article.crossref}
{ key empty$
{ journal empty$
2014-06-10 12:56:14 +00:00
{ "need key or journal for " cite$ * " to crossref " * crossref *
warning$
""
}
{ "{In: }{\emph " journal * "}" * }
2014-01-22 09:39:06 +00:00
if$
}
2014-06-10 12:56:14 +00:00
{ "{In: }" key * }
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
"\cite{" * crossref * "}" * ", " * format.pages *
2014-01-22 09:39:06 +00:00
}
FUNCTION {format.crossref.editor}
{ editor #1 "{ll}" format.name$ " (Hrsg.)" *
editor num.names$ duplicate$
#2 >
2014-06-10 12:56:14 +00:00
{ pop$ ua.etal * }%% --->u. a.
2014-01-22 09:39:06 +00:00
{ #2 <
2014-06-10 12:56:14 +00:00
'skip$
{ editor #2 "{ff }{vv }{ll}{ jj}" format.name$ "others" =
{ ua.etal }
{ " ; " * editor #2 "{vv~}{ll}" format.name$ * " (Hrsg.)" * }
if$
}
2014-01-22 09:39:06 +00:00
if$
}
if$
}
2014-06-10 12:56:14 +00:00
FUNCTION {format.inbk.vol.title}
{ volume empty$
{ " In: " }
{ title empty$
{ " In: Bd." volume tie.or.space.connect
" von " *
}
{ "In: Bd." volume tie.or.space.connect ": " * title emphasize *
" (" * year * ") in " *
}
if$
}
if$
}
2014-01-22 09:39:06 +00:00
FUNCTION {format.book.crossref}
2014-06-10 12:56:14 +00:00
{ type$ "inbook" =
{ format.inbk.vol.title }
{ volume empty$
{ "empty volume in " cite$ * "'s crossref of " * crossref * warning$
" "
}
{ ". -- Bd." volume tie.or.space.connect
" von " *
}
if$
2014-01-22 09:39:06 +00:00
}
if$
editor empty$
editor field.or.null author field.or.null =
or
{ key empty$
2014-06-10 12:56:14 +00:00
{ series empty$
{ "need editor, key, or series for " cite$ * " to crossref " *
crossref * warning$
"" *
}
{ "" * }
if$
}
{ key * }
2014-01-22 09:39:06 +00:00
if$
}
2014-06-10 12:56:14 +00:00
{ "" * }
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
"\cite{" * crossref * "}" *
2014-01-22 09:39:06 +00:00
}
FUNCTION {format.incoll.inproc.crossref}
{ editor empty$
2014-06-10 12:56:14 +00:00
editor field.or.null author field.or.null =
or
{ key empty$
{ booktitle empty$
{ "need editor, key, or booktitle for " cite$ * " to crossref " *
crossref * warning$
""
}
{ "{In: }{\emph " booktitle * "}" * }%%
if$
}
{ "{In: }" }
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
}
{ "{In: }" }
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
"\cite{" * crossref * "}" * %% ", " * format.pages * 5.12.2005
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
2014-01-22 09:39:06 +00:00
FUNCTION {article}
{ output.bibitem
format.authors "author" output.check
set.colon.after
format.title "title" output.check
crossref missing$
2014-06-10 12:56:14 +00:00
{ journal article.in.journal output.nonnull
new.sentence
2014-01-22 09:39:06 +00:00
format.vol.year.num.pages output
2014-06-10 12:56:14 +00:00
format.url output
2014-01-22 09:39:06 +00:00
}
{ format.article.crossref output.nonnull }
if$
2014-06-10 12:56:14 +00:00
format.online.lastcheck
doi set.period.dash.check
urn set.period.dash.check
format.doi.urn output
2014-01-22 09:39:06 +00:00
issn set.period.dash.check
format.isbn.issn output
2014-06-10 12:56:14 +00:00
note set.period.dash.check
note output
2014-01-22 09:39:06 +00:00
fin.entry
}
FUNCTION {book}
{ output.bibitem
author empty$
{ format.editors "author and editor" output.check }
2014-06-10 12:56:14 +00:00
{ format.authors format.editors output.nonnull }
2014-01-22 09:39:06 +00:00
if$
set.colon.after
crossref missing$
{ format.btitle.vol "title" output.check }
{ format.btitle "title" output.check }
if$
2014-06-10 12:56:14 +00:00
format.edition output
2014-01-22 09:39:06 +00:00
format.address.publisher.year "publisher" output.check
new.sentence
crossref missing$
2014-06-10 12:56:14 +00:00
{ format.series.number.din output }
{ format.book.crossref output.nonnull }
if$
pages empty$
{ skip$ }
{ pages set.period.dash.check
pages format.bkpages.collat.check output
2014-01-22 09:39:06 +00:00
}
if$
2014-06-10 12:56:14 +00:00
format.doi output
format.url output
new.block
2014-01-22 09:39:06 +00:00
isbn set.period.dash.check
format.isbn.issn output
2014-06-10 12:56:14 +00:00
note set.period.dash.check
note output
2014-01-22 09:39:06 +00:00
fin.entry
}
2014-06-10 12:56:14 +00:00
FUNCTION {booklet}
2014-01-22 09:39:06 +00:00
{ output.bibitem
author empty$
{ format.editors "author and editor" output.check }
2014-06-10 12:56:14 +00:00
{ format.authors format.editors output.nonnull }
2014-01-22 09:39:06 +00:00
if$
set.colon.after
2014-06-10 12:56:14 +00:00
format.btitle "title" output.check
format.edition.or.version output
format.url output
format.online.lastcheck
format.howpublished output
series new.sentence.checka
format.series.number.din output
pages empty$
{ skip$ }
{ pages set.period.dash.check
pages format.bkpages.collat.check output
}
if$
type set.period.dash.check
format.digital.type output
doi set.period.dash.check
urn set.period.dash.check
format.doi.urn output
note set.period.dash.check
note output
format.isbn.issn output
fin.entry
}
FUNCTION {inbook}
{ output.bibitem
chapter format.chapter.inbook output.nonnull
crossref missing$
{ author empty$
{ format.editors "\,{In:\,}" swap$ * "author and editor" output.check }
{ format.authors "\,{In:\,}" swap$ * output.nonnull }
if$
author empty$ editor empty$ AND
{ before.all 'output.state := }
{ set.colon.after }
if$
format.btitle.vol "title" output.check
format.edition output
2014-01-22 09:39:06 +00:00
format.address.publisher.year "publisher" output.check
new.sentence
2014-06-10 12:56:14 +00:00
format.series.number.din output
isbn set.period.dash.check
format.isbn.issn output
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
{ format.book.crossref output.nonnull }
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
part.of.sentence
format.pages output
note set.period.dash.check
note output
2014-01-22 09:39:06 +00:00
fin.entry
}
FUNCTION {incollection}
{ output.bibitem
format.authors "author" output.check
set.colon.after
format.title "title" output.check
2014-06-10 12:56:14 +00:00
format.version.url output
type empty$ NOT
{ type #-1 #4 substring$ "mail" =
type #1 #4 substring$ "Mail" =
OR
'skip$
{ format.online.lastcheck }
if$
}
{ format.online.lastcheck }
if$
2014-01-22 09:39:06 +00:00
crossref missing$
{ format.in.ed.booktitle.din "booktitle" output.check
format.edition output
format.address.publisher.year "publisher" output.check
2014-06-10 12:56:14 +00:00
format.maillist.url output
format.maillist.lastcheck
2014-01-22 09:39:06 +00:00
new.sentence
format.series.number.din output
2014-06-10 12:56:14 +00:00
doi set.period.dash.check
urn set.period.dash.check
format.doi.urn output
2014-01-22 09:39:06 +00:00
isbn set.period.dash.check
issn set.period.dash.check
format.isbn.issn output
}
2014-06-10 12:56:14 +00:00
{ format.incoll.inproc.crossref output.nonnull }
if$
part.of.sentence
format.chapter.pages "pages" output.check
note set.period.dash.check
note output
fin.entry
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
2014-01-22 09:39:06 +00:00
FUNCTION {inproceedings}
{ output.bibitem
format.authors "author" output.check
set.colon.after
format.title "title" output.check
crossref missing$
{ format.in.ed.booktitle.din "booktitle" output.check
address empty$
2014-06-10 12:56:14 +00:00
{ organization new.sentence.checka
organization output
2014-01-22 09:39:06 +00:00
part.of.sentence
format.address.publisher.year output
2014-06-10 12:56:14 +00:00
}
{ format.address.publisher.year "publisher" output.check }
2014-01-22 09:39:06 +00:00
if$
new.sentence
2014-06-10 12:56:14 +00:00
series empty$
2014-01-22 09:39:06 +00:00
'skip$
{ format.series.number.din output }
if$
isbn set.period.dash.check
issn set.period.dash.check
format.isbn.issn output
}
2014-06-10 12:56:14 +00:00
{ format.incoll.inproc.crossref output.nonnull }
if$
part.of.sentence
format.pages "pages" output.check
note set.period.dash.check
note output
fin.entry
2014-01-22 09:39:06 +00:00
}
FUNCTION {conference} { inproceedings }%% nach Patashnik, wg US-Kompatibilitaet
FUNCTION {manual}
{ output.bibitem
author empty$
{ organization empty$
{ title empty$
2014-06-10 12:56:14 +00:00
'skip$
2014-01-22 09:39:06 +00:00
{format.btitle "title" output.check }
if$
}
2014-06-10 12:56:14 +00:00
'skip$
2014-01-22 09:39:06 +00:00
if$
}
2014-06-10 12:56:14 +00:00
'skip$
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
format.authors.organization output.nonnull
set.colon.after
format.btitle "title" output.check
2014-01-22 09:39:06 +00:00
format.edition "edition" output.check
2014-06-10 12:56:14 +00:00
author empty$ organization empty$ AND
{ address "address" output.check
part.of.sentence
}
2014-01-22 09:39:06 +00:00
{ organization empty$
2014-06-10 12:56:14 +00:00
{ address "address" output.check
part.of.sentence
}
{ address ": " * organization * output
2014-01-22 09:39:06 +00:00
part.of.sentence
2014-06-10 12:56:14 +00:00
}
2014-01-22 09:39:06 +00:00
if$
}
if$
format.date output
2014-06-10 12:56:14 +00:00
number empty$
'skip$
{ "(" number * ") " * output }
if$
pages empty$
{ skip$ }
{ pages set.period.dash.check
pages format.bkpages.collat.check output
}
if$
format.doi output
format.url output
format.online.lastcheck
2014-01-22 09:39:06 +00:00
note set.period.dash.check
note output
fin.entry
}
2014-06-10 12:56:14 +00:00
%% Standard ist "Diplomarbeit", anderes mit TYPE="anderer Typ" erfassen!
%% z.B. TYPE={Hausarbeit}, TYPE={Diss.}, TYPE={Habil.}, TYPE={Magisterarb.}
2014-01-22 09:39:06 +00:00
FUNCTION {mastersthesis}
{ output.bibitem
format.authors "author" output.check
set.colon.after
format.btitle "title" output.check
address output
2014-06-10 12:56:14 +00:00
part.of.sentence
2014-01-22 09:39:06 +00:00
school "school" output.check
part.of.sentence
2014-06-10 12:56:14 +00:00
"Diplomarbeit" format.thesis.tr.type output.nonnull
2014-01-22 09:39:06 +00:00
part.of.sentence
format.date "year" output.check
2014-06-10 12:56:14 +00:00
format.url output
format.online.lastcheck
%% format.digital.resource.type
doi set.period.dash.check
urn set.period.dash.check
format.doi.urn output
%% pages set.period.dash.check
%% format.pages.book output
pages empty$
{ skip$ }
{ pages set.period.dash.check
pages format.bkpages.collat.check output
}
if$
2014-01-22 09:39:06 +00:00
note set.period.dash.check
note output
fin.entry
}
FUNCTION {phdthesis} %% {mastersthesis}% ist identisch bis auf Standardwert, s.o.
{ output.bibitem
format.authors "author" output.check
set.colon.after
format.btitle "title" output.check
address output
2014-06-10 12:56:14 +00:00
part.of.sentence
2014-01-22 09:39:06 +00:00
school "school" output.check
part.of.sentence
2014-06-10 12:56:14 +00:00
"Diss." format.thesis.tr.type output.nonnull % koennte auch `Dissertation' sein
2014-01-22 09:39:06 +00:00
part.of.sentence
format.date "year" output.check
2014-06-10 12:56:14 +00:00
format.url output
format.online.lastcheck
%% format.digital.resource.type
doi set.period.dash.check
urn set.period.dash.check
format.doi.urn output
pages empty$
{ skip$ }
{ pages set.period.dash.check
pages format.bkpages.collat.check output
}
if$
%% pages set.period.dash.check
%% format.pages.book output
2014-01-22 09:39:06 +00:00
note set.period.dash.check
note output
fin.entry
}
2014-06-10 12:56:14 +00:00
%% Normen, Vornormen, Schutzrechte (Patente) werden hiermit erfasst;
%% (z.Zt. auch noch Internetressourcen)
%% das type-Feld uebernimmt eine wichtige Steuerfunktion:
2014-01-22 09:39:06 +00:00
FUNCTION {misc}
{ output.bibitem
2014-06-10 12:56:14 +00:00
type missing$ not
{ type duplicate$ #1 #4 substring$ "Norm" =
type #1 #4 substring$ "Vorn" = OR
{ " " *
format.number * output
2014-01-22 09:39:06 +00:00
new.sentence
2014-06-10 12:56:14 +00:00
format.date output
title empty$
{ skip$ }
{ add.period$ new.sentence }
if$
format.btitle "title" output.check
2014-01-22 09:39:06 +00:00
note set.period.dash.check
note output
}
2014-06-10 12:56:14 +00:00
{ duplicate$ #1 #6 substring$ "Schutz" =
{ " " * format.number * output
new.sentence
"(" * format.date ")" * output
add.period$ new.sentence
format.authors.organization add.period$ output
note output
}
%% wenn irgendein anderer Typ eingetragen ist
{ pop$ pop$ ""
title empty$
{ note empty$
{ url empty$
{ "there's no relevant field in " cite$ warning$
pop$ ""
}
{ format.url output }%%%
if$
}
{ note " " * output.nonnull }
if$
}
{ author empty$
{ editor empty$
{ organization empty$
{ skip$ }
{ format.editors.organization output.nonnull
set.colon.after
}
if$
}
{ format.editors format.editors.organization
output.nonnull set.colon.after
}
if$
}
{ format.authors format.editors output.nonnull
set.colon.after
}
if$
format.btitle output.nonnull
url empty$
{ format.edition output
format.howpublished output}
{ format.howpublished output
format.edition.or.date output
format.url output
}
if$
format.online.lastcheck
new.sentence
format.misc.series output
%% note set.period.dash.check
note output
}
if$
}
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
}
if$
2014-01-22 09:39:06 +00:00
}
2014-06-10 12:56:14 +00:00
%% wenn es keinen type gibt
{ title empty$
{ note empty$
{ url empty$
{ "there's no relevant field in " cite$ warning$
pop$ ""
}
{ format.url output }%%% das waere e. reine URL
if$
}
{ note " " * output.nonnull
%% format.url format.date output
}
if$
}
{ author empty$
{ editor empty$
{ organization empty$
{ skip$ }
{ format.editors.organization output.nonnull
set.colon.after
}
if$
}
{ format.editors format.editors.organization
output.nonnull set.colon.after
}
if$
}
{ format.authors format.editors output.nonnull
set.colon.after
}
if$
format.btitle output.nonnull
url empty$
{ format.edition output
format.howpublished output}
{ format.howpublished output
format.url output
format.edition.or.date output
format.online.lastcheck
}
if$
new.sentence
format.misc.series output
note set.period.dash.check
note output
}
if$
}
if$
fin.entry
2014-01-22 09:39:06 +00:00
}
FUNCTION {proceedings}
{ output.bibitem
editor empty$
{ organization empty$
2014-06-10 12:56:14 +00:00
{ "empty organization and editor in " cite$ * warning$ }
2014-01-22 09:39:06 +00:00
{ organization " (Veranst.)" * output }
if$
}
{ format.editors format.editors.organization output.nonnull }
if$
set.colon.after
format.btitle "title" output.check
volume empty$
2014-06-10 12:56:14 +00:00
{ skip$ }
2014-01-22 09:39:06 +00:00
{ "{\textnormal{Bd.}}" volume tie.or.space.connect emphasize "volume" output.check }
if$
format.address.publisher.year "publisher" output.check
new.sentence
format.series.number.din output.nonnull
2014-06-10 12:56:14 +00:00
pages empty$
{ skip$ }
{ pages set.period.dash.check
pages format.bkpages.collat.check output
}
if$
2014-01-22 09:39:06 +00:00
isbn set.period.dash.check
issn set.period.dash.check
format.isbn.issn output
2014-06-10 12:56:14 +00:00
note set.period.dash.check
note output
2014-01-22 09:39:06 +00:00
fin.entry
}
FUNCTION {techreport}
{ output.bibitem
author empty$
2014-06-10 12:56:14 +00:00
{ format.editors "author and editor" output.check
format.tr.institution output.nonnull }
2014-01-22 09:39:06 +00:00
{ format.authors format.editors output.nonnull }
if$
set.colon.after
format.title "title" output.check
institution empty$
'skip$
2014-06-10 12:56:14 +00:00
{ author empty$ editor empty$ AND
'skip$
{ institution new.sentence.checka
"/ " institution * output.nonnull
}
if$
}
2014-01-22 09:39:06 +00:00
if$
2014-06-10 12:56:14 +00:00
format.version.url output
format.online.lastcheck
2014-01-22 09:39:06 +00:00
format.address.publisher.year output
number new.sentence.checka
2014-06-10 12:56:14 +00:00
format.tr.series.or.number "number" output.check
"Forschungsbericht" format.thesis.tr.type set.period.dash.check
"Forschungsbericht" format.thesis.tr.type output
%% format.digital.resource.type
pages empty$
{ skip$ }
{ pages set.period.dash.check
pages format.bkpages.collat.check output
}
if$
2014-01-22 09:39:06 +00:00
isbn set.period.dash.check
issn set.period.dash.check
format.isbn.issn output
2014-06-10 12:56:14 +00:00
note set.period.dash.check
note "note" output.check
2014-01-22 09:39:06 +00:00
fin.entry
}
2014-06-10 12:56:14 +00:00
FUNCTION {unpublished} {misc}%% AUTHOR, TITLE, NOTE muessen sein!
%% andere Felder sind optional
2014-01-22 09:39:06 +00:00
FUNCTION {default.type} { misc }
2014-06-10 12:56:14 +00:00
2014-01-22 09:39:06 +00:00
MACRO {jan} {"Januar"}
MACRO {feb} {"Februar"}
MACRO {mar} {"M{\^^b a}rz"}
MACRO {apr} {"April"}
MACRO {mai} {"Mai"}
MACRO {may} {"Mai"}
MACRO {jun} {"Juni"}
MACRO {jul} {"Juli"}
MACRO {aug} {"August"}
MACRO {sep} {"September"}
MACRO {okt} {"Oktober"}
MACRO {oct} {"Oktober"}
MACRO {nov} {"November"}
MACRO {dez} {"Dezember"}
MACRO {dec} {"Dezember"}
2014-06-10 12:56:14 +00:00
%%$$$ stillgelegte Beispiele fuer den Gebrauch von Kuerzeln (hier Zs-Titel).
2014-01-22 09:39:06 +00:00
%%MACRO {acmcs} {"ACM Computing Surveys"}
%%MACRO {acta} {"Acta Informatica"}
READ
FUNCTION {sortify}
{ purify$
"l" change.case$
}
FUNCTION {chop.word}
{ 's :=
'len :=
s #1 len substring$ =
{ s len #1 + global.max$ substring$ }
's
if$
}
FUNCTION {sort.format.names}
{ 's :=
#1 'nameptr :=
""
s num.names$ 'numnames :=
numnames 'namesleft :=
{ namesleft #0 > }
{ nameptr #1 >
2014-06-10 12:56:14 +00:00
{ " " * }
'skip$
2014-01-22 09:39:06 +00:00
if$
s nameptr "{ll{ }}{ ff{ }}{ vv{ }}{ jj{ }}" format.name$ 't :=
nameptr numnames = t "others" = and
2014-06-10 12:56:14 +00:00
{ ua.etal * }
{ t sortify * }
2014-01-22 09:39:06 +00:00
if$
nameptr #1 + 'nameptr :=
namesleft #1 - 'namesleft :=
}
while$
}
FUNCTION {sort.format.title}
{ 't :=
"A " #2
"An " #3
"Der " #4
"Die " #4
"Das " #4
"Ein " #4
2014-06-10 12:56:14 +00:00
"Eine " #5
2014-01-22 09:39:06 +00:00
"The " #4 t chop.word
chop.word
chop.word
chop.word
chop.word
chop.word
chop.word
chop.word
sortify
#1 global.max$ substring$
}
FUNCTION {author.sort}
{ author empty$
{ key empty$
2014-06-10 12:56:14 +00:00
{ "to sort, need author or key in " cite$ * warning$
""
}
{ key sortify }
2014-01-22 09:39:06 +00:00
if$
}
{ author sort.format.names }
if$
}
FUNCTION {author.editor.sort}
{ author empty$
{ editor empty$
2014-06-10 12:56:14 +00:00
{ key empty$
{ "to sort, need author, editor, or key in " cite$ * warning$
""
}
{ key sortify }
if$
}
{ editor sort.format.names }
2014-01-22 09:39:06 +00:00
if$
}
{ author sort.format.names }
if$
}
FUNCTION {author.organization.sort}
{ author empty$
{ organization empty$
2014-06-10 12:56:14 +00:00
{ key empty$
{ "to sort, need author, organization, or key in " cite$ * warning$
""
}
{ key sortify }
if$
}
{ "The " #4 organization chop.word sortify }
2014-01-22 09:39:06 +00:00
if$
}
{ author sort.format.names }
if$
}
FUNCTION {editor.organization.sort}
{ editor empty$
{ organization empty$
2014-06-10 12:56:14 +00:00
{ key empty$
{ "to sort, need editor, organization, or key in " cite$ * warning$
""
}
{ key sortify }
if$
}
{ "The " #4 organization chop.word sortify }
2014-01-22 09:39:06 +00:00
if$
}
{ editor sort.format.names }
if$
}
FUNCTION {presort}
{ type$ "book" =
type$ "inbook" =
or
'author.editor.sort
{ type$ "proceedings" =
2014-06-10 12:56:14 +00:00
'editor.organization.sort
{ type$ "manual" =
'author.organization.sort
'author.sort
if$
}
2014-01-22 09:39:06 +00:00
if$
}
if$
" "
*
year field.or.null sortify
*
" "
*
title field.or.null
sort.format.title
*
#1 entry.max$ substring$
'sort.key$ :=
}
ITERATE {presort}
SORT
FUNCTION {initialize.longest.label}%% nicht identisch mit der Fkt.im ALPHA-Stil
{ "" 'longest.label :=
#1 'number.label :=
#0 'longest.label.width :=
}
FUNCTION {longest.label.pass}
{ number.label int.to.str$ 'label :=
number.label #1 + 'number.label :=
label width$ longest.label.width >
{ label 'longest.label :=
label width$ 'longest.label.width :=
}
'skip$
if$
}
EXECUTE { initialize.longest.label }
2014-06-10 12:56:14 +00:00
2014-01-22 09:39:06 +00:00
ITERATE { longest.label.pass }
FUNCTION {begin.bib}
{ preamble$ empty$
'skip$
{ preamble$ write$ newline$ }
if$
"\begin{thebibliography}{" longest.label * "}" * write$ newline$
2014-06-10 12:56:14 +00:00
newline$
"% this bibliography is generated by plaindin.bst [8.2] from 2005-12-21"
write$ newline$ newline$
"\providecommand{\url}[1]{\texttt{#1}}"
write$ newline$
"\expandafter\ifx\csname urlstyle\endcsname\relax"
write$ newline$
" \providecommand{\doi}[1]{doi: #1}\else"
write$ newline$
" \providecommand{\doi}{doi: \begingroup \urlstyle{rm}\Url}\fi"
write$ newline$
2014-01-22 09:39:06 +00:00
}
EXECUTE {begin.bib}
EXECUTE {init.state.consts}
ITERATE {call.type$}
FUNCTION {end.bib}
{ newline$
"\end{thebibliography}" write$ newline$
}
EXECUTE {end.bib}