Update LuaTeX testfiles for ^@ change
[latex2e.git] / latex2e-20170101 / required / tools / somedefs.dtx
blob70c05c583823ad59d16e041abaeecbd0edf4f17e
1 % \iffalse meta-comment
3 % Copyright 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005
4 % 2006 2008 2009
5 % The LaTeX3 Project and any individual authors listed elsewhere
6 % in this file.
8 % This file is part of the Standard LaTeX `Tools Bundle'.
9 % -------------------------------------------------------
11 % It may be distributed and/or modified under the
12 % conditions of the LaTeX Project Public License, either version 1.3c
13 % of this license or (at your option) any later version.
14 % The latest version of this license is in
15 %    http://www.latex-project.org/lppl.txt
16 % and version 1.3c or later is part of all distributions of LaTeX
17 % version 2005/12/01 or later.
19 % The list of all files belonging to the LaTeX `Tools Bundle' is
20 % given in the file `manifest.txt'.
22 % \fi
23 % \title{The \textsf{somedefs} toolkit package}
24 % \date{long time ago in a different century\ldots}
25 % \author{Alan Jeffrey}
26 % \MaintainedByLaTeXTeam{tools}
27 % \maketitle
30 % \changes{v0.03}{1994/06/01}{Use new style error commands. DPC}
31 % \changes{v0.02}{1994/05/10}{Added a \cmd\relax, to stop arguments to
32 %    \cmd\newcommand\ being unbraced by \cmd\ProvidesCommand.  Added
33 %    an error message for commands which are requested but never
34 %    defined.  Spotted by DPC.}
36 % \section*{Overview}
38 % This is an example `programmers toolkit' package, for use by package
39 % writers.  It allows package writers to provide options which switch
40 % definitions on and off.  For example, a package |fred| might define a
41 % large number of commands, including |\foo| and |\baz|, so:
42 % \begin{verbatim}
43 %    \usepackage{fred}
44 % \end{verbatim}
45 % would use a lot of memory, even if |\foo| and |\baz| were the only
46 % commands needed.  However, if the author of |fred| used the |somedefs|
47 % package, then the user would be able to say:
48 % \begin{verbatim}
49 %    \usepackage[only,foo,baz]{fred}
50 % \end{verbatim}
51 % and only the commands |\foo| and |\baz| would be defined.
53 % To use the |somedefs| package in your own packages or classes, you
54 %  say:
55 % \begin{verbatim}
56 %    \RequirePackage{somedefs}
57 % \end{verbatim}
58 % You can then use four new commands:
59 % \begin{flushleft}\begin{itemize}
60 % \item |\UseAllDefinitions| which says that all the commands in the
61 %    file should be defined.
62 % \item |\UseSomeDefinitions| which says that only the commands
63 %    specified by |\UseDefinition| should be defined.
64 % \item |\UseDefinition{|\meta{name}|}| which says that the command
65 %    |\name| should be defined.
66 % \item |\ProvidesDefinition{|\meta{definition}|}| which provides one
67 %    definition, of the form |\definingcommand{\command}...|
68 % \end{itemize}\end{flushleft}
69 % For example, the package |fred| could say:
70 % \begin{verbatim}
71 %    \RequirePackage{somedefs}
72 %    \UseAllDefinitions
73 %    \DeclareOption{only}{\UseSomeDefinitions}
74 %    \DeclareOption*{\UseDefinition{\CurrentOption}}
75 %    \ProcessOptions
76 %    \ProvidesDefinition{\newcommand{\foo}{...}}
77 %    \ProvidesDefinition{\newcommand{\baz}{...}}
78 % \end{verbatim}
79 % One of the commands |\UseAllDefinitions| or |\UseSomeDefinitions|
80 % should always be used.  You may have some commands which need other
81 % commands, in which case you have to declare the options by hand.  For
82 % example, if the command |\bar| needs the command |\foo|, you could
83 % say:
84 % \begin{verbatim}
85 %    \DeclareOption{bar}{\UseDefinition{bar}\UseDefinition{foo}}
86 % \end{verbatim}
87 % For a longer example of the use of the |somedefs| package, look at the
88 % |rawfonts| package.
90 % \StopEventually{}
92 % \section*{Implementation}
94 % The driver for the documentation you're now reading.
95 %    \begin{macrocode}
96 %<*driver>
97 \documentclass{ltxdoc}
98 \begin{document}
99 \DocInput{somedefs.dtx}
100 \end{document}
101 %</driver>
102 %    \end{macrocode}
103 % This is a \LaTeXe{} package.
104 %    \begin{macrocode}
105 %<*package>
106 \NeedsTeXFormat{LaTeX2e}
107 \ProvidesPackage{somedefs}[1994/06/01 v0.03 Toolkit for optional definitions]
108 %    \end{macrocode}
109 % \begin{macro}{\UseSomeDefinitions}
110 % \begin{macro}{\UseAllDefinitions}
111 % \begin{macro}{\UseDefinition}
112 % \begin{macro}{\ProvidesDefinition}
113 % \begin{macro}{\@providesdefinition}
114 % \begin{macro}{\@provides@definition}
115 % \begin{macro}{\@unprovided@definition}
116 %    The package works by having |\UseDefinition{|\meta{name}|}| define
117 %    |\name| to be |\@unprovided@definition|.
118 %    If |\UseSomeDefinitions| has been called,
119 %    then |\ProvidesDefinition| looks to see if |\name|
120 %    is |\@unprovided@definition|.  If
121 %    |\UseAllDefinitions| has been called, then |\ProvidesDefinition|
122 %    does nothing.  If neither has been called, then
123 %    |\ProvidesDefinition| produces an error message.
124 %    \begin{macrocode}
125 \def\UseSomeDefinitions{%
126    \let\ProvidesDefinition\@providesdefinition
128 \def\UseAllDefinitions{%
129    \let\ProvidesDefinition\@firstofone
131 \def\UseDefinition#1{%
132    \expandafter\let\csname#1\endcsname\@unprovided@definition
134 \def\ProvidesDefinition#1{%
135    \PackageError{somedefs}%
136      {No \noexpand\UseSomeDefinitions or \string\UseAllDefinitions}%
137      {The package which used the `somedefs' package has an error.}%
139 \def\@providesdefinition#1{\@provides@definition#1\relax
140    \@provides@definition}
141 \def\@provides@definition#1#2#3\@provides@definition{%
142    \ifx#2\@unprovided@definition
143       #1#2#3%
144    \fi
146 \def\@unprovided@definition{%
147    \PackageError{somedefs}%
148      {Package `somedefs' error: this command was never defined}%
149      {You have requested a command which does not exist.}%
151 \@onlypreamble\UseSomeDefinitions
152 \@onlypreamble\UseAllDefinitions
153 \@onlypreamble\UseDefinition
154 \@onlypreamble\ProvidesDefinition
155 \@onlypreamble\@providesdefinition
156 \@onlypreamble\@provides@definition
157 %    \end{macrocode}
158 % \end{macro}
159 % \end{macro}
160 % \end{macro}
161 % \end{macro}
162 % \end{macro}
163 % \end{macro}
164 % \end{macro}
165 % That's it!
166 %    \begin{macrocode}
167 %</package>
168 %    \end{macrocode}
170 % \Finale
172 % \endinput