% D R F T C I T E . S T Y
%
% version 3.5 (Jan 1995)
%
% Print the tags instead of the numbers for \cite.
% See also CITE.STY and OVERCITE.STY.
%
% Copyright (C) 1989,1991-1995 by Donald Arseneau
% These macros may be freely transmitted, reproduced, or modified
% provided that this notice is left intact.
%
% Instructions are below, after \endinput.
% ........................
%
% Handle formatting hooks:
% \citeform,\citeleft,\citeright,\citemid,\citepunct
%
% Set defaults:
% [ on the left.
\@ifundefined{citeleft}{\let\citeleft=[}{}
% ] on the right:
\@ifundefined{citeright}{\let\citeright=]}{}
% , (comma space) before note
\@ifundefined{citemid}{\def\citemid{,\penalty\@lowpenalty\ }}{}
% , (comma space) between entries
\@ifundefined{citepunct}{
% Default: To put space after the comma. [nospace] eliminates the space
\def\citepunct{,\penalty\@lowpenalty\ }%
}{}
% Each citation tag left as-is:
\@ifundefined{citeform}{\def\citeform{}}{}
% Do not repeat warnings. [verbose] reverses
\let\oc@verbo\relax
% \citen gives the citation tag in the text and writes the aux file entry.
% Use \citen to give citation name without the other formatting; e.g.,
% "See also ref.~\citen{junk}" gives "See also ref. junk".
%
\edef\citen{\noexpand\protect \expandafter\noexpand\csname citen \endcsname}
\@namedef{citen }#1{%
\edef\@tempa{\@ignspaftercomma,#1, \@end, }% ignore spaces in parameter list.
\edef\@tempa{\expandafter\@ignendcommas\@tempa\@end}%
\if@filesw \immediate\write \@auxout {\string\citation {\@tempa}}\fi
\def\@citea{}%
\@for \@citeb:=\@tempa\do {\@citea
\@ifundefined {b@\@citeb\@extra@b@citeb}%
{{\bf \@citeverb{\@citeb}?}%% issue warning only for first mis-use:
\@dftc@ifund {DCN@\@citeb\@extra@b@citeb}{% delete to warn always
\@warning {Citation `\@citeb' on page \thepage\space undefined}%
}{}% delete to warn always
}% else, defined
{\@dftc@hbox{\@citeverb{\@citeb}}}%
\let\@citea\citepunct\@advancecitecount
}}
% for ignoring spaces in the input:
\def\@ignspaftercomma#1, {\ifx\@end#1\@empty\else
#1,\expandafter\@ignspaftercomma\fi}
\def\@ignendcommas,#1,\@end{#1}
% Make \cite robust.
%
\edef\cite{\noexpand\protect\expandafter\noexpand\csname cite \endcsname}
\@namedef{cite }{\@ifnextchar [{\@tempswatrue\@citex}{\@tempswafalse\@citex[]}}
% Make \@citex refer to \citen:
% (Put a single space before the output)
%
\def\@citex[#1]#2{\@cite{\citen{#2}}{#1}}%
% Replacement for \@cite which defines the formatting normally done
% around the citation list. Adjust the spacing before the citation:
% if no space or if there is extra space due to some punctuation, then
% change to one inter-word space. The way to change this is by changing
% \citeleft, \citemid, and \citeright; but in extreme cases it might be
% necessary to redefine the whole macro.
%
\def\@cite#1#2{\leavevmode
\@tempskipa\lastskip \edef\@tempa{\the\@tempskipa}\unskip
\ifx\@tempa\@zero@skip \spacefactor1001 \fi % if no space before, set flag
\ifnum\spacefactor>\@m \ \else \hskip\@tempskipa \fi
\citeleft{#1\if@tempswa \citemid #2\fi}\citeright
\spacefactor\@m % punctuation in note doesn't affect outside
}
\edef\@zero@skip{\the\z@skip}
%
% Give the citation tag as the label (even if another label is specified)
%
\def\@lbibitem[#1]#2{\global\@HighCite\z@
\item[\@biblabel{\@ifundefined{DCN@#2\@extra@b@citeb}{\@warning
{Reference `#2' on page \thepage\space was never cited}}{}%
\DC@llap{$^{\@nameuse{DCN@#2\@extra@b@citeb}}$\ \ }%%o
\@citeverb{#2}}\hfil]\if@filesw{\def\protect##1{\string ##1\space}%
\immediate\write\@auxout{\string\bibcite{#2}{#1}}}\fi\ignorespaces}
\def\@bibitem#1{\refstepcounter{\@listctr}\@lbibitem[\the\value{\@listctr}]{#1}}
% make the special characters in the citation tag printable
%
\def\@citeverb#1{%
{\citeform{% to get characters <>_|{}: \citeform->\tt
\expandafter \expandafter \expandafter \@gobblethree % do \csname, \string,
\expandafter \string\csname b@#1\endcsname}% % \@gobble, in that order.
}}%
\def\@gobblethree#1#2#3{}
% \@extra@b@citeb is a hook for other style files to further specify
% citations; for example, to number by chapter.
% In case no fancy bib package (chapterbib) defines it:
\@ifundefined{@extra@b@citeb}{\def\@extra@b@citeb{}}{}
%------------------------------------
% Handle optional variations:
\def\nocitecount{%
\def\@advancecitecount{\global\@namedef{DCN@\@citeb\@extra@b@citeb}{}}%
\let\DC@llap\@gobble}
\nocitecount % in case what follows gets removed
\newcount\@HighCite \global\@HighCite\z@
\let\@dftc@ifund\@ifundefined
\let\@dftc@hbox\hbox
\@ifundefined{DeclareOption}{}%
{ \DeclareOption{nocitecount}{\endinput}
\toks@={\def\@dftc@ifund#1#2#3{#2}}
\DeclareOption{verbose}{\the\toks@}
\DeclareOption{tt}{\def\citeform{\tt}}
\DeclareOption{nospace}{\def\citepunct{,\penalty\z@}}
\DeclareOption{space}{\def\citepunct{,\ }}
\DeclareOption{breakcites}{\let\@dftc@hbox\relax}
\ProvidesPackage{drftcite}[1995/01/23 \space v 3.5]
\ProcessOptions }
% The rest deals only with counting, and can be removed if counting is never
% desired.
\let\DC@llap=\llap
%
% count the citations as they appear in the text
%
\def\@advancecitecount{\@ifundefined {DCN@\@citeb\@extra@b@citeb}%
{\global\advance\@HighCite\@ne
\expandafter\xdef\csname DCN@\@citeb\@extra@b@citeb\endcsname{\the\@HighCite}}%
{}}
%
% The remainder handles (counting over) input files skipped by \includeonly.
% It adds code to LaTeX's \include to re-read the .aux file checking the
% \citation commands.
%
% For included files that are skipped (not listed by \includeonly)
% input the .aux file ignoring all commands but \citation, which
% does \@advancecitecount (keeps count of the citations). This adds
% a requirement for other style files that add commands to the .aux
% file: the commands must be safe to execute an extra time.
%
\let\@dftc@include\include
\def\include#1{\relax
\ifx\DC@llap\llap \begingroup % do counting only if wanted
\@ifundefined{cp@#1}{}% don't do if .aux file not there!
{\toks@\expandafter\expandafter\expandafter{\csname cp@#1\endcsname}%
\expandafter\xdef\csname cp@#1\endcsname{\the\toks@
\noexpand\@dftc@auxcite{#1}}}%
\endgroup\fi \@dftc@include{#1}}
%
\def\@dftc@auxcite#1{\begingroup % disable everything but \citation
\let\bibcite\@gobbletwo \let\newlabel\@gobbletwo \let\@writefile\@gobbletwo
\let\bibdata\@gobble \let\bibstyle\@gobble % already \@gobble normally
\def\citation##1{\@for\@citeb:=##1\do {\@advancecitecount}}%
\makeatletter\@input{#1.aux}\endgroup
}
\endinput
% D R F T C I T E . S T Y
%
% version 3.5 (Jan 1995)
%
% This package makes LaTeX use the identifying label instead of the number
% for citations, as if the bibliography had entries like \bibitem[name]{name}
% but LaTeX writes the proper citation number to the aux file for later runs.
% Spaces before the \cite command are ignored, and an ordinary interword
% space is used. This package is particularly useful for draft (draught)
% versions of documents.
%
% The \citen command is provided, as in cite.sty, to print just the citation
% or list of citations without the brackets and other formatting.
%
% Drftcite keeps track of which references were cited, and issues warnings
% for bibliography items that were never cited in the text.
%
% This package also keeps track of the order of first-citations in the text
% for easy sorting (in lieu of BibTeX). To omit this counting...
% LaTeX 2.09: declare \nocitecount before the first \cite; or, for
% a more permanent removal, comment-out the lines ending with %%o
% below, and omit everything following the line that begins with %%o.
% LaTeX2e: specify \usepackage[nocitecount]{drftcite}, or perform the
% editing described above.
%
% The characters <>|_{}\ are not present in the cm roman fonts, so if you use
% them in identifiers, they will have to be typeset in typewriter style.
% To do this,...
% LaTeX 2.09: insert \renewcommand\citeform{\tt} in your preamble
% LaTeX2e: specify \usepackage[tt]{drftcite}
%
% `Citation...undefined' warnings are only given once per undefined
% citation name. In the text, missing numbers are represented with a
% bold `name?'. To restore multiple warnings...
% LaTex 2.09: edit this file, removing the lines with the comments:
% "delete to warn always"
% LaTeX2e: specify \usepackage[verbose]{drftcite}
%
% Other options for \usepackage are:
% [space] - Separate printed names with comma-space (Default).
% [nospace] - Print just a comma (not comma-space) after each name.
% [breakcites] - Allow each printed name to be broken (hyphenated).
%
% There are several commands that you may redefine (using \renewcommand)
% to change the formatting of citation lists:
%
% command function default
% ---------- ----------------------- ----------------------------
% \citeform reformats every entry nothing
% \citepunct printed between numbers comma + space
% \citeleft left delimiter of list [
% \citeright right delimeter of list ]
% \citemid printed before note comma + space
%
% This version of drftcite can co-exist with chapterbib.sty (version 1.4
% or later).
%
% [This file is named "drftcite" because "draftcite" is too long a name for
% some computers. Sorry to those who use the spelling "draught." I could
% have abbreviated the name by selecting the shared letters in "draft" and
% "draught," but "dratcite" somehow conveys the wrong meaning.]
%
% Version 1991: Ignore spaces after commas in the parameter list. Create
% \nocitecount to turn off counting the order of citations.
% Version 3.1 (1992): protect \cite and \citen. (There is no version 3.0)
% Version 3.2 (1993): Supress repetitions of warning messages. Include
% \@extra@b@citeb hook for chapterbib.sty. Make \include handle case that
% \cp@FOO was not defined.
% Version 3.3 (1993): Fix \nocitecount. Change printing of undefined refs.
% Version 3.4 (1994): LaTex2e support, including spaces in protected command
% names; better chapterbib support.
% Version 3.5 (1995): Add tests before removing space + options from cite.sty.
% change \@citeverb to not eat hash space.
%
% Send problem reports to [email protected]
%
% Test integrity of file:
% brackets: round, square, curly, angle: () [] {} <>
% backslash, slash, vertical, at, dollar, and: \ / | @ $ &
% hat, grave, acute (apostrophe), quote, tilde, under: ^ ` ' " ~ _
|