annotate man/url.texi @ 75495:d241328c04c5

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