58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1 \input texinfo
|
58849
|
2 @setfilename ../info/url
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
3 @settitle URL Programmer's Manual
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
4
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
5 @iftex
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
6 @c @finalout
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
7 @end iftex
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
8 @c @setchapternewpage odd
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
9 @c @smallbook
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
10
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
11 @tex
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
12 \overfullrule=0pt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
13 %\global\baselineskip 30pt % for printing in double space
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
14 @end tex
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
15 @dircategory World Wide Web
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
16 @dircategory GNU Emacs Lisp
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
17 @direntry
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
18 * URL: (url). URL loading package.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
19 @end direntry
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
20
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
21 @ifnottex
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
22 This file documents the URL loading package.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
23
|
69681
|
24 Copyright @copyright{} 1996, 1997, 1998, 1999, 2002, 2004,
|
|
25 2005, 2006 Free Software Foundation, Inc.@*
|
|
26 Copyright @copyright{} 1993, 1994, 1995, 1996 William M. Perry
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
27
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
28 Permission is granted to copy, distribute and/or modify this document
|
65555
|
29 under the terms of the GNU Free Documentation License, Version 1.2 or
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
30 any later version published by the Free Software Foundation; with the
|
59002
|
31 Invariant Sections being
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
32 ``GNU GENERAL PUBLIC LICENSE''. A copy of the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
33 license is included in the section entitled ``GNU Free Documentation
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
34 License.''
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
35 @end ifnottex
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
36
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
37 @c
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
38 @titlepage
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
39 @sp 6
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
40 @center @titlefont{URL}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
41 @center @titlefont{Programmer's Manual}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
42 @sp 4
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
43 @center First Edition, URL Version 2.0
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
44 @sp 1
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
45 @c @center December 1999
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
46 @sp 5
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
47 @center William M. Perry
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
48 @center @email{wmperry@@gnu.org}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
49 @center David Love
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
50 @center @email{fx@@gnu.org}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
51 @page
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
52 @vskip 0pt plus 1filll
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
53 Copyright @copyright{} 1993, 1994, 1995, 1996 William M. Perry@*
|
64890
|
54 Copyright @copyright{} 1996, 1997, 1998, 1999, 2002, 2003, 2004,
|
69681
|
55 2005, 2006 Free Software Foundation, Inc.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
56
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
57 Permission is granted to copy, distribute and/or modify this document
|
65555
|
58 under the terms of the GNU Free Documentation License, Version 1.2 or
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
59 any later version published by the Free Software Foundation; with the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
60 Invariant Sections being
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
61 ``GNU GENERAL PUBLIC LICENSE''. A copy of the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
62 license is included in the section entitled ``GNU Free Documentation
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
63 License.''
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
64 @end titlepage
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
65 @page
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
66 @node Top
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
67 @top URL
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
68
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
69
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
70
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
71 @menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
72 * Getting Started:: Preparing your program to use URLs.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
73 * Retrieving URLs:: How to use this package to retrieve a URL.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
74 * Supported URL Types:: Descriptions of URL types currently supported.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
75 * Defining New URLs:: How to define a URL loader for a new protocol.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
76 * General Facilities:: URLs can be cached, accessed via a gateway
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
77 and tracked in a history list.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
78 * Customization:: Variables you can alter.
|
59002
|
79 * Function Index::
|
|
80 * Variable Index::
|
|
81 * Concept Index::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
82 @end menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
83
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
84 @node Getting Started
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
85 @chapter Getting Started
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
86 @cindex URLs, definition
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
87 @cindex URIs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
88
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
89 @dfn{Uniform Resource Locators} (URLs) are a specific form of
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
90 @dfn{Uniform Resource Identifiers} (URI) described in RFC 2396 which
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
91 updates RFC 1738 and RFC 1808. RFC 2016 defines uniform resource
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
92 agents.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
93
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
94 URIs have the form @var{scheme}:@var{scheme-specific-part}, where the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
95 @var{scheme}s supported by this library are described below.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
96 @xref{Supported URL Types}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
97
|
62429
|
98 FTP, NFS, HTTP, HTTPS, @code{rlogin}, @code{telnet}, tn3270,
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
99 IRC and gopher URLs all have the form
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
100
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
101 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
102 @var{scheme}://@r{[}@var{userinfo}@@@r{]}@var{hostname}@r{[}:@var{port}@r{]}@r{[}/@var{path}@r{]}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
103 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
104 @noindent
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
105 where @samp{@r{[}} and @samp{@r{]}} delimit optional parts.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
106 @var{userinfo} sometimes takes the form @var{username}:@var{password}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
107 but you should beware of the security risks of sending cleartext
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
108 passwords. @var{hostname} may be a domain name or a dotted decimal
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
109 address. If the @samp{:@var{port}} is omitted then the library will
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
110 use the `well known' port for that service when accessing URLs. With
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
111 the possible exception of @code{telnet}, it is rare for ports to be
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
112 specified, and it is possible using a non-standard port may have
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
113 undesired consequences if a different service is listening on that
|
60497
|
114 port (e.g., an HTTP URL specifying the SMTP port can cause mail to be
|
62429
|
115 sent). @c , but @xref{Other Variables, url-bad-port-list}.
|
|
116 The meaning of the @var{path} component depends on the service.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
117
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
118 @menu
|
59002
|
119 * Configuration::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
120 * Parsed URLs:: URLs are parsed into vector structures.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
121 @end menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
122
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
123 @node Configuration
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
124 @section Configuration
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
125
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
126 @defvar url-configuration-directory
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
127 @cindex @file{~/.url}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
128 @cindex configuration files
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
129 The directory in which URL configuration files, the cache etc.,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
130 reside. Default @file{~/.url}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
131 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
132
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
133 @node Parsed URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
134 @section Parsed URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
135 @cindex parsed URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
136 The library functions typically operate on @dfn{parsed} versions of
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
137 URLs. These are actually vectors of the form:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
138
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
139 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
140 [@var{type} @var{user} @var{password} @var{host} @var{port} @var{file} @var{target} @var{attributes} @var{full}]
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
141 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
142
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
143 @noindent where
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
144 @table @var
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
145 @item type
|
60497
|
146 is the type of the URL scheme, e.g., @code{http}
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
147 @item user
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
148 is the username associated with it, or @code{nil};
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
149 @item password
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
150 is the user password associated with it, or @code{nil};
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
151 @item host
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
152 is the host name associated with it, or @code{nil};
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
153 @item port
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
154 is the port number associated with it, or @code{nil};
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
155 @item file
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
156 is the `file' part of it, or @code{nil}. This doesn't necessarily
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
157 actually refer to a file;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
158 @item target
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
159 is the target part, or @code{nil};
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
160 @item attributes
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
161 is the attributes associated with it, or @code{nil};
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
162 @item full
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
163 is @code{t} for a fully-specified URL, with a host part indicated by
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
164 @samp{//} after the scheme part.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
165 @end table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
166
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
167 @findex url-type
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
168 @findex url-user
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
169 @findex url-password
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
170 @findex url-host
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
171 @findex url-port
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
172 @findex url-file
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
173 @findex url-target
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
174 @findex url-attributes
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
175 @findex url-full
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
176 @findex url-set-type
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
177 @findex url-set-user
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
178 @findex url-set-password
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
179 @findex url-set-host
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
180 @findex url-set-port
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
181 @findex url-set-file
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
182 @findex url-set-target
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
183 @findex url-set-attributes
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
184 @findex url-set-full
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
185 These attributes have accessors named @code{url-@var{part}}, where
|
60497
|
186 @var{part} is the name of one of the elements above, e.g.,
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
187 @code{url-host}. Similarly, there are setters of the form
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
188 @code{url-set-@var{part}}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
189
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
190 There are functions for parsing and unparsing between the string and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
191 vector forms.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
192
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
193 @defun url-generic-parse-url url
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
194 Return a parsed version of the string @var{url}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
195 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
196
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
197 @defun url-recreate-url url
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
198 @cindex unparsing URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
199 Recreates a URL string from the parsed @var{url}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
200 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
201
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
202 @node Retrieving URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
203 @chapter Retrieving URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
204
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
205 @defun url-retrieve-synchronously url
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
206 Retrieve @var{url} synchronously and return a buffer containing the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
207 data. @var{url} is either a string or a parsed URL structure. Return
|
59004
|
208 @code{nil} if there are no data associated with it (the case for dired,
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
209 info, or mailto URLs that need no further processing).
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
210 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
211
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
212 @defun url-retrieve url callback &optional cbargs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
213 Retrieve @var{url} asynchronously and call @var{callback} with args
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
214 @var{cbargs} when finished. The callback is called when the object
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
215 has been completely retrieved, with the current buffer containing the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
216 object and any MIME headers associated with it. @var{url} is either a
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
217 string or a parsed URL structure. Returns the buffer @var{url} will
|
59004
|
218 load into, or @code{nil} if the process has already completed.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
219 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
220
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
221 @node Supported URL Types
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
222 @chapter Supported URL Types
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
223
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
224 @menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
225 * http/https:: Hypertext Transfer Protocol.
|
59002
|
226 * file/ftp:: Local files and FTP archives.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
227 * info:: Emacs `Info' pages.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
228 * mailto:: Sending email.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
229 * news/nntp/snews:: Usenet news.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
230 * rlogin/telnet/tn3270:: Remote host connectivity.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
231 * irc:: Internet Relay Chat.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
232 * data:: Embedded data URLs.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
233 * nfs:: Networked File System
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
234 @c * finger::
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
235 @c * gopher::
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
236 @c * netrek::
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
237 @c * prospero::
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
238 * cid:: Content-ID.
|
59002
|
239 * about::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
240 * ldap:: Lightweight Directory Access Protocol
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
241 * imap:: IMAP mailboxes.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
242 * man:: Unix man pages.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
243 @end menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
244
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
245 @node http/https
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
246 @section @code{http} and @code{https}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
247
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
248 The scheme @code{http} is Hypertext Transfer Protocol. The library
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
249 supports version 1.1, specified in RFC 2616. (This supersedes 1.0,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
250 defined in RFC 1945) HTTP URLs have the following form, where most of
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
251 the parts are optional:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
252 @example
|
74026
|
253 http://@var{user}:@var{password}@@@var{host}:@var{port}/@var{path}?@var{searchpart}#@var{fragment}
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
254 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
255 @c The @code{:@var{port}} part is optional, and @var{port} defaults to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
256 @c 80. The @code{/@var{path}} part, if present, is a slash-separated
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
257 @c series elements. The @code{?@var{searchpart}}, if present, is the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
258 @c query for a search or the content of a form submission. The
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
259 @c @code{#fragment} part, if present, is a location in the document.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
260
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
261 The scheme @code{https} is a secure version of @code{http}, with
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
262 transmission via SSL. It is defined in RFC 2069. Its default port is
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
263 443. This scheme depends on SSL support in Emacs via the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
264 @file{ssl.el} library and is actually implemented by forcing the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
265 @code{ssl} gateway method to be used. @xref{Gateways in general}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
266
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
267 @defopt url-honor-refresh-requests
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
268 This controls honouring of HTTP @samp{Refresh} headers by which
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
269 servers can direct clients to reload documents from the same URL or a
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
270 or different one. @code{nil} means they will not be honoured,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
271 @code{t} (the default) means they will always be honoured, and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
272 otherwise the user will be asked on each request.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
273 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
274
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
275
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
276 @menu
|
59002
|
277 * Cookies::
|
|
278 * HTTP language/coding::
|
|
279 * HTTP URL Options::
|
|
280 * Dealing with HTTP documents::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
281 @end menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
282
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
283 @node Cookies
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
284 @subsection Cookies
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
285
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
286 @defopt url-cookie-file
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
287 The file in which cookies are stored, defaulting to @file{cookies} in
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
288 the directory specified by @code{url-configuration-directory}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
289 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
290
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
291 @defopt url-cookie-confirmation
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
292 Specifies whether confirmation is require to accept cookies.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
293 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
294
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
295 @defopt url-cookie-multiple-line
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
296 Specifies whether to put all cookies for the server on one line in the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
297 HTTP request to satisfy broken servers like
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
298 @url{http://www.hotmail.com}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
299 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
300
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
301 @defopt url-cookie-trusted-urls
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
302 A list of regular expressions matching URLs from which to accept
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
303 cookies always.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
304 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
305
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
306 @defopt url-cookie-untrusted-urls
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
307 A list of regular expressions matching URLs from which to reject
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
308 cookies always.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
309 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
310
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
311 @defopt url-cookie-save-interval
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
312 The number of seconds between automatic saves of cookies to disk.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
313 Default is one hour.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
314 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
315
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
316
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
317 @node HTTP language/coding
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
318 @subsection Language and Encoding Preferences
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
319
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
320 HTTP allows clients to express preferences for the language and
|
60497
|
321 encoding of documents which servers may honour. For each of these
|
|
322 variables, the value is a string; it can specify a single choice, or
|
60861
|
323 it can be a comma-separated list.
|
|
324
|
|
325 Normally this list ordered by descending preference. However, each
|
|
326 element can be followed by @samp{;q=@var{priority}} to specify its
|
|
327 preference level, a decimal number from 0 to 1; e.g., for
|
|
328 @code{url-mime-language-string}, @w{@code{"de, en-gb;q=0.8,
|
|
329 en;q=0.7"}}. An element that has no @samp{;q} specification has
|
|
330 preference level 1.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
331
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
332 @defopt url-mime-charset-string
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
333 @cindex character sets
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
334 @cindex coding systems
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
335 This variable specifies a preference for character sets when documents
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
336 can be served in more than one encoding.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
337
|
60497
|
338 HTTP allows specifying a series of MIME charsets which indicate your
|
|
339 preferred character set encodings, e.g., Latin-9 or Big5, and these
|
|
340 can be weighted. The default series is generated automatically from
|
|
341 the associated MIME types of all defined coding systems, sorted by the
|
|
342 coding system priority specified in Emacs. @xref{Recognize Coding, ,
|
|
343 Recognizing Coding Systems, emacs, The GNU Emacs Manual}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
344 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
345
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
346 @defopt url-mime-language-string
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
347 @cindex language preferences
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
348 A string specifying the preferred language when servers can serve
|
60497
|
349 files in several languages. Use RFC 1766 abbreviations, e.g.,
|
|
350 @samp{en} for English, @samp{de} for German.
|
|
351
|
|
352 The string can be @code{"*"} to get the first available language (as
|
|
353 opposed to the default).
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
354 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
355
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
356 @node HTTP URL Options
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
357 @subsection HTTP URL Options
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
358
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
359 HTTP supports an @samp{OPTIONS} method describing things supported by
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
360 the URL@.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
361
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
362 @defun url-http-options url
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
363 Returns a property list describing options available for URL. The
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
364 property list members are:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
365
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
366 @table @code
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
367 @item methods
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
368 A list of symbols specifying what HTTP methods the resource
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
369 supports.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
370
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
371 @item dav
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
372 @cindex DAV
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
373 A list of numbers specifying what DAV protocol/schema versions are
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
374 supported.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
375
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
376 @item dasl
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
377 @cindex DASL
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
378 A list of supported DASL search types supported (string form).
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
379
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
380 @item ranges
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
381 A list of the units available for use in partial document fetches.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
382
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
383 @item p3p
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
384 @cindex P3P
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
385 The @dfn{Platform For Privacy Protection} description for the resource.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
386 Currently this is just the raw header contents.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
387 @end table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
388
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
389 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
390
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
391 @node Dealing with HTTP documents
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
392 @subsection Dealing with HTTP documents
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
393
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
394 HTTP URLs are retrieved into a buffer containing the HTTP headers
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
395 followed by the body. Since the headers are quasi-MIME, they may be
|
59005
5c053e769038
(HTTP language/coding, mailto): Replace "GNU Emacs manual" with
Luc Teirlinck <teirllm@auburn.edu>
diff
changeset
|
396 processed using the MIME library. @xref{Top,, Emacs MIME,
|
5c053e769038
(HTTP language/coding, mailto): Replace "GNU Emacs manual" with
Luc Teirlinck <teirllm@auburn.edu>
diff
changeset
|
397 emacs-mime, The Emacs MIME Manual}. The URL package provides a
|
5c053e769038
(HTTP language/coding, mailto): Replace "GNU Emacs manual" with
Luc Teirlinck <teirllm@auburn.edu>
diff
changeset
|
398 function to do this in general:
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
399
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
400 @defun url-decode-text-part handle &optional coding
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
401 This function decodes charset-encoded text in the current buffer. In
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
402 Emacs, the buffer is expected to be unibyte initially and is set to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
403 multibyte after decoding.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
404 HANDLE is the MIME handle of the original part. CODING is an explicit
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
405 coding to use, overriding what the MIME headers specify.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
406 The coding system used for the decoding is returned.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
407
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
408 Note that this function doesn't deal with @samp{http-equiv} charset
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
409 specifications in HTML @samp{<meta>} elements.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
410 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
411
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
412 @node file/ftp
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
413 @section file and ftp
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
414 @cindex files
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
415 @cindex FTP
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
416 @cindex File Transfer Protocol
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
417 @cindex compressed files
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
418 @findex dired
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
419
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
420 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
421 ftp://@var{user}:@var{password}@@@var{host}:@var{port}/@var{file}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
422 file://@var{user}:@var{password}@@@var{host}:@var{port}/@var{file}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
423 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
424
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
425 These schemes are defined in RFC 1808.
|
59003
|
426 @samp{ftp:} and @samp{file:} are synonymous in this library. They
|
|
427 allow reading arbitrary files from hosts. Either @samp{ange-ftp}
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
428 (Emacs) or @samp{efs} (XEmacs) is used to retrieve them from remote
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
429 hosts. Local files are accessed directly.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
430
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
431 Compressed files are handled, but support is hard-coded so that
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
432 @code{jka-compr-compression-info-list} and so on have no affect.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
433 Suffixes recognized are @samp{.z}, @samp{.gz}, @samp{.Z} and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
434 @samp{.bz2}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
435
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
436 @defopt url-directory-index-file
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
437 The filename to look for when indexing a directory, default
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
438 @samp{"index.html"}. If this file exists, and is readable, then it
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
439 will be viewed instead of using @code{dired} to view the directory.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
440 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
441
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
442 @node info
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
443 @section info
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
444 @cindex Info
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
445 @cindex Texinfo
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
446 @findex Info-goto-node
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
447
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
448 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
449 info:@var{file}#@var{node}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
450 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
451
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
452 Info URLs are not officially defined. They invoke
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
453 @code{Info-goto-node} with argument @samp{(@var{file})@var{node}}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
454 @samp{#@var{node}} is optional, defaulting to @samp{Top}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
455
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
456 @node mailto
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
457 @section mailto
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
458
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
459 @cindex mailto
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
460 @cindex email
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
461 A mailto URL will send an email message to the address in the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
462 URL, for example @samp{mailto:foo@@bar.com} would compose a
|
59002
|
463 message to @samp{foo@@bar.com}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
464
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
465 @defopt url-mail-command
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
466 @vindex mail-user-agent
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
467 The function called whenever url needs to send mail. This should
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
468 normally be left to default from @var{mail-user-agent}. @xref{Mail
|
59005
5c053e769038
(HTTP language/coding, mailto): Replace "GNU Emacs manual" with
Luc Teirlinck <teirllm@auburn.edu>
diff
changeset
|
469 Methods, , Mail-Composition Methods, emacs, The GNU Emacs Manual}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
470 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
471
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
472 An @samp{X-Url-From} header field containing the URL of the document
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
473 that contained the mailto URL is added if that URL is known.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
474
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
475 RFC 2368 extends the definition of mailto URLs in RFC 1738.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
476 The form of a mailto URL is
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
477 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
478 @samp{mailto:@var{mailbox}[?@var{header}=@var{contents}[&@var{header}=@var{contents}]]}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
479 @end example
|
59003
|
480 @noindent where an arbitrary number of @var{header}s can be added. If the
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
481 @var{header} is @samp{body}, then @var{contents} is put in the body
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
482 otherwise a @var{header} header field is created with @var{contents}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
483 as its contents. Note that the URL library does not consider any
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
484 headers `dangerous' so you should check them before sending the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
485 message.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
486
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
487 @c Fixme: update
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
488 Email messages are defined in @sc{rfc}822.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
489
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
490 @node news/nntp/snews
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
491 @section @code{news}, @code{nntp} and @code{snews}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
492 @cindex news
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
493 @cindex network news
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
494 @cindex usenet
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
495 @cindex NNTP
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
496 @cindex snews
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
497
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
498 @c draft-gilman-news-url-01
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
499 The network news URL scheme take the following forms following RFC
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
500 1738 except that for compatibility with other clients, host and port
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
501 fields may be included in news URLs though they are properly only
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
502 allowed for nntp an snews.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
503
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
504 @table @samp
|
59002
|
505 @item news:@var{newsgroup}
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
506 Retrieves a list of messages in @var{newsgroup};
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
507 @item news:@var{message-id}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
508 Retrieves the message with the given @var{message-id};
|
59002
|
509 @item news:*
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
510 Retrieves a list of all available newsgroups;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
511 @item nntp://@var{host}:@var{port}/@var{newsgroup}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
512 @itemx nntp://@var{host}:@var{port}/@var{message-id}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
513 @itemx nntp://@var{host}:@var{port}/*
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
514 Similar to the @samp{news} versions.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
515 @end table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
516
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
517 @samp{:@var{port}} is optional and defaults to :119.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
518
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
519 @samp{snews} is the same as @samp{nntp} except that the default port
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
520 is :563.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
521 @cindex SSL
|
59003
|
522 (It is tunneled through SSL.)
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
523
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
524 An @samp{nntp} URL is the same as a news URL, except that the URL may
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
525 specify an article by its number.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
526
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
527 @defopt url-news-server
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
528 This variable can be used to override the default news server.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
529 Usually this will be set by the Gnus package, which is used to fetch
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
530 news.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
531 @cindex environment variable
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
532 @vindex NNTPSERVER
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
533 It may be set from the conventional environment variable
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
534 @code{NNTPSERVER}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
535 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
536
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
537 @node rlogin/telnet/tn3270
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
538 @section rlogin, telnet and tn3270
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
539 @cindex rlogin
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
540 @cindex telnet
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
541 @cindex tn3270
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
542 @cindex terminal emulation
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
543 @findex terminal-emulator
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
544
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
545 These URL schemes from RFC 1738 for logon via a terminal emulator have
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
546 the form
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
547 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
548 telnet://@var{user}:@var{password}@@@var{host}:@var{port}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
549 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
550 but the @code{:@var{password}} component is ignored.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
551
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
552 To handle rlogin, telnet and tn3270 URLs, a @code{rlogin},
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
553 @code{telnet} or @code{tn3270} (the program names and arguments are
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
554 hardcoded) session is run in a @code{terminal-emulator} buffer.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
555 Well-known ports are used if the URL does not specify a port.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
556
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
557 @node irc
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
558 @section irc
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
559 @cindex IRC
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
560 @cindex Internet Relay Chat
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
561 @cindex ZEN IRC
|
71226
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
562 @cindex ERC
|
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
563 @cindex rcirc
|
59002
|
564 @c Fixme: reference (was http://www.w3.org/Addressing/draft-mirashi-url-irc-01.txt)
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
565 @dfn{Internet Relay Chat} (IRC) is handled by handing off the @sc{irc}
|
59002
|
566 session to a function named in @code{url-irc-function}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
567
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
568 @defopt url-irc-function
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
569 A function to actually open an IRC connection.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
570 This function
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
571 must take five arguments, @var{host}, @var{port}, @var{channel},
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
572 @var{user} and @var{password}. The @var{channel} argument specifies the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
573 channel to join immediately, this can be @code{nil}. By default this is
|
71226
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
574 @code{url-irc-rcirc}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
575 @end defopt
|
71226
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
576 @defun url-irc-rcirc host port channel user password
|
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
577 Processes the arguments and lets @code{rcirc} handle the session.
|
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
578 @end defun
|
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
579 @defun url-irc-erc host port channel user password
|
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
580 Processes the arguments and lets @code{ERC} handle the session.
|
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
581 @end defun
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
582 @defun url-irc-zenirc host port channel user password
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
583 Processes the arguments and lets @code{zenirc} handle the session.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
584 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
585
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
586 @node data
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
587 @section data
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
588 @cindex data URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
589
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
590 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
591 data:@r{[}@var{media-type}@r{]}@r{[};@var{base64}@r{]},@var{data}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
592 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
593
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
594 Data URLs contain MIME data in the URL itself. They are defined in
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
595 RFC 2397.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
596
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
597 @var{media-type} is a MIME @samp{Content-Type} string, possibly
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
598 including parameters. It defaults to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
599 @samp{text/plain;charset=US-ASCII}. The @samp{text/plain} can be
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
600 omitted but the charset parameter supplied. If @samp{;base64} is
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
601 present, the @var{data} are base64-encoded.
|
59002
|
602
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
603 @node nfs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
604 @section nfs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
605 @cindex NFS
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
606 @cindex Network File System
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
607 @cindex automounter
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
608
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
609 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
610 nfs://@var{user}:@var{password}@@@var{host}:@var{port}/@var{file}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
611 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
612
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
613 The @samp{nfs:} scheme is defined in RFC 2224. It is similar to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
614 @samp{ftp:} except that it points to a file on a remote host that is
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
615 handled by the automounter on the local host.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
616
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
617 @defvar url-nfs-automounter-directory-spec
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
618 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
619 A string saying how to invoke the NFS automounter. Certain @samp{%}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
620 sequences are recognized:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
621
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
622 @table @samp
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
623 @item %h
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
624 The hostname of the NFS server;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
625 @item %n
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
626 The port number of the NFS server;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
627 @item %u
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
628 The username to use to authenticate;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
629 @item %p
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
630 The password to use to authenticate;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
631 @item %f
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
632 The filename on the remote server;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
633 @item %%
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
634 A literal @samp{%}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
635 @end table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
636
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
637 Each can be used any number of times.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
638
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
639 @node cid
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
640 @section cid
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
641 @cindex Content-ID
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
642
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
643 RFC 2111
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
644
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
645 @node about
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
646 @section about
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
647
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
648 @node ldap
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
649 @section ldap
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
650 @cindex LDAP
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
651 @cindex Lightweight Directory Access Protocol
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
652
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
653 The LDAP scheme is defined in RFC 2255.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
654
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
655 @node imap
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
656 @section imap
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
657 @cindex IMAP
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
658
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
659 RFC 2192
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
660
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
661 @node man
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
662 @section man
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
663 @cindex @command{man}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
664 @cindex Unix man pages
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
665 @findex man
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
666
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
667 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
668 @samp{man:@var{page-spec}}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
669 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
670
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
671 This is a non-standard scheme. @var{page-spec} is passed directly to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
672 the Lisp @code{man} function.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
673
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
674 @node Defining New URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
675 @chapter Defining New URLs
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
676
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
677 @menu
|
59002
|
678 * Naming conventions::
|
|
679 * Required functions::
|
|
680 * Optional functions::
|
|
681 * Asynchronous fetching::
|
|
682 * Supporting file-name-handlers::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
683 @end menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
684
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
685 @node Naming conventions
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
686 @section Naming conventions
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
687
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
688 @node Required functions
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
689 @section Required functions
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
690
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
691 @node Optional functions
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
692 @section Optional functions
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
693
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
694 @node Asynchronous fetching
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
695 @section Asynchronous fetching
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
696
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
697 @node Supporting file-name-handlers
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
698 @section Supporting file-name-handlers
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
699
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
700 @node General Facilities
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
701 @chapter General Facilities
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
702
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
703 @menu
|
59002
|
704 * Disk Caching::
|
|
705 * Proxies::
|
|
706 * Gateways in general::
|
|
707 * History::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
708 @end menu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
709
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
710 @node Disk Caching
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
711 @section Disk Caching
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
712 @cindex Caching
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
713 @cindex Persistent Cache
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
714 @cindex Disk Cache
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
715
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
716 The disk cache stores retrieved documents locally, whence they can be
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
717 retrieved more quickly. When requesting a URL that is in the cache,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
718 the library checks to see if the page has changed since it was last
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
719 retrieved from the remote machine. If not, the local copy is used,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
720 saving the transmission over the network.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
721 @cindex Cleaning the cache
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
722 @cindex Clearing the cache
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
723 @cindex Cache cleaning
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
724 Currently the cache isn't cleared automatically.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
725 @c Running the @code{clean-cache} shell script
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
726 @c fist is recommended, to allow for future cleaning of the cache. This
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
727 @c shell script will remove all files that have not been accessed since it
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
728 @c was last run. To keep the cache pared down, it is recommended that this
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
729 @c script be run from @i{at} or @i{cron} (see the manual pages for
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
730 @c crontab(5) or at(1) for more information)
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
731
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
732 @defopt url-automatic-caching
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
733 Setting this variable non-@code{nil} causes documents to be cached
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
734 automatically.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
735 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
736
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
737 @defopt url-cache-directory
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
738 This variable specifies the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
739 directory to store the cache files. It defaults to sub-directory
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
740 @file{cache} of @code{url-configuration-directory}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
741 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
742
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
743 @c Fixme: function v. option, but neither used.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
744 @c @findex url-cache-expired
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
745 @c @defopt url-cache-expired
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
746 @c This is a function to decide whether or not a cache entry has expired.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
747 @c It takes two times as it parameters and returns non-@code{nil} if the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
748 @c second time is ``too old'' when compared with the first time.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
749 @c @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
750
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
751 @defopt url-cache-creation-function
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
752 The cache relies on a scheme for mapping URLs to files in the cache.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
753 This variable names a function which sets the type of cache to use.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
754 It takes a URL as argument and returns the absolute file name of the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
755 corresponding cache file. The two supplied possibilities are
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
756 @code{url-cache-create-filename-using-md5} and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
757 @code{url-cache-create-filename-human-readable}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
758 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
759
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
760 @defun url-cache-create-filename-using-md5 url
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
761 Creates a cache file name from @var{url} using MD5 hashing.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
762 @findex md5
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
763 This is creates entries with very few cache collisions and is fast if
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
764 you have the @code{md5} function as a primitive (Emacs 21 and XEmacs).
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
765 @smallexample
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
766 (url-cache-create-filename-using-md5 "http://www.example.com/foo/bar")
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
767 @result{} "/home/fx/.url/cache/fx/http/com/example/www/b8a35774ad20db71c7c3409a5410e74f"
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
768 @end smallexample
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
769 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
770
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
771 @defun url-cache-create-filename-human-readable url
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
772 Creates a cache file name from @var{url} more obviously connected to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
773 @var{url} than for @code{url-cache-create-filename-using-md5}, but
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
774 more likely to conflict with other files.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
775 @smallexample
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
776 (url-cache-create-filename-human-readable "http://www.example.com/foo/bar")
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
777 @result{} "/home/fx/.url/cache/fx/http/com/example/www/foo/bar"
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
778 @end smallexample
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
779 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
780
|
59002
|
781 @c Fixme: never actually used currently?
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
782 @c @defopt url-standalone-mode
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
783 @c @cindex Relying on cache
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
784 @c @cindex Cache only mode
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
785 @c @cindex Standalone mode
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
786 @c If this variable is non-@code{nil}, the library relies solely on the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
787 @c cache for fetching documents and avoids checking if they have changed
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
788 @c on remote servers.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
789 @c @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
790
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
791 @c With a large cache of documents on the local disk, it can be very handy
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
792 @c when traveling, or any other time the network connection is not active
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
793 @c (a laptop with a dial-on-demand PPP connection, etc). Emacs/W3 can rely
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
794 @c solely on its cache, and avoid checking to see if the page has changed
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
795 @c on the remote server. In the case of a dial-on-demand PPP connection,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
796 @c this will keep the phone line free as long as possible, only bringing up
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
797 @c the PPP connection when asking for a page that is not located in the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
798 @c cache. This is very useful for demonstrations as well.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
799
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
800 @node Proxies
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
801 @section Proxies and Gatewaying
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
802
|
59002
|
803 @c fixme: check/document url-ns stuff
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
804 @cindex proxy servers
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
805 @cindex proxies
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
806 @cindex environment variables
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
807 @vindex HTTP_PROXY
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
808 Proxy servers are commonly used to provide gateways through firewalls
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
809 or as caches serving some more-or-less local network. Each protocol
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
810 (HTTP, FTP, etc.)@: can have a different gateway server. Proxying is
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
811 conventionally configured commonly amongst different programs through
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
812 environment variables of the form @code{@var{protocol}_proxy}, where
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
813 @var{protocol} is one of the supported network protocols (@code{http},
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
814 @code{ftp} etc.). The library recognizes such variables in either
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
815 upper or lower case. Their values are of one of the forms:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
816 @itemize @bullet
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
817 @item @code{@var{host}:@var{port}}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
818 @item A full URL;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
819 @item Simply a host name.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
820 @end itemize
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
821
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
822 @vindex NO_PROXY
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
823 The @code{NO_PROXY} environment variable specifies URLs that should be
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
824 excluded from proxying (on servers that should be contacted directly).
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
825 This should be a comma-separated list of hostnames, domain names, or a
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
826 mixture of both. Asterisks can be used as wildcards, but other
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
827 clients may not support that. Domain names may be indicated by a
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
828 leading dot. For example:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
829 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
830 NO_PROXY="*.aventail.com,home.com,.seanet.com"
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
831 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
832 @noindent says to contact all machines in the @samp{aventail.com} and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
833 @samp{seanet.com} domains directly, as well as the machine named
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
834 @samp{home.com}. If @code{NO_PROXY} isn't defined, @code{no_PROXY}
|
59002
|
835 and @code{no_proxy} are also tried, in that order.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
836
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
837 Proxies may also be specified directly in Lisp.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
838
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
839 @defopt url-proxy-services
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
840 This variable is an alist of URL schemes and proxy servers that
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
841 gateway them. The items are of the form @w{@code{(@var{scheme}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
842 . @var{host}:@var{portnumber})}}, says that the URL @var{scheme} is
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
843 gatewayed through @var{portnumber} on the specified @var{host}. An
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
844 exception is the pseudo scheme @code{"no_proxy"}, which is paired with
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
845 a regexp matching host names not to be proxied. This variable is
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
846 initialized from the environment as above.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
847
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
848 @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
849 (setq url-proxy-services
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
850 '(("http" . "proxy.aventail.com:80")
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
851 ("no_proxy" . "^.*\\(aventail\\|seanet\\)\\.com")))
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
852 @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
853 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
854
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
855 @node Gateways in general
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
856 @section Gateways in General
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
857 @cindex gateways
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
858 @cindex firewalls
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
859
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
860 The library provides a general gateway layer through which all
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
861 networking passes. It can both control access to the network and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
862 provide access through gateways in firewalls. This may make direct
|
63636
|
863 connections in some cases and pass through some sort of gateway in
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
864 others.@footnote{Proxies (which only operate over HTTP) are
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
865 implemented using this.} The library's basic function responsible for
|
63636
|
866 making connections is @code{url-open-stream}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
867
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
868 @defun url-open-stream name buffer host service
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
869 @cindex opening a stream
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
870 @cindex stream, opening
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
871 Open a stream to @var{host}, possibly via a gateway. The other
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
872 arguments are as for @code{open-network-stream}. This will not make a
|
63636
|
873 connection if @code{url-gateway-unplugged} is non-@code{nil}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
874 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
875
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
876 @defvar url-gateway-local-host-regexp
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
877 This is a regular expression that matches local hosts that do not
|
63636
|
878 require the use of a gateway. If @code{nil}, all connections are made
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
879 through the gateway.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
880 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
881
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
882 @defvar url-gateway-method
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
883 This variable controls which gateway method is used. It may be useful
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
884 to bind it temporarily in some applications. It has values taken from
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
885 a list of symbols. Possible values are:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
886
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
887 @table @code
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
888 @item telnet
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
889 @cindex @command{telnet}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
890 Use this method if you must first telnet and log into a gateway host,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
891 and then run telnet from that host to connect to outside machines.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
892
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
893 @item rlogin
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
894 @cindex @command{rlogin}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
895 This method is identical to @code{telnet}, but uses @command{rlogin}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
896 to log into the remote machine without having to send the username and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
897 password over the wire every time.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
898
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
899 @item socks
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
900 @cindex @sc{socks}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
901 Use if the firewall has a @sc{socks} gateway running on it. The
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
902 @sc{socks} v5 protocol is defined in RFC 1928.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
903
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
904 @c @item ssl
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
905 @c This probably shouldn't be documented
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
906 @c Fixme: why not? -- fx
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
907
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
908 @item native
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
909 This method uses Emacs's builtin networking directly. This is the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
910 default. It can be used only if there is no firewall blocking access.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
911 @end table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
912 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
913
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
914 The following variables control the gateway methods.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
915
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
916 @defopt url-gateway-telnet-host
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
917 The gateway host to telnet to. Once logged in there, you then telnet
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
918 out to the hosts you want to connect to.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
919 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
920 @defopt url-gateway-telnet-parameters
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
921 This should be a list of parameters to pass to the @command{telnet} program.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
922 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
923 @defopt url-gateway-telnet-password-prompt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
924 This is a regular expression that matches the password prompt when
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
925 logging in.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
926 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
927 @defopt url-gateway-telnet-login-prompt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
928 This is a regular expression that matches the username prompt when
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
929 logging in.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
930 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
931 @defopt url-gateway-telnet-user-name
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
932 The username to log in with.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
933 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
934 @defopt url-gateway-telnet-password
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
935 The password to send when logging in.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
936 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
937 @defopt url-gateway-prompt-pattern
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
938 This is a regular expression that matches the shell prompt.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
939 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
940
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
941 @defopt url-gateway-rlogin-host
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
942 Host to @samp{rlogin} to before telnetting out.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
943 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
944 @defopt url-gateway-rlogin-parameters
|
71226
a6a1e9e44f8b
(irc): Mention new funs `url-irc-rcirc' and `url-irc-erc'.
Romain Francoise <romain@orebokech.com>
diff
changeset
|
945 Parameters to pass to @samp{rsh}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
946 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
947 @defopt url-gateway-rlogin-user-name
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
948 User name to use when logging in to the gateway.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
949 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
950 @defopt url-gateway-prompt-pattern
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
951 This is a regular expression that matches the shell prompt.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
952 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
953
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
954 @defopt socks-server
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
955 This specifies the default server, it takes the form
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
956 @w{@code{("Default server" @var{server} @var{port} @var{version})}}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
957 where @var{version} can be either 4 or 5.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
958 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
959 @defvar socks-password
|
59003
|
960 If this is @code{nil} then you will be asked for the password,
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
961 otherwise it will be used as the password for authenticating you to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
962 the @sc{socks} server.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
963 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
964 @defvar socks-username
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
965 This is the username to use when authenticating yourself to the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
966 @sc{socks} server. By default this is your login name.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
967 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
968 @defvar socks-timeout
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
969 This controls how long, in seconds, to wait for responses from the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
970 @sc{socks} server; it is 5 by default.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
971 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
972 @c fixme: these have been effectively commented-out in the code
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
973 @c @defopt socks-server-aliases
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
974 @c This a list of server aliases. It is a list of aliases of the form
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
975 @c @var{(alias hostname port version)}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
976 @c @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
977 @c @defopt socks-network-aliases
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
978 @c This a list of network aliases. Each entry in the list takes the form
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
979 @c @var{(alias (network))} where @var{alias} is a string that names the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
980 @c @var{network}. The networks can contain a pair (not a dotted pair) of
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
981 @c @sc{ip} addresses which specify a range of @sc{ip} addresses, an @sc{ip}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
982 @c address and a netmask, a domain name or a unique hostname or @sc{ip}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
983 @c address.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
984 @c @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
985 @c @defopt socks-redirection-rules
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
986 @c This a list of redirection rules. Each rule take the form
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
987 @c @var{(Destination network Connection type)} where @var{Destination
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
988 @c network} is a network alias from @code{socks-network-aliases} and
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
989 @c @var{Connection type} can be @code{nil} in which case a direct
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
990 @c connection is used, or it can be an alias from
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
991 @c @code{socks-server-aliases} in which case that server is used as a
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
992 @c proxy.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
993 @c @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
994 @defopt socks-nslookup-program
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
995 @cindex @command{nslookup}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
996 This the @samp{nslookup} program. It is @code{"nslookup"} by default.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
997 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
998
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
999 @menu
|
63636
|
1000 * Suppressing network connections::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1001 @end menu
|
59002
|
1002 @c * Broken hostname resolution::
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1003
|
63636
|
1004 @node Suppressing network connections
|
|
1005 @subsection Suppressing Network Connections
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1006
|
63636
|
1007 @cindex network connections, suppressing
|
|
1008 @cindex suppressing network connections
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1009 @cindex bugs, HTML
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1010 @cindex HTML `bugs'
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1011 In some circumstances it is desirable to suppress making network
|
63636
|
1012 connections. A typical case is when rendering HTML in a mail user
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1013 agent, when external URLs should not be activated, particularly to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1014 avoid `bugs' which `call home' by fetch single-pixel images and the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1015 like. To arrange this, bind the following variable for the duration
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1016 of such processing.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1017
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1018 @defvar url-gateway-unplugged
|
63636
|
1019 If this variable is non-@code{nil} new network connections are never
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1020 opened by the URL library.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1021 @end defvar
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1022
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1023 @c @node Broken hostname resolution
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1024 @c @subsection Broken Hostname Resolution
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1025
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1026 @c @cindex hostname resolver
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1027 @c @cindex resolver, hostname
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1028 @c Some C libraries do not include the hostname resolver routines in
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1029 @c their static libraries. If Emacs was linked statically, and was not
|
59003
|
1030 @c linked with the resolver libraries, it will not be able to get to any
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1031 @c machines off the local network. This is characterized by being able
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1032 @c to reach someplace with a raw ip number, but not its hostname
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1033 @c (@url{http://129.79.254.191/} works, but
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1034 @c @url{http://www.cs.indiana.edu/} doesn't). This used to happen on
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1035 @c SunOS4 and Ultrix, but is now probably now rare. If Emacs can't be
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1036 @c rebuilt linked against the resolver library, it can use the external
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1037 @c @command{nslookup} program instead.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1038
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1039 @c @defopt url-gateway-broken-resolution
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1040 @c @cindex @code{nslookup} program
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1041 @c @cindex program, @code{nslookup}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1042 @c If non-@code{nil}, this variable says to use the program specified by
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1043 @c @code{url-gateway-nslookup-program} program to do hostname resolution.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1044 @c @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1045
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1046 @c @defopt url-gateway-nslookup-program
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1047 @c The name of the program to do hostname lookup if Emacs can't do it
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1048 @c directly. This program should expect a single argument on the command
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1049 @c line---the hostname to resolve---and should produce output similar to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1050 @c the standard Unix @command{nslookup} program:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1051 @c @example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1052 @c Name: www.cs.indiana.edu
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1053 @c Address: 129.79.254.191
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1054 @c @end example
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1055 @c @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1056
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1057 @node History
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1058 @section History
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1059
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1060 The library can maintain a global history list tracking URLs accessed.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1061 URL completion can be done from it. The history mechanism is set up
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1062 @findex url-do-setup
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1063 automatically via @code{url-do-setup} when it is configured to be on.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1064 Note that the size of the history list is currently not limited.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1065
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1066 @vindex url-history-hash-table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1067 The history `list' is actually a hash table,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1068 @code{url-history-hash-table}. It contains access times keyed by URL
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1069 strings. The times are in the format returned by @code{current-time}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1070
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1071 @defun url-history-update-url url time
|
59003
|
1072 This function updates the history table with an entry for @var{url}
|
|
1073 accessed at the given @var{time}.
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1074 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1075
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1076 @defopt url-history-track
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1077 If non-@code{nil}, the library will keep track of all the URLs
|
64465
|
1078 accessed. If it is @code{t}, the list is saved to disk at the end of
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1079 each Emacs session. The default is @code{nil}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1080 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1081
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1082 @defopt url-history-file
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1083 The file storing the history list between sessions. It defaults to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1084 @file{history} in @code{url-configuration-directory}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1085 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1086
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1087 @defopt url-history-save-interval
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1088 @findex url-history-setup-save-timer
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1089 The number of seconds between automatic saves of the history list.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1090 Default is one hour. Note that if you change this variable directly,
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1091 rather than using Custom, after @code{url-do-setup} has been run, you
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1092 need to run the function @code{url-history-setup-save-timer}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1093 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1094
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1095 @defun url-history-parse-history &optional fname
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1096 Parses the history file @var{fname} (default @code{url-history-file})
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1097 and sets up the history list.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1098 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1099
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1100 @defun url-history-save-history &optional fname
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1101 Saves the current history to file @var{fname} (default
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1102 @code{url-history-file}).
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1103 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1104
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1105 @defun url-completion-function string predicate function
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1106 You can use this function to do completion of URLs from the history.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1107 @end defun
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1108
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1109 @node Customization
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1110 @chapter Customization
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1111
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1112 @section Environment Variables
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1113
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1114 @cindex environment variables
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1115 The following environment variables affect the library's operation at
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1116 startup.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1117
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1118 @table @code
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1119 @item TMPDIR
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1120 @vindex TMPDIR
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1121 @vindex url-temporary-directory
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1122 If this is defined, @var{url-temporary-directory} is initialized from
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1123 it.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1124 @end table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1125
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1126 @section General User Options
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1127
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1128 The following user options, settable with Customize, affect the
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1129 general operation of the package.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1130
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1131 @defopt url-debug
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1132 @cindex debugging
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1133 Specifies the types of debug messages the library which are logged to
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1134 the @code{*URL-DEBUG*} buffer.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1135 @code{t} means log all messages.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1136 A number means log all messages and show them with @code{message}.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1137 If may also be a list of the types of messages to be logged.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1138 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1139 @defopt url-personal-mail-address
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1140 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1141 @defopt url-privacy-level
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1142 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1143 @defopt url-uncompressor-alist
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1144 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1145 @defopt url-passwd-entry-func
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1146 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1147 @defopt url-standalone-mode
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1148 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1149 @defopt url-bad-port-list
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1150 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1151 @defopt url-max-password-attempts
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1152 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1153 @defopt url-temporary-directory
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1154 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1155 @defopt url-show-status
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1156 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1157 @defopt url-confirmation-func
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1158 The function to use for asking yes or no functions. This is normally
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1159 either @code{y-or-n-p} or @code{yes-or-no-p}, but could be another
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1160 function taking a single argument (the prompt) and returning @code{t}
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1161 only if an affirmative answer is given.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1162 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1163 @defopt url-gateway-method
|
59002
|
1164 @c fixme: describe gatewaying
|
63636
|
1165 A symbol specifying the type of gateway support to use for connections
|
58830
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1166 from the local machine. The supported methods are:
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1167
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1168 @table @code
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1169 @item telnet
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1170 Run telnet in a subprocess to connect;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1171 @item rlogin
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1172 Rlogin to another machine to connect;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1173 @item socks
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1174 Connect through a socks server;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1175 @item ssl
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1176 Connect with SSL;
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1177 @item native
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1178 Connect directly.
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1179 @end table
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1180 @end defopt
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1181
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1182 @node Function Index
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1183 @unnumbered Command and Function Index
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1184 @printindex fn
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1185
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1186 @node Variable Index
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1187 @unnumbered Variable Index
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1188 @printindex vr
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1189
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1190 @node Concept Index
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1191 @unnumbered Concept Index
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1192 @printindex cp
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1193
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1194 @setchapternewpage odd
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1195 @contents
|
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
diff
changeset
|
1196 @bye
|
58833
|
1197
|
|
1198 @ignore
|
|
1199 arch-tag: c96be356-7e2d-4196-bcda-b13246c5c3f0
|
|
1200 @end ignore
|