The package EASYBIB

Enrico Bertolazzi

Laboratorio di Matematica Applicata e Meccanica Computazionale
Dipartimento di Ingegneria Meccanica e Strutturale
Università degli Studi di Trento
Mesiano, Trento, Italy

enrico.bertolazzi@ing.unitn.it

Abstract:

The package EASYBIB introduces some new items for easy customization of the bibliography.


Contents

The package EASYBIB

The scheme for the bibliography in the package EASYBIB was inspired by the beautiful bibliography system of AMS-TEX . Due to the necessity of flexibility, the syntax is a little bit different but the functionality is similar (although not identical). For the use, load the package using the usual syntax:

  
  \documentclass{article}
  .
  .
  \usepackage[definethebibliography]{easybib}
  .
  .
The option \definethebibliography permits to override the default thebibliography environment. In this case the environment thebibliography take this form:

  
  \begin{thebibliography}``[optional name]''
                         ``(\cmd,space)''{99}
  .
  .
  .
  \end{thebibliography}
so that you can override the default name \refname with your own name, you can change the default \section* with \cmd and add extra space space before the items. The syntax of the bibliography command is now the following


\begin{thebibliography}{99}

\bookref{label name}
  \by        Author(s) name
  \bysame
  \title     Title of the book
  \bookinfo  ...
  \publ      publisher
  \publaddr  publisher address
  \pages     pages number
  \yr        year
  \lang      ...
  \transl    ...
\endref

\paperref{label name}
  \by        Author(s) name
  \bysame
  \title     Title of the book
  \transl    ...
  \jour      Journal name
  \toappear  ...
  \inbook    ...
  \publ      publisher
  \eds       ...
  \publaddr  publisher address
  \vol       volume
  \yr        year
  \pages     pages number
  \finalinfo ...
  \lang      ...
\endref

\end{thebibliography}

the command


  \bookref``[display label]''{label} ... \endref
is used to refer to a book, while

  \paperref``[display label]''{label} ... \endref
is used to refer to a paper.

When an item, for example \xxx, is encountered then the following text is expanded as follows


  \xxx+text ==> punctation + 
                begin commands + 
		text + 
		end commands
where the punctation is displayed unless \xxx is the first displayed item. The default values for the items in the \bookref environment are the following

command punctation begin commands end commands
\by , \bfseries nothing
\bysame , $\vcenter{\vskip.5em\hbox{\verb*'\hbox to3em'}\vskip.2em
\hbox{\verb*'{\hrulefill\hskip.1em}'}\vskip.5em}$ nothing
\title , \scshape nothing
\bookinfo , \rmfamily nothing
\publ , \rmfamily nothing
\publaddr , \rmfamily nothing
\pages , \rmfamily nothing
\yr , \rmfamily nothing
\lang nothing ( )
\transl , \rmfamily nothing

The default values for the items in the \paperref environment are the following

command punctation begin commands end commands
\by , \bfseries nothing
\bysame , $\vcenter{\vskip.5em\hbox{\verb*'\hbox to3em'}\vskip.2em
\hbox{\verb*'{\hrulefill'}\vskip.2em
\hbox{\verb*' \hskip.1em}'}\vskip.5em}
$ nothing
\title , \itshape nothing
\transl , \rmfamily nothing
\jour , \rmfamily nothing
\toappear nothing (to appear )
\inbook , \rmfamily nothing
\publ , \rmfamily nothing
\eds nothing ( \@killglue, eds.)
\publaddr , \rmfamily nothing
\vol nothing \bfseries nothing
\yr nothing ( )
\pages , \rmfamily nothing
\finalinfo , \rmfamily nothing
\lang nothing ( )

The command \moreref

In the case of more than one reference of the same author or in the case of a series of papers or books on the same argument, it is sometimes useful to use the \moreref command. The syntax is the following

  \paperref{label name} or \bookref{label name}
  items
  \moreref`[punctation]'{book or paper}
  items
  \moreref`[punctation]'{book or paper}
  .
  .    
  \endref
The effect is to use a single label reference for more than one book or paper. The optional command ``[punctation]'' can be used to change the default punctation ``;'' to something else for example you can use \moreref[, see also:]{book}.

The command \endref

The command \endref ends the definition of a reference. By default the reference is ended with the punctation ;. It is possible to change the default value as follows

  \endref[punctation], for example \endref[.]
This is useful for the last reference, for example


\begin{thebibliography}{99}

\bookref{ORTEGA}
\by     J.~M.~Ortega, W.~C.~Rheinboldt
\title  Iterative Solution of Nonlinear
        Equation in Several Variables
\publ   Accademic Press
\yr     1970
\endref

\bookref{aaa}
\by     C.~V.~Pao
\title  Nonlinear Parabolic and Elliptic Equations
\publ   Plenum Press \publaddr NY
\yr     1992
\endref

\bookref{ZEIDLER}
\by     E.~Zeidler
\title  Nonlinear Functional Analysis
        and its Applications I
\publ   Springer Verlag \publaddr NY
\yr     1986
\endref[.]

\end{thebibliography}

\begin{center}\vbox{\input{docbib.2}
}\end{center}

The command \refstyle

There are many styles for display the labels of the bibliography. The standard LATEX way of changing the appearance is to modify the \@bibitem macro. A easiest way in EASYBIB is to use \refstyle before \begin{thebibliography}. The syntax is the following:

  \refstyle{A} or \refstyle{B}  or  \refstyle{C}
the effect is to change \@bibitem as follows

command \@bibitem definition sample output
\refstyle{A} \def\@bibitem#1{#1.} 1.
\refstyle{B} \def\@bibitem#1{[#1]} [1]
\refstyle{C} \def\@bibitem#1{} nothing

An example of bibliography from AMS-TEX documentation

The following complex example shows the features of easybib and is essentially the example showed in the AMS-TEX documentation translated in the language of easybib.


\begin{thebibliography}{99}

\bookref{abc}
\by    V. I. Arnol$'$d, A. N. Varchenko,
       and S. M. Guse\u\i n-Zade
\title Singularities of differentiable maps.~{\rm I}
\publ  ``Nauka'' \publaddr Moscow
\yr    1982
\lang  Russian
\endref

\bookref{def}
\bysame
\title Singularities of differentiable maps.~{\rm II}
\publ  ``Nauka'' \publaddr Moscow
\yr    1984
\lang  Russian
\endref

\bookref{ghi}
\by    O. A. Ladyzhenskaya
\title Mathematical problems in the dynamics of a
       viscous incompressible fluid
\bookinfo 2nd rev. aug. ed.
\publ  ``Nauka'' \publaddr Moscow
\yr    1970
\lang  Russian
\transl English transl. of 1st ed.
\moreref{book}
\title The mathematical theory of viscous
       incompressible flow
\publ  Gordon and Breach \publaddr New York
\yr    1963; rev. 1969
\endref


\bigskip

\paperref{bib:4}
\by     P. D. Lax and C. D. Levermore
\title  The small dispersion limit for
        the KdV equation.~{\rm I}
\jour   Comm. Pure Appl. Math.
\vol 36 \yr 1983 \pages 253--290
\finalinfo (overview)
\moreref[, see also:]{paper}
\title  {\rm II}
\jour   Comm. Pure Appl. Math.
\vol 36 \yr 1983 \pages 571--594
\moreref[, see also:]{paper}
\title  {\rm III}
\jour   Comm. Pure Appl. Math.
\vol 36 \yr 1983 \pages 809--829
\endref

\paperref{bib:5}
\by     S. Osher
\title  Shock capturing algorithms for
        equations of mixed type
\inbook Numerical Methods for Partial
        Differential Equations
\eds    S. I. Hariharan and T. H. Moulton
\publ Longman \publaddr New York
\yr 1986 \pages 305--322
\endref

\paperref{bib:6}
\by     G. S. Petrov
\title  Elliptic integrals and their
        nonoscillatory behavior
\jour   Funktsional. Anal. i Pri\-lo\-zhen.
\vol 20 \yr 1986 \pages 46--49
\moreref{paper}
\transl English transl. in Functional
        Anal. Appl. \vol 20\yr 1986
\endref[.]

\end{thebibliography}

\begin{center}\vbox{\input{docbib.3.tex}
}\end{center}


\refstyle{B}

\begin{thebibliography}{AAAA}

\bookref[C1]{C1}
\by     B. Coomes
\title  Polynomial flows, symmetry groups, and
        conditions sufficient for injectivity of maps
\bookinfo Ph.D. thesis, Univ. Nebraska--Lincoln
\yr 1988
\endref

\paperref[C2]{C2}
\bysame % B. Coomes
\title The Lorenz system does not have
       a polynomial flow
\jour  J. Differential Equations
\toappear
\endref

\paperref[GHMR]{GHMR}
\by    J. Guckenheimer, P. Holmes,
       M. Martineau, and L. P. Robinson
\title Nonlinear oscillations, dynamical systems, and
       bifurcations of vector fields
\publ Springer-Verlag \publaddr New York
\yr 1983
\endref[.]

\end{thebibliography}

\begin{center}\vbox{\input{docbib.4}
}\end{center}

Changing the appearance

You can change the default formats by the command

  \bibsetfmt[group name,item]{punctation}
                             {begin commands}
                             {end commands}
for example

  \bibsetfmt[paper,by]{,}{\textit}{:}
In this way you can change in an easy way the appearance of the bibliography.

Changing the order of the items

The order or the items:

  for `paper' group:
  by,bysame,title,transl,jour,toappear,
  inbook,publ,eds,publaddr,vol,
  yr,pages,finalinfo,lang
  
  for `book' group:
  by,bysame,title,bookinfo,publ,publaddr,
  pages,yr,lang,transl
can be changed defining the macro \paperlist and \booklist. For example in order to have the yr item displayed after pages item in the paper group define:

  \def\paperlist{by,bysame,title,transl,jour,%
                 toappear,inbook,publ,eds,%
		 publaddr,vol,pages,yr,%
		 finalinfo,lang}

Citing

The following code


\citestyle{A}
Cite mode A \cite{book:1,art:1,art:2}. \\
\citestyle{B}
Cite mode B \cite{book:1,art:1,art:2}. \\
\citestyle{C}
Cite mode C \cite{book:1,art:1,art:2}.

\begin{center}\vbox{\input{docbib.5}
}\end{center}

for the following bibliography

\begin{center}\vbox{\input{docbib.7.tex}
}\end{center}

Defining new styles

If you do not like the predefined styles paper and book you can easily define new ones. For example suppose you want to define a new style tales with the item \author, \title, \year with:

* \author
in smallcaps style surrounded by a box

* \title
in italic style

* \year
in bold style within (...)

you must follow the following steps

* define the list of items

  \def\taleslist{author,title,year}

* define the command ``talesref'' with the items

  \bibdefinestyles{tales}
it defines the items \author, \title, \year with the default format and the command \talesref.

* change the default formatting

  \bibsetfmt[tales,author]
    {,}
    {\setbox0\hbox\bgroup\scshape}
    {\egroup\fbox{\box0}}
  \bibsetfmt[tales,title]{}{\itshape}{}
  \bibsetfmt[tales,year]{}{\bfseries(}{)}

The following example (which uses [definethebibliography]) shows the effect:


\def\taleslist{author,title,year}
\bibdefinestyles{tales}
\bibsetfmt[tales,author]{,}
  {\setbox0\hbox\bgroup\scshape}
  {\egroup\fbox{\box0}}
\bibsetfmt[tales,title]{}{\itshape}{}
\bibsetfmt[tales,year]{}{\bfseries(}{)}

\begin{thebibliography}[Tales](\section*,1cm){99}
   \talesref{A}
      \author Isaac Asimov
      \title  Nemesis
      \year   1989
   \endref
   \talesref{B}
      \author Roger Zelazny
      \title  Nove principi in ambra
      \year   1970
   \endref
   \talesref{C}
      \author Dean R. Koontz
      \title  Strangers
      \year   1986
   \endref[.]
\end{thebibliography}

\begin{center}\vbox{\input{docbib.6}
}\end{center}

About this document ...

The package EASYBIB

This document was generated using the LaTeX2HTML translator Version 99.1 release (March 30, 1999)

Copyright © 1993, 1994, 1995, 1996, Nikos Drakos, Computer Based Learning Unit, University of Leeds.
Copyright © 1997, 1998, 1999, Ross Moore, Mathematics Department, Macquarie University, Sydney.

The command line arguments were:
latex2html -local_icons -no_navigation -split 0 docbib

The translation was initiated by Bertolazzi Enrico on 1999-10-22


Bertolazzi Enrico
1999-10-22