-
Notifications
You must be signed in to change notification settings - Fork 41
/
url.sty
313 lines (278 loc) · 12.5 KB
/
url.sty
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
% url.sty ver 3.4 16-Sep-2013 Donald Arseneau [email protected]
% Copyright 1996-2013 Donald Arseneau, Vancouver, Canada.
% This program can be used, distributed, and modified under the terms
% of the LaTeX Project Public License, version 2 or later.
%
% A form of \verb that allows linebreaks at certain characters or
% combinations of characters, accepts reconfiguration, and can usually
% be used in the argument to another command. It is intended for email
% addresses, hypertext links, directories/paths, etc., which normally
% have no spaces. The font may be selected using the \urlstyle command,
% and new url-like commands can be defined using \urldef.
%
% Usage: Conditions:
% \url{ } If the argument contains any "%" or "^^", or ends with
% "\", it can't be used in the argument to another command.
% The argument must not contain unbalanced braces.
% \url| | ...where "|" is any character not used in the argument and not
% "{" or a space. The same restrictions as above except that the
% argument may contain unbalanced braces.
% \urldef\xyz\url{ }
% \xyz a defined-url: "\xyz" can be used anywhere, no matter what
% characters it contains.
% \DeclareUrlCommand\abc{settings}: makes \abc{ } like \url{ } with settings
%
% See url.tex/url.pdf for documentation. Some info after \endinput
%
% Required catcodes during loading: letters @ = letter,
% ` = > < . [ ] + - digits = other,
% { } \ ~ # % $ _ ^ = their normal
% default style assignments
\def\UrlBreaks{\do\.\do\@\do\\\do\/\do\!\do\_\do\|\do\;\do\>\do\]%
\do\)\do\,\do\?\do\&\do\'\do+\do\=\do\#}%
\def\UrlBigBreaks{\do\:\do@url@hyp}%
\def\UrlNoBreaks{\do\(\do\[\do\{\do\<}%
% any ordinary characters that aren't usually:
\def\UrlOrds{\do\*\do\-\do\~\do\'\do\"\do\-}%
\def\UrlSpecials{\do\ {\Url@space}\do\%{\Url@percent}\do\^^M{\Url@space}%
\Url@force@Tilde}% package option may force faked text-ascii-tilde
\@namedef{Url@OT1encSpecials}{%
% *Some* latin-1 or windows characters that ot1 has elsewhere: OE oe ss
\do\^^8c{\mathchar30 }\do\^^9c{\mathchar27 }\do\^^df{\mathchar25 }%
\do\~{\lower.45ex\hbox{\m@th$\mathchar126$}}% For tt style
% lots more to add, but I should later link into inputenc
\do\^^b5{\mu}%
\Url@OTnonTT % more for any but typewriter
}
\def\Url@OTnonTT{\do\<{\langle}\do\>{\mathbin{\rangle}}\do
\_{\_\penalty\@m}\do\|{\mid}\do\{{\lbrace}\do\}{\mathbin{\rbrace}}\do
\\{\mathbin{\backslash}}\UrlTildeSpecial}
% *Some* latin-1 or windows characters. Most will pass through safely to T1 enc
% mu inverted-? OE oe
% lots more to add, but I should later link into inputenc
\@namedef{Url@T1encSpecials}{\do\^^b5{\mu}\do\^^bf{\mathchar190 }%
\do\^^8c{\mathchar215 }\do\^^9c{\mathchar247 }\do\^^df{\mathchar255 }%
\do\^^ff{\mathchar184 }}
\@namedef{Url@LY1encSpecials}{\do\~{\mathchar158 }}
\def\UrlTildeSpecial{\do\~{\raise.45ex\hbox{\m@th$\scriptstyle\sim$}}}
\let\Url@force@Tilde\relax
\def\url@ttstyle{%
\@ifundefined{selectfont}{\def\UrlFont{\tt}}{\def\UrlFont{\ttfamily}}}
\def\url@rmstyle{%
\@ifundefined{selectfont}{\def\UrlFont{\rm}}{\def\UrlFont{\rmfamily}}}
\def\url@sfstyle{%
\@ifundefined{selectfont}{\def\UrlFont{\sf}}{\def\UrlFont{\sffamily}}}
\def\url@samestyle{\def\UrlFont{}}
\@ifundefined{strip@prefix}{\def\strip@prefix#1>{}}{}
\@ifundefined{verbatim@nolig@list}{\def\verbatim@nolig@list{\do\`}}{}
% \Url sets up the reading the argument verbatim if possible
\def\Url{%
\Url@movingtest
\ifmmode\@inmatherr$\fi %$
\let\do\@makeother \dospecials % verbatim catcodes
\catcode`{\@ne \catcode`}\tw@ % with exceptions
\catcode`\ =10 % allow "\url {x}"
\catcode`\#=6 % always # -> ##, so I can later convert ## -> #
\@ifnextchar\bgroup{\obeyspaces\obeylines\Url@z}\Url@y}
% \Url@y read arguments delimited like |...|, passing to \Url@z
\def\Url@y#1{\catcode`{11 \catcode`}11\obeyspaces\obeylines
\def\@tempa##1#1{\Url@z{##1}}\@tempa}
% \Url@z read arguments delimited like {...}, verbatimizes with \meaning,
% performs character translations, then invokes the formatter.
\def\Url@z#1{\toks@{#1}\edef\Url@String{\the\toks@}%
\edef\Url@String{\expandafter\strip@prefix\meaning\Url@String}%
%\if\urldebug \message{------------------------------------------------------}%
%\message{ \Url@String}\fi
% \meaning introduces spurious spaces in the text, so it would be nice
% to preserve the real spaces before \meaning, but that doesn't work --
% we can only do replacement on streams of non-syntactic characters.
\Url@ObeySp % may be no-op; otherwise put ordinary (12) space characters
%\if\urldebug \message{ \Url@String}\fi
% we left the catcode of # with its normal value (6) so \meaning
% doubles it to ##. Now we convert back to single #. This allows
% \url{#} to appear in the arguments of other commands, where we can't
% make # be an ordinary character. We make the single # active rather
% than `other' to support hyperref.sty.
\Url@acthash
%\if\urldebug \message{ \Url@String}\fi
% Also make % active to support hyperref.
\Url@actpercent
% now do any hyper referencing due to hyperref (or perform a url-def)
\Url@HyperHook
% Now do the formatting in a group (can also have \Url@HyperHook take
% this as an argument.
{\Url@FormatString}%
\endgroup}
\let\Url@ObeySp\@empty
\let\UrlRight\@empty
\let\UrlLeft\@empty
\let\Url@HyperHook\@empty
% This is the normal way to format the strings, using math mode.
\def\Url@FormatString{%
\UrlFont \Url@MathSetup
$\fam\z@ \textfont\z@\font
\expandafter\UrlLeft\Url@String\UrlRight
\m@th$%
% \if\urldebug \showlists \fi
}%
\def\Url@MathSetup{%
\medmuskip\Urlmuskip \thickmuskip\medmuskip \thinmuskip0mu%
\relpenalty\UrlBigBreakPenalty \binoppenalty\UrlBreakPenalty
\expandafter\let\expandafter\UrlEncSpecials\csname Url@\f@encoding encSpecials\endcsname
% Insert test for unknown encodings here \ifx\UrlEncSpecials\relax
\ifdim\fontdimen\thr@@\font=\z@ \let\Url@OTnonTT\relax \fi
\@tempcnta\z@ % \fam\multiply\@tempcnta\@cclvi
\let\do\set@mathcode \UrlOrds % ordinary characters that were special
\advance\@tempcnta 8192 \UrlBreaks % bin
\advance\@tempcnta 4096 \UrlBigBreaks % rel
\advance\@tempcnta 4096 \UrlNoBreaks % open
\let\do\set@mathact \UrlSpecials \UrlEncSpecials % active
\let\do\set@mathnolig \verbatim@nolig@list % prevent ligatures
}
\def\set@mathcode#1{\count@`#1\advance\count@\@tempcnta
%\message{Set mathcode of \string #1 (\number`#1) = \number`#1 + \number\@tempcnta. }%
\mathcode`#1\count@}
\def\set@mathact#1#2{\mathcode`#1=32768 \begingroup
\lccode`\~`#1\lowercase{\endgroup\def~}{#2}}
\def\set@mathnolig#1{\ifnum\mathcode`#1<32768
\begingroup\lccode`\~`#1\lowercase{\endgroup
\edef~}{\mathchar\number\mathcode`#1\sb{\/}}%
\mathcode`#1=32768 \fi}
\def\Url@movingtest{\begingroup
\ifx\let\HyPsd@LetCommand % we are already in a pdf string!
\expandafter\Url@unmove \fi % give the argument and hope for the best
\let\Url@moving\relax\relax\relax
\ifx\Url@moving\relax\else \expandafter\Url@unmove \fi
\endgroup}
\long\def\Url@unmove#1\Url@y{\endgroup \ifx\protect\relax\else\protect\Url\fi}
\edef\Url@moving{\csname Url Error\endcsname}
\expandafter\edef\Url@moving
{\csname url used in a moving argument.\endcsname}
\expandafter\expandafter\expandafter \let \Url@moving\@undefined
\def\urldef#1#2{\begingroup \setbox\z@\hbox\bgroup
\def\Url@HyperHook##1\endgroup{\Url@def{#1}{#2}}%
% Because hyperref breaks \urldef and does not define its own (Grrrr!)...
\def\url@##1{\egroup\endgroup\DeclareRobustCommand#1{#2{##1}}}%
#2}
\def\Url@def#1#2{%
\toks0\expandafter{\Url@String}%
\protected@edef\Url@String{\Url@String}%
\toks1\expandafter{\Url@String}%
\edef\Url@String{\endgroup\egroup\endgroup\def
\expandafter\noexpand\csname\expandafter\@gobble\string#1 \endcsname
{\noexpand\Url@eitherdef{\the\toks1}{\noexpand#2{\the\toks0}}}}%
\Url@String
\edef#1{\noexpand\protect
\expandafter\noexpand\csname\expandafter\@gobble\string#1 \endcsname}%
}
\def\Url@eitherdef{\ifx\let\HyPsd@LetCommand % we are already in a pdf string!
\expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi}
\def\urlstyle#1{\expandafter\protect\csname url@#1style\endcsname}
\def\DeclareUrlCommand#1#2{\def#1{\leavevmode\begingroup #2\Url}}
% Sample (and default) configuration:
%
\DeclareUrlCommand\url{}
\urlstyle{tt}
%
\newmuskip\Urlmuskip \Urlmuskip=0mu
\mathchardef\UrlBreakPenalty=\binoppenalty
\mathchardef\UrlBigBreakPenalty=\relpenalty
%
% picTeX defines \path, so declare it optionally:
\@ifundefined{path}{\DeclareUrlCommand\path{\urlstyle{tt}}}{}
%
% too many styles define \email like \address, so I will not define it.
% \DeclareUrlCommand\email{\urlstyle{rm}}
% Process LaTeX \package options
%
\let\Url@sppen\@M
\def\Url@space{\penalty\Url@sppen}
\def\do@url@hyp{}% by default, no breaks after hyphens
\@ifundefined{ProvidesPackage}{
}{\ProvidesPackage
{url}[2013/09/16 \space ver 3.4 \space Verb mode for urls, etc.]
\DeclareOption{hyphens}{\def\do@url@hyp{\do\-}}% allow breaks after hyphens
\DeclareOption{obeyspaces}{\let\Url@ObeySp\relax}% a flag for later
\DeclareOption{spaces}{\def\Url@sppen{\UrlBreakPenalty}}
\DeclareOption{LY1}{}
\DeclareOption{T1}{}
\DeclareOption{allowmove}{\let\Url@moving\@empty}
\DeclareOption{lowtilde}{%
\def\UrlTildeSpecial{\do\~{\raise.2ex\hbox{\m@th$\scriptstyle\sim$}}}
\let\Url@force@Tilde\UrlTildeSpecial
}
\ProcessOptions\relax
\ifx\Url@ObeySp\relax % [obeyspaces] was declared
\begingroup \lccode`+=32 \lowercase
{\endgroup \def\Url@ObeySp{\Url@Edit\Url@String{ }{+}}}
\def\Url@space{\penalty\Url@sppen\ }
\fi
}
\ifx\f@encoding\undefined \def\f@encoding{OT1}\fi
\begingroup
% \Url@acthash: convert `other' (doubled) ## to active #
% \Url@actpercent: convert `other' % to active %
\lccode`+=`\# \lccode`\~=`\#
\lowercase {\long\gdef\Url@acthash{\Url@Edit\Url@String{++}{~}%
\ifnum\mathcode`\#<32768 \def~{\#}\fi}}%
\lccode`+=`\% \lccode`\~=`\%
\lowercase {\long\gdef\Url@actpercent{\Url@Edit\Url@String{+}{~}%
\ifnum\mathcode`\%<32768 \def~{\%}\fi}}%
\catcode13=12 %
\gdef\Url@percent{\@ifnextchar^^M{\@gobble}{\mathbin{\mathchar`\%}}}%
\endgroup%
% Edit macro #1 changing all appearances of pattern #2 to replacement #3.
% The replacement is recursive, so don't put the search pattern into the
% replacement text!
{ \catcode`Q=3
\gdef\Url@Edit#1#2#3{%
\begingroup % \tracingall
\def\DOE@a{\endgroup\def#1}% Just so I can \expandafter it safely.
\def\DOE@b##1#2##2Q##3{\@ifblank{##2}% if finished,
{\DOE@c ##1Q}% then remove \@empty's and redefine macro
{\DOE@b##1##3##2Q{##3}}% else, re-iterate
}% the leading \@empty preserves braces, as does the trailing pattern:
\expandafter\DOE@b\expandafter\@empty #1\@empty#2Q{#3}}
\gdef\DOE@c#1\@empty Q{\expandafter\DOE@a\expandafter{#1}}
%
% \@ifblank (LaTeX syntax) --- checks if parameter is blank (Spaces
% count as blank) use \@ifblank{#1}{true case}{false case} etc
\long\gdef\@ifblank#1{\@Ifbl@nk#1QQ\@secondoftwo\@firstoftwo!}%
\long\gdef\@Ifbl@nk#1#2Q#3#4#5!{#4}
} % restore Q catcode
%\ifx\urldebug\@undefined \def\urldebug{01}\fi
\endinput
% For documentation, please see accompanying url.tex (url.pdf)
% Package Options: obeyspaces, hyphens, spaces, lowtilde
%
% Revision History:
% ver 1.1 6-Feb-1996:
% Fix hyphens that wouldn't break and ligatures that weren't suppressed.
% ver 1.2 19-Oct-1996:
% Package option for T1 encoding; Hooks: "\UrlLeft" and "\UrlRight".
% ver 1.3 21-Jul-1997:
% Prohibit spaces as delimiter characters; change ascii tilde in OT1.
% ver 1.4 02-Mar-1999:
% LaTeX license; moving-argument-error
% ver 1.5 28-Mar-1999:
% possibility of spacing around break characters; re-settable penalties
% ver 1.6 20-Jun-2002:
% un-double #, fix obeyed-spaces, ignore trailing %, hook for hyperref
% (\Url@HyperHook), no macros in pre-processed url string (in \Url@String),
% limit catcode change of ~.
% ver 3.0 June 2003/Nov 2003:
% \DeclareUrlCommand; make font encoding automatic (only a few inputenc characters
% are supported yet - needs refactoring); reverse penalties.
% ver 3.1 Mar 2004:
% Remove spurious spaces in \url@XXstyle commands.
% ver 3.2 June 2005:
% Fix cmsy-symbols in tt bug (from 3.0); LY1 encoding bug; Enable plain
% with miniltx (again); Define the \urldef for hyperref; Lower "sim" tilde
% a little; fix \lowercase error in \UrlSpecials handling.
% ver 3.3 April 2006:
% Fix some encoding bugs and remove 8-bit characters. lowtilde option
% ver 3.4 Sept 2013:
% \@nomatherr->\@inmatherr. & is now another \UrlBreak character.
% The End
Test file integrity: ASCII 32-57, 58-126: !"#$%&'()*+,-./0123456789
:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~