]> mj.ucw.cz Git - ucwmac.git/blob - ucwmac.tex
\verbatim finished
[ucwmac.git] / ucwmac.tex
1 % The UCW Macro Collection (a successor of mjmac.tex)
2 % Written by Martin Mares <mj@ucw.cz> in 2010 and placed into public domain
3 % -------------------------------------------------------------------------
4
5 %%% Prolog %%%
6
7 % We'll use internal macros of plain TeX
8 \catcode`@=11
9
10 %%% PDF output detection %%%
11
12 \newif\ifpdf
13 \pdffalse
14
15 \ifx\pdfoutput\undefined
16 \else\ifnum\pdfoutput>0
17         \pdftrue
18 \fi\fi
19
20 %%% Page size and margins %%%
21
22 % If you modify these registers, call \setuppage afterwards
23 \newdimen\pagewidth
24 \newdimen\pageheight
25 \newdimen\leftmargin
26 \newdimen\rightmargin
27 \newdimen\topmargin
28 \newdimen\bottommargin
29 \newdimen\evenpageshift
30
31 \def\setuppage{%
32         \hsize=\pagewidth
33         \advance\hsize by -\leftmargin
34         \advance\hsize by -\rightmargin
35         \vsize=\pageheight
36         \advance\vsize by -\topmargin
37         \advance\vsize by -\bottommargin
38         \hoffset=\leftmargin
39         \advance\hoffset by -1truein
40         \voffset=\topmargin
41         \advance\voffset by -1truein
42         \ifpdf
43                 \pdfpagewidth=\pagewidth
44                 \pdfpageheight=\pageheight
45         \fi
46 }
47
48 % Set multiple margins to the same value
49 \def\sethmargins#1{\leftmargin=#1\relax\rightmargin=#1\relax\evenpageshift=0pt\relax}
50 \def\setvmargins#1{\topmargin=#1\relax\bottommargin=#1\relax}
51 \def\setmargins#1{\sethmargins{#1}\setvmargins{#1}}
52
53 % Define inner/outer margin instead of left/right
54 \def\setinneroutermargin#1#2{\sethmargins{#1}{#2}\evenpageshift=\rightmargin\advance\evenpageshift by -\leftmargin}
55
56 % Use a predefined paper format, calls \setuppage automagically
57 \def\setpaper#1{%
58         \expandafter\let\expandafter\currentpaper\csname paper-#1\endcsname
59         \ifx\currentpaper\relax
60                 \errmessage{Undefined paper format #1}
61         \fi
62         \currentpaper
63 }
64
65 % Switch to landscape orientation, calls \setuppage automagically
66 \def\landscape{%
67         \dimen0=\pageheight
68         \pageheight=\pagewidth
69         \pagewidth=\dimen0
70         \setuppage
71 }
72
73 % Common paper sizes
74 \def\defpaper#1#2#3{\expandafter\def\csname paper-#1\endcsname{\pagewidth=#2\pageheight=#3\setuppage}}
75 \defpaper{a3}{297truemm}{420truemm}
76 \defpaper{a4}{210truemm}{297truemm}
77 \defpaper{a5}{148truemm}{210truemm}
78 \defpaper{a6}{105truemm}{148truemm}
79 \defpaper{letter}{8.5truein}{11truein}
80 \defpaper{legal}{8.5truein}{14truein}
81
82 % Default page parameters
83 \setmargins{1truein}
84 \setpaper{a4}
85
86 %%% Placing material at specified coordinates %%%
87
88 % Set all dimensions of a given box register to zero
89 \def\smashbox#1{\ht#1=0pt \dp#1=0pt \wd#1=0pt}
90 \def\smashedhbox#1{{\setbox0=\hbox{#1}\smashbox0\box0}}
91 \def\smashedvbox#1{{\setbox0=\vbox{#1}\smashbox0\box0}}
92
93 % Variants of \llap and \rlap working equally on both sides and/or vertically
94 \def\hlap#1{\hbox to 0pt{\hss #1\hss}}
95 \def\vlap#1{\vbox to 0pt{\vss #1\vss}}
96 \def\clap#1{\vlap{\hlap{#1}}}
97
98 % \placeat{right}{down}{hmaterial} places <hmaterial>, so that its
99 % reference point lies at the given position wrt. the current ref point
100 \long\def\placeat#1#2#3{\smashedhbox{\hskip #1\lower #2\hbox{#3}}}
101
102 % Like \vbox, but with reference point in the upper left corner
103 \def\vhang#1{\vtop{\hrule height 0pt\relax #1}}
104
105 % Like \vhang, but respecting interline skips
106 \def\vhanglines#1{\vtop{\hbox to 0pt{}#1}}
107
108 % Crosshair with reference point in its center
109 \def\crosshair#1{\clap{\vrule height 0.2pt width #1}\clap{\vrule height #1 width 0.2pt}}
110
111 %%% Output routine %%%
112
113 \newbox\pageunderlays
114 \newbox\pageoverlays
115 \newbox\commonunderlays
116 \newbox\commonoverlays
117
118 % In addition to the normal page contents, you can define page overlays
119 % and underlays, which are zero-size vboxes positioned absolutely in the
120 % front / in the back of the normal material. Also, there are global
121 % versions of both which are not reset after every page.
122 \def\addlay#1#2{\setbox#1=\vbox{\ifvbox#1\box#1\fi\smashedvbox{#2}}}
123 \def\pageunderlay{\addlay\pageunderlays}
124 \def\pageoverlay{\addlay\pageoverlays}
125 \def\commonunderlay{\addlay\commonoverlays}
126 \def\commonoverlay{\addlay\commonoverlays}
127
128 % Our variation on \plainoutput, which manages inner/outer margins and overlays
129 \output{\ucwoutput}
130 \def\ucwoutput{\wigglepage\shipout\vbox{%
131         \makeheadline
132         \ifvbox\commonunderlays\copy\commonunderlays\nointerlineskip\fi
133         \ifvbox\pageunderlays\box\pageunderlays\nointerlineskip\fi
134         \pagebody
135         \ifvbox\commonoverlays\vbox to 0pt{\vskip -\vsize\copy\commonoverlays}\fi
136         \ifvbox\pageoverlays\vbox to 0pt{\vskip -\vsize\box\pageoverlays}\fi
137         \makefootline
138 }\advancepageno
139 \ifnum\outputpenalty>-\@MM \else\dosupereject\fi}
140
141 \def\wigglepage{\ifodd\pageno\else\advance\hoffset by \evenpageshift\fi}
142
143 %%% Itemization %%%
144
145 % Default dimensions of itemized lists
146 \newdimen\itemindent            \itemindent=0.5in
147 \newdimen\itemnarrow            \itemnarrow=0.5in                       % make lines narrower by this amount
148 \newskip\itemmarkerskip         \itemmarkerskip=0.4em                   % between marker and the item
149 \newskip\preitemizeskip         \preitemizeskip=3pt plus 2pt minus 1pt  % before the list
150 \newskip\postitemizeskip        \postitemizeskip=3pt plus 2pt minus 1pt % after the list
151 \newskip\interitemskip          \interitemskip=2pt plus 1pt minus 0.5pt % between two items
152
153 % Analogues for nested lists
154 \newdimen\nesteditemindent      \nesteditemindent=0.25in
155 \newdimen\nesteditemnarrow      \nesteditemnarrow=0.25in
156 \newskip\prenesteditemizeskip   \prenesteditemizeskip=0pt
157 \newskip\postnesteditemizeskip  \postnesteditemizeskip=0pt
158
159 \newif\ifitems\itemsfalse
160 \newbox\itembox
161 \newcount\itemcount
162
163 \def\preitemize{
164         \ifitems
165                 \vskip\prenesteditemizeskip
166                 \advance\leftskip by \nesteditemindent
167                 \advance\rightskip by \nesteditemnarrow
168         \else
169                 \vskip\preitemizeskip
170                 \advance\leftskip by \itemindent
171                 \advance\rightskip by \itemnarrow
172         \fi
173         \parskip=\interitemskip
174 }
175
176 \def\postitemize{
177         \ifitems
178                 \vskip\postnesteditemizeskip
179         \else
180                 \vskip\postitemizeskip
181         \fi
182 }
183
184 \def\inititemize{\begingroup\preitemize\itemstrue\parindent=0pt}
185
186 \def\itemize#1{\inititemize\setbox\itembox\llap{#1\hskip\itemmarkerskip}%
187 \let\:=\singleitem}
188
189 \def\singleitem{\par\leavevmode\copy\itembox\ignorespaces}
190
191 \def\endlist{\par\endgroup\postitemize}
192
193 \def\ibull{\raise0.2ex\hbox{$\bullet$}} % Signs frequently used for \itemize
194 \def\idot{\raise0.2ex\hbox{$\cdot$}}
195 \def\istar{\raise0.2ex\hbox{$\ast$}}
196
197 \def\numlist#1{\inititemize\itemcount=0\let\:=\numbereditem
198 \let\itemnumbering=#1}
199
200 \def\numbereditem{\par\leavevmode\advance\itemcount by 1
201 \llap{\itemnumbering\hskip\itemmarkerskip}\ignorespaces}
202
203 \def\nnorm{\the\itemcount}
204 \def\ndotted{\nnorm.}
205 \def\nparen{\nnorm)}
206 \def\nroman{\romannumeral\itemcount}
207 \def\nromanp{\nroman)}
208 \def\nalpha{\count@=96\advance\count@ by\itemcount\char\count@)}
209 \def\nAlpha{\count@=64\advance\count@ by\itemcount\char\count@)}
210 \def\ngreek{$\ifcase\itemcount\or\alpha\or\beta\or\gamma\or\delta\or\epsilon\or
211 \zeta\or\eta\or\theta\or\iota\or\kappa\or\lambda\or\mu\or\nu\or\xi\or\pi\or\rho
212 \or\sigma\or\tau\or\upsilon\or\phi\or\chi\or\psi\or\omega\fi$)}
213
214 %%% Verbatim typesetting %%%
215
216 % New \frenchspacing, which doesn't leave unwanted spaces in text.
217 \def\frenchsp@cing{\sfcode`\.\@m \sfcode`\?\@m \sfcode`\!\@m%
218 \sfcode`\:\@m \sfcode`\;\@m \sfcode`\,\@m}
219
220 % Typesetting of one verbatim word: |word|
221
222 % Set if spaces should be rendered as "bath-tub" glyphs
223 \newif\ifshowspaces
224 \showspacesfalse
225
226 \def\make@ther#1{\catcode`#1=12\relax}
227 \def\setverb@tim{\tt\frenchsp@cing\catcode`\`=13\catcode`\'=13\n@ligs%
228 \let\do=\make@ther\dospecials\obeyspaces\showsp@ces}
229
230 {\catcode`'=13
231 \catcode``=13
232 \gdef\n@ligs{\def`{\relax\lq}\def'{\relax\rq}}}
233
234 {\obeyspaces
235 \global\chardef\sp@ce=32
236 \gdef\showsp@ces{\ifshowspaces\let =\sp@ce\fi}
237 \global\let =\ }
238
239 \catcode124=\active % Make | active
240 \def\ttst@rt{\begingroup\setverb@tim\let|=\endgroup}
241 \let|=\ttst@rt
242
243 % Typesetting of verbatim blocks:
244 %       - the block is enclosed in balanced {}'s
245 %       - leading and trailing empty lines are ignored
246 %       - all other empty lines are converted to \verbemptylineskip's
247 %       - tabs are interpreted (one tab stop per \verbtabsize columns)
248 %       - \showspacestrue works here, too, but it does not apply to tabs
249
250 \newskip\verbstartskip          % vskip before \verbatim
251 \newskip\verbendskip            % vskip after \verbatim
252 \newskip\verbinterlineskip      % between adjacent non-empty lines
253 \newskip\verbemptylineskip      % instead of every empty line
254 \newskip\verbleftskip           % left and right margin
255 \newskip\verbrightskip
256
257 \verbstartskip=3pt plus 1pt minus 0.3pt
258 \verbendskip=\verbstartskip
259 \verbinterlineskip=0pt
260 \verbemptylineskip=5pt plus 2pt
261 \verbleftskip=0in
262 \verbrightskip=0pt plus 1fil
263
264 % Can be re-defined to customize the verbatim environment
265 \def\verblocaldefs{}
266
267 % Size of a single tab
268 \newcount\verbtabsize
269 \verbtabsize=8
270
271 \newdimen\v@rbspace
272 \newdimen\t@b
273 \newdimen\t@bwidth
274
275 % When a complete line is assembled in \box0, \verbship is called to add it
276 % to the main vertical list. You can override it to get e.g. line numbering.
277 \def\verbship{%
278         \ifdim\wd0>0pt
279                 \ifdim\v@rbspace>0pt
280                         \penalty-100
281                         \vskip\v@rbspace
282                 \else
283                         \ifdim\v@rbspace=0pt
284                                 \vskip\verbinterlineskip
285                         \fi
286                 \fi
287                 \line{\hskip\verbleftskip \box0 \hskip\verbrightskip}
288                 \v@rbspace=0pt
289         \else
290                 \advance\v@rbspace by \verbemptylineskip
291         \fi
292 }
293
294 \newcount\verbcnt
295 \def\v@rbend{\par\egroup\endgroup\vskip\verbendskip}
296 \def\v@rbl{\ifnum\verbcnt>0\{\fi\global\advance\verbcnt by 1\relax}
297 \def\v@rbr{\ifnum\verbcnt>1\}\else\v@rbend\fi\global\advance\verbcnt by -1\relax}
298
299 \def\v@rbparams{%
300         \setverb@tim
301         \raggedbottom
302         \verbcnt=0
303         \v@rbspace=-1000pt
304         \catcode124=12
305         \vskip\verbstartskip
306         \let\par=\endb@x
307         \obeylines
308 }
309
310 \def\startb@x{\setbox0=\hbox\bgroup}
311 \def\endb@x{\egroup\verbship\startb@x}
312
313 {\catcode`\^^I=\active
314 \gdef\setupt@bs{\catcode`\^^I=\active
315 \setbox0=\hbox{\ }\t@bwidth=\wd0\multiply\t@bwidth by \verbtabsize
316 \def^^I{\egroup\t@b=\wd0\divide\t@b by \t@bwidth%
317 \multiply\t@b by \t@bwidth%
318 \advance\t@b by \t@bwidth\advance\t@b by -\wd0\startb@x\box0\hbox to \t@b{}}%
319 }}
320
321 {
322 \catcode`[=1\catcode`]=2\catcode123=\active\catcode125=\active
323 \gdef\verbatim[\begingroup\v@rbparams\catcode123=\active\catcode125=\active%
324 \let{=\v@rbl\let}=\v@rbr\chardef\{=123\chardef\}=125\verblocaldefs\setupt@bs\startb@x%
325 ]]
326
327 % Input file verbatim
328
329 \def\verbinput#1{\begingroup\v@rbparams\verblocaldefs\setupt@bs\startb@x\input #1 \egroup\endgroup}
330
331 %%% Epilog %%%
332
333 % Let's hide all internal macros
334 \catcode`@=12