diff options
Diffstat (limited to 'doc')
-rw-r--r-- | doc/callback.html | 158 | ||||
-rw-r--r-- | doc/dns.html | 19 | ||||
-rw-r--r-- | doc/http.html | 2 | ||||
-rw-r--r-- | doc/index.html | 18 | ||||
-rw-r--r-- | doc/reference.html | 8 | ||||
-rw-r--r-- | doc/tcp.html | 148 | ||||
-rw-r--r-- | doc/url.html | 44 |
7 files changed, 319 insertions, 78 deletions
diff --git a/doc/callback.html b/doc/callback.html index 94af8ff..98b4476 100644 --- a/doc/callback.html +++ b/doc/callback.html | |||
@@ -31,16 +31,16 @@ | |||
31 | <hr> | 31 | <hr> |
32 | </div> | 32 | </div> |
33 | 33 | ||
34 | <!-- stream ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 34 | <!-- stream ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
35 | 35 | ||
36 | <h2 id=stream>Streaming with Callbacks</h2> | 36 | <h2 id=stream>Callbacks</h2> |
37 | 37 | ||
38 | <p> | 38 | <p> |
39 | HTTP, FTP, and SMTP transfers sometimes involve large amounts of | 39 | HTTP, FTP, and SMTP transfers sometimes involve large amounts of |
40 | information. Sometimes an application needs to generate outgoing data | 40 | information. Sometimes an application needs to generate outgoing data |
41 | in real time, or needs to process incoming information as it is being | 41 | in real time, or needs to process incoming information as it is being |
42 | received. To address these problems, LuaSocket allows HTTP and SMTP message | 42 | received. To address these problems, LuaSocket allows HTTP and SMTP message |
43 | bodies and FTP file contents to be received or sent through the | 43 | bodies and FTP file contents to be streamed through the |
44 | callback mechanism outlined below. | 44 | callback mechanism outlined below. |
45 | </p> | 45 | </p> |
46 | 46 | ||
@@ -52,7 +52,7 @@ chunks of data, as the data becomes available. Conversely, the <em>send | |||
52 | callback</em> mechanism can be used when the application wants to incrementally provide LuaSocket with the data to be sent. | 52 | callback</em> mechanism can be used when the application wants to incrementally provide LuaSocket with the data to be sent. |
53 | </p> | 53 | </p> |
54 | 54 | ||
55 | <!-- tohostname +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 55 | <!-- receive +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
56 | 56 | ||
57 | <p class=name id=receive> | 57 | <p class=name id=receive> |
58 | <b>receive_cb(</b>chunk, err<b>)</b> | 58 | <b>receive_cb(</b>chunk, err<b>)</b> |
@@ -60,7 +60,7 @@ callback</em> mechanism can be used when the application wants to incrementally | |||
60 | 60 | ||
61 | <p class=description> | 61 | <p class=description> |
62 | A receive callback will be repeatedly called by | 62 | A receive callback will be repeatedly called by |
63 | LuaSocket wheneve new data is available. Each time it is called, the | 63 | LuaSocket whenever new data is available. Each time it is called, the |
64 | callback receives successive chunks of downloaded data. | 64 | callback receives successive chunks of downloaded data. |
65 | </p> | 65 | </p> |
66 | 66 | ||
@@ -113,10 +113,129 @@ Together, these two modules provide a powerful interface to send and | |||
113 | receive information. | 113 | receive information. |
114 | </p> | 114 | </p> |
115 | 115 | ||
116 | <!-- done +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
117 | |||
118 | <p class=name id=done> | ||
119 | socket.callback.<b>done()</b> | ||
120 | </p> | ||
121 | |||
122 | <p class=description> | ||
123 | This function creates and returns a callback that successfully terminates | ||
124 | the transmission. | ||
125 | </p> | ||
126 | |||
127 | <!-- fail +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
128 | |||
129 | <p class=name id=fail> | ||
130 | socket.callback.<b>fail(</b>message<b>)</b> | ||
131 | </p> | ||
132 | |||
133 | <p class=description> | ||
134 | This function creates and returns a callback that aborts the | ||
135 | transmission with a given error <tt>message</tt>. | ||
136 | </p> | ||
137 | |||
138 | <!-- receive.concat +++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
139 | |||
140 | <p class=name id=receive.concat> | ||
141 | socket.callback.<b>receive.concat(</b>cat<b>)</b> | ||
142 | </p> | ||
143 | |||
144 | <p class=description> | ||
145 | This function creates a receive callback that stores whatever it receives | ||
146 | into a concat object. When done, the application can get the contents | ||
147 | received as a single string, directly from the concat object. | ||
148 | </p> | ||
149 | |||
150 | <p class=parameters> | ||
151 | <tt>Cat</tt> is the target concat object, or <b><tt>nil</tt></b>. | ||
152 | If <tt>cat</tt> is <b><tt>nil</tt></b>, the function creates its own | ||
153 | concat object. | ||
154 | </p> | ||
155 | |||
156 | <p class=return> | ||
157 | The function returns a receive callback for the file, and the concat object | ||
158 | that will be used to store the received contents. | ||
159 | </p> | ||
160 | |||
161 | <!-- receive.file +++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
162 | |||
163 | <p class=name id=receive.file> | ||
164 | socket.callback.<b>receive.file(</b>file, io_err<b>)</b> | ||
165 | </p> | ||
166 | |||
167 | <p class=description> | ||
168 | This function creates a receive callback that stores whatever it receives | ||
169 | into a file. When done, the callback closes the file. | ||
170 | </p> | ||
171 | |||
172 | <p class=parameters> | ||
173 | <tt>File</tt> is a file handle opened for writing. If <tt>file</tt> is | ||
174 | <b><tt>nil</tt></b>, <tt>io_err</tt> can contain an error message. In this | ||
175 | case, the function returns a callback that just aborts | ||
176 | transmission with the error message. | ||
177 | </p> | ||
178 | |||
179 | <p class=return> | ||
180 | The function returns a receive callback for the file. | ||
181 | </p> | ||
182 | |||
183 | <p class=note> | ||
184 | Note: This function is designed so that it directly accepts the return | ||
185 | values of Lua's IO <tt>io.open</tt> library function. | ||
186 | </p> | ||
187 | |||
188 | <!-- receive.chain ++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
189 | |||
190 | <p class=name id=receive.chain> | ||
191 | socket.callback.<b>receive.chain(</b>filter, receive_cb<b>)</b> | ||
192 | </p> | ||
193 | |||
194 | <p class=description> | ||
195 | This function creates a receive callback that passes all received data | ||
196 | through a filter, before handing it to a given receive callback. | ||
197 | </p> | ||
198 | |||
199 | <p class=parameters> | ||
200 | <tt>Cat</tt> is the target concat object, or <b><tt>nil</tt></b>. | ||
201 | If <tt>cat</tt> is <b><tt>nil</tt></b>, the function creates its own | ||
202 | concat object. | ||
203 | </p> | ||
204 | |||
205 | <p class=return> | ||
206 | The function returns a receive callback for the file, and the concat object | ||
207 | that will be used to store the received contents. | ||
208 | </p> | ||
209 | |||
210 | <p class=note> | ||
211 | Note: Several filters are defined in the <a href=mime.html>MIME</a> | ||
212 | module. Below is an example that creates a receive callback that | ||
213 | creates a string from the received contents, after decoding the | ||
214 | Quoted-Printable transfer content encoding. | ||
215 | </p> | ||
216 | |||
217 | <pre class=example> | ||
218 | string_cb, concat = socket.callback.receive.concat() | ||
219 | receive_cb = socket.callback.receive.chain( | ||
220 | socket.mime.decode("quoted-printable"), | ||
221 | string_cb | ||
222 | ) | ||
223 | </pre> | ||
224 | |||
225 | <p class=note> | ||
226 | The call to <tt>callback.chain</tt> creates a chained | ||
227 | receive callback that decodes data using the | ||
228 | <tt><a href=mime.html#decode>mime.decode</a></tt> | ||
229 | Quoted-Printable MIME filter and | ||
230 | hands the decoded data to a concat receive callback. | ||
231 | The concatenated decoded data can be retrieved later | ||
232 | from the associated concat object. | ||
233 | </p> | ||
234 | |||
116 | <!-- send.file ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 235 | <!-- send.file ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
117 | 236 | ||
118 | <p class=name id=send.file> | 237 | <p class=name id=send.file> |
119 | <b>send.file</b>(file, io_err<b>)</b> | 238 | socket.callback.<b>send.file(</b>file, io_err<b>)</b> |
120 | </p> | 239 | </p> |
121 | 240 | ||
122 | <p class=description> | 241 | <p class=description> |
@@ -126,25 +245,25 @@ When done, the callback closes the file. | |||
126 | </p> | 245 | </p> |
127 | 246 | ||
128 | <p class=parameters> | 247 | <p class=parameters> |
129 | <tt>File</tt> is a file opened for reading. If <tt>file</tt> is | 248 | <tt>File</tt> is a file handle opened for reading. If <tt>file</tt> is |
130 | <b><tt>nil</tt></b>, <tt>io_err</tt> can contain an error message. In this | 249 | <b><tt>nil</tt></b>, <tt>io_err</tt> can contain an error message. In this |
131 | case, the function returns a callback that just aborts | 250 | case, the function returns a callback that just aborts |
132 | transmission with the error message. | 251 | transmission with the error message. |
133 | </p> | 252 | </p> |
134 | 253 | ||
135 | <p class=return> | 254 | <p class=return> |
136 | Returns a send callback for the file. | 255 | The function returns a send callback for the file. |
137 | </p> | 256 | </p> |
138 | 257 | ||
139 | <p class=note> | 258 | <p class=note> |
140 | Note: This function is designed so that it directly accepts the return | 259 | Note: This function is designed so that it directly accepts the return |
141 | values of the <tt>io.open</tt> function. | 260 | values of Lua's IO <tt>io.open</tt> library function. |
142 | </p> | 261 | </p> |
143 | 262 | ||
144 | <!-- send.string ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 263 | <!-- send.string ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
145 | 264 | ||
146 | <p class=name id=send.string> | 265 | <p class=name id=send.string> |
147 | <b>send.string(</b>str, err<b>)</b> | 266 | socket.callback.<b>send.string(</b>str, err<b>)</b> |
148 | </p> | 267 | </p> |
149 | 268 | ||
150 | <p class=description> | 269 | <p class=description> |
@@ -154,26 +273,17 @@ the contents of a string. | |||
154 | 273 | ||
155 | <p class=parameters> | 274 | <p class=parameters> |
156 | <tt>Str</tt> is the string to be sent. | 275 | <tt>Str</tt> is the string to be sent. |
157 | <!-- | ||
158 | If <tt>str</tt> is | ||
159 | <b><tt>nil</tt></b>, <tt>err</tt> can optionally contain an error message. | ||
160 | --> | ||
161 | </p> | 276 | </p> |
162 | 277 | ||
163 | <p class=return> | 278 | <p class=return> |
164 | Returns a send callback for the string, or <b><tt>nil</tt></b> if the string is | 279 | It returns a send callback for the string, |
165 | <b><tt>nil</tt></b>. | 280 | or <b><tt>nil</tt></b> if <tt>str</tt> is <b><tt>nil</tt></b>. |
166 | </p> | ||
167 | |||
168 | <p class=note> | ||
169 | Note: A <tt>nil</tt></b> | ||
170 | send callback is equivalent to a callback that returns the empty string. | ||
171 | </p> | 281 | </p> |
172 | 282 | ||
173 | <!-- send.chain ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 283 | <!-- send.chain ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
174 | 284 | ||
175 | <p class=name id=send.chain> | 285 | <p class=name id=send.chain> |
176 | <b>send.chain(</b>send_cb, filter<b>)</b> | 286 | socket.callback.<b>send.chain(</b>send_cb, filter<b>)</b> |
177 | </p> | 287 | </p> |
178 | 288 | ||
179 | <p class=description> | 289 | <p class=description> |
@@ -207,9 +317,9 @@ send_cb = socket.callback.send.chain( | |||
207 | </pre> | 317 | </pre> |
208 | 318 | ||
209 | <p class=note> | 319 | <p class=note> |
210 | The call to <a href=mime.html#chain><tt>socket.mime.chain</tt></a> | 320 | The call to <a href=mime.html#chain><tt>mime.chain</tt></a> |
211 | creates a chained filter that encodes it's input and then breaks it | 321 | creates a chained filter that encodes it's input and then breaks it |
212 | into lines. The call to <tt>socket.callback.chain</tt> creates a chained | 322 | into lines. The call to <tt>callback.chain</tt> creates a chained |
213 | send callback that reads the file from disk and passes it through the | 323 | send callback that reads the file from disk and passes it through the |
214 | filter before sending it. | 324 | filter before sending it. |
215 | </p> | 325 | </p> |
diff --git a/doc/dns.html b/doc/dns.html index 17cee45..71a9719 100644 --- a/doc/dns.html +++ b/doc/dns.html | |||
@@ -36,8 +36,7 @@ | |||
36 | <h2 id=dns>DNS</h2> | 36 | <h2 id=dns>DNS</h2> |
37 | 37 | ||
38 | <p> | 38 | <p> |
39 | The following functions can be used to convert between host names and IP | 39 | Name resolution function return <em>all</em> information returned by the |
40 | addresses. Both functions return <em>all</em> information returned by the | ||
41 | resolver in a table of the form: | 40 | resolver in a table of the form: |
42 | </p> | 41 | </p> |
43 | 42 | ||
@@ -53,6 +52,21 @@ resolved = {<br> | |||
53 | Note that the <tt>alias</tt> list can be empty. | 52 | Note that the <tt>alias</tt> list can be empty. |
54 | </p> | 53 | </p> |
55 | 54 | ||
55 | <!-- gethostname ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
56 | |||
57 | <p class=name id=gethostname> | ||
58 | socket.dns.<b>gethostname()</b> | ||
59 | </p> | ||
60 | |||
61 | <p class=description> | ||
62 | Returns the standard host name for the machine. | ||
63 | </p> | ||
64 | |||
65 | <p class=return> | ||
66 | The function returns a string with the host name. | ||
67 | </p> | ||
68 | |||
69 | |||
56 | <!-- tohostname +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 70 | <!-- tohostname +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
57 | 71 | ||
58 | <p class=name id=tohostname> | 72 | <p class=name id=tohostname> |
@@ -74,7 +88,6 @@ the resolver. In case of error, the function returns <b><tt>nil</tt></b> | |||
74 | followed by an error message. | 88 | followed by an error message. |
75 | </p> | 89 | </p> |
76 | 90 | ||
77 | |||
78 | <!-- toip +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 91 | <!-- toip +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
79 | 92 | ||
80 | <p class=name id=toip> | 93 | <p class=name id=toip> |
diff --git a/doc/http.html b/doc/http.html index f977ea9..f82f515 100644 --- a/doc/http.html +++ b/doc/http.html | |||
@@ -49,7 +49,7 @@ implementation conforms to the HTTP/1.1 standard, | |||
49 | The module exports functions that provide HTTP functionality in different | 49 | The module exports functions that provide HTTP functionality in different |
50 | levels of abstraction, from a simple <a | 50 | levels of abstraction, from a simple <a |
51 | href="#get"><tt>get</tt></a>, to the generic, stream oriented | 51 | href="#get"><tt>get</tt></a>, to the generic, stream oriented |
52 | <a href="#request_cb"> <tt>request_cb</tt></a>. | 52 | <a href="#request_cb"><tt>request_cb</tt></a>. |
53 | </p> | 53 | </p> |
54 | 54 | ||
55 | <p> | 55 | <p> |
diff --git a/doc/index.html b/doc/index.html index 620f385..a2c2d59 100644 --- a/doc/index.html +++ b/doc/index.html | |||
@@ -40,7 +40,8 @@ LuaSocket is a <a href="http://www.lua.org">Lua</a> extension library | |||
40 | that is composed by two parts: a C layer that provides support for the TCP | 40 | that is composed by two parts: a C layer that provides support for the TCP |
41 | and UDP transport layers, and a set of Lua modules that add support for | 41 | and UDP transport layers, and a set of Lua modules that add support for |
42 | the SMTP (sending e-mails), HTTP (WWW access) and FTP (uploading and | 42 | the SMTP (sending e-mails), HTTP (WWW access) and FTP (uploading and |
43 | downloading files) protocols. | 43 | downloading files) protocols and other functionality commonly needed by |
44 | applications that deal with the Internet. | ||
44 | </p> | 45 | </p> |
45 | 46 | ||
46 | <p> | 47 | <p> |
@@ -106,10 +107,25 @@ This binary has been compiled with the <tt>LUASOCKET_DEBUG</tt> | |||
106 | option, and should be able to run the automatic test procedures. | 107 | option, and should be able to run the automatic test procedures. |
107 | </p> | 108 | </p> |
108 | 109 | ||
110 | <!-- thanks +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
111 | |||
112 | <h2 id=thanks>Special thanks</h2> | ||
113 | |||
114 | <p> | ||
115 | Throughout LuaSocket its history, many people gave sugestions that helped | ||
116 | improve it. For that, I thank the Lua comunity. | ||
117 | Special thanks go to | ||
118 | David Burgess, who has pushed the library to a new level of quality and | ||
119 | from whom I have learned a lot stuff that doesn't show up in RFCs. | ||
120 | Special thanks also to Carlos Cassino, who played a big part in the | ||
121 | extensible design seen in the C core of LuaSocket 2.0. | ||
122 | </p> | ||
123 | |||
109 | <!-- whatsnew +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 124 | <!-- whatsnew +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
110 | 125 | ||
111 | <h2 id=new>What's New</h2> | 126 | <h2 id=new>What's New</h2> |
112 | 127 | ||
128 | |||
113 | <p> | 129 | <p> |
114 | Most of the changes for 2.0 happened in the C layer, which | 130 | Most of the changes for 2.0 happened in the C layer, which |
115 | has been almost completely rewritten. The code has been ported to Lua 5.0 | 131 | has been almost completely rewritten. The code has been ported to Lua 5.0 |
diff --git a/doc/reference.html b/doc/reference.html index 0bfd378..e6efb6e 100644 --- a/doc/reference.html +++ b/doc/reference.html | |||
@@ -40,6 +40,10 @@ | |||
40 | <blockquote> | 40 | <blockquote> |
41 | <a href="callback.html">Callbacks (socket.callback)</a> | 41 | <a href="callback.html">Callbacks (socket.callback)</a> |
42 | <blockquote> | 42 | <blockquote> |
43 | <a href="callback.html#done">done</a>, | ||
44 | <a href="callback.html#fail">fail</a>. | ||
45 | </blockquote> | ||
46 | <blockquote> | ||
43 | <a href="callback.html#send">send</a>: | 47 | <a href="callback.html#send">send</a>: |
44 | <a href="callback.html#send.chain">chain</a>, | 48 | <a href="callback.html#send.chain">chain</a>, |
45 | <a href="callback.html#send.file">file</a>, | 49 | <a href="callback.html#send.file">file</a>, |
@@ -121,7 +125,7 @@ | |||
121 | <blockquote> | 125 | <blockquote> |
122 | <a href="mime.html">MIME (socket.mime) </a> | 126 | <a href="mime.html">MIME (socket.mime) </a> |
123 | <blockquote> | 127 | <blockquote> |
124 | <a href="mime.html#filters">filters</a>: | 128 | <a href="mime.html#high">high-level</a>: |
125 | <a href="mime.html#decode">canonic</a>, | 129 | <a href="mime.html#decode">canonic</a>, |
126 | <a href="mime.html#chain">chain</a>, | 130 | <a href="mime.html#chain">chain</a>, |
127 | <a href="mime.html#decode">decode</a>, | 131 | <a href="mime.html#decode">decode</a>, |
@@ -129,7 +133,7 @@ | |||
129 | <a href="mime.html#wrap">wrap</a>. | 133 | <a href="mime.html#wrap">wrap</a>. |
130 | </blockquote> | 134 | </blockquote> |
131 | <blockquote> | 135 | <blockquote> |
132 | <a href="mime.html#low-level">low-level</a>: | 136 | <a href="mime.html#low">low-level</a>: |
133 | <a href="mime.html#b64">b64</a>, | 137 | <a href="mime.html#b64">b64</a>, |
134 | <a href="mime.html#unb64">unb64</a>, | 138 | <a href="mime.html#unb64">unb64</a>, |
135 | <a href="mime.html#eol">eol</a>, | 139 | <a href="mime.html#eol">eol</a>, |
diff --git a/doc/tcp.html b/doc/tcp.html index eb4cdfa..34d6c6e 100644 --- a/doc/tcp.html +++ b/doc/tcp.html | |||
@@ -44,10 +44,11 @@ socket.<b>tcp()</b> | |||
44 | <p class=description> | 44 | <p class=description> |
45 | Creates and returns a TCP master object. A master object can | 45 | Creates and returns a TCP master object. A master object can |
46 | be transformed into a server object with the method | 46 | be transformed into a server object with the method |
47 | <a href=#bind><tt>bind</tt></a> or into a client object with the method | 47 | <a href=#listen><tt>listen</tt></a> (after a call to <a |
48 | <a href=#connect><tt>connect</tt></a>. The only other method | 48 | href=#bind><tt>bind</tt></a>) or into a client object with |
49 | supported by a master object is the <a href=#close><tt>close</tt></a> | 49 | the method <a href=#connect><tt>connect</tt></a>. The only other |
50 | method.</p> | 50 | method supported by a master object is the |
51 | <a href=#close><tt>close</tt></a> method.</p> | ||
51 | 52 | ||
52 | <p class=return> | 53 | <p class=return> |
53 | In case of success, a new master object is returned. In case of error, | 54 | In case of success, a new master object is returned. In case of error, |
@@ -67,8 +68,9 @@ object and returns a client object representing that connection. | |||
67 | 68 | ||
68 | <p class=return> | 69 | <p class=return> |
69 | If a connection is successfully initiated, a client object is returned. | 70 | If a connection is successfully initiated, a client object is returned. |
70 | If a timeout condition is met, the method returns <b><tt>nil</tt></b> followed | 71 | If a timeout condition is met, the method returns <b><tt>nil</tt></b> |
71 | by the error string '<tt>timeout</tt>'. | 72 | followed by the error string '<tt>timeout</tt>'. Other errors are |
73 | reported by <b><tt>nil</tt></b> followed by a message describing the error. | ||
72 | </p> | 74 | </p> |
73 | 75 | ||
74 | <p class=note> | 76 | <p class=note> |
@@ -77,25 +79,18 @@ with a server object in | |||
77 | the <tt>receive</tt> parameter before a call to <tt>accept</tt> does | 79 | the <tt>receive</tt> parameter before a call to <tt>accept</tt> does |
78 | <em>not</em> guarantee <tt>accept</tt> will return immediately. Use the <a | 80 | <em>not</em> guarantee <tt>accept</tt> will return immediately. Use the <a |
79 | href=#settimeout><tt>settimeout</tt></a> method or <tt>accept</tt> | 81 | href=#settimeout><tt>settimeout</tt></a> method or <tt>accept</tt> |
80 | might block until <em>another</em> client shows up. | 82 | might block until <em>another</em> client shows up. |
81 | </p> | 83 | </p> |
82 | 84 | ||
83 | <!-- bind +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 85 | <!-- bind +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
84 | 86 | ||
85 | <p class=name id=bind> | 87 | <p class=name id=bind> |
86 | master:<b>bind(</b>address, port [, backlog]<b>)</b> | 88 | master:<b>bind(</b>address, port<b>)</b> |
87 | </p> | 89 | </p> |
88 | 90 | ||
89 | <p class=description> | 91 | <p class=description> |
90 | Binds a master object to <tt>address</tt> and <tt>port</tt> on the | 92 | Binds a master object to <tt>address</tt> and <tt>port</tt> on the |
91 | local host, transforming it into a server object. Server | 93 | local host. |
92 | objects support the | ||
93 | <a href=#accept><tt>accept</tt></a>, | ||
94 | <a href=#getsockname><tt>getsockname</tt></a>, | ||
95 | <a href=#setoption><tt>setoption</tt></a>, | ||
96 | <a href=#settimeout><tt>settimeout</tt></a>, | ||
97 | and <a href=#close><tt>close</tt></a> methods. | ||
98 | </p> | ||
99 | 94 | ||
100 | <p class=parameters> | 95 | <p class=parameters> |
101 | <tt>Address</tt> can be an IP address or a host name. | 96 | <tt>Address</tt> can be an IP address or a host name. |
@@ -103,10 +98,7 @@ and <a href=#close><tt>close</tt></a> methods. | |||
103 | If <tt>address</tt> | 98 | If <tt>address</tt> |
104 | is '<tt>*</tt>', the system binds to all local interfaces | 99 | is '<tt>*</tt>', the system binds to all local interfaces |
105 | using the <tt>INADDR_ANY</tt> constant. If <tt>port</tt> is 0, the system automatically | 100 | using the <tt>INADDR_ANY</tt> constant. If <tt>port</tt> is 0, the system automatically |
106 | chooses an ephemeral port. The optional parameter <tt>backlog</tt>, which | 101 | chooses an ephemeral port. |
107 | defaults to 1, specifies the number of client connections that can | ||
108 | be queued waiting for service. If the queue is full and another client | ||
109 | attempts connection, the connection is refused. | ||
110 | </p> | 102 | </p> |
111 | 103 | ||
112 | <p class=return> | 104 | <p class=return> |
@@ -115,8 +107,8 @@ method returns <b><tt>nil</tt></b> followed by an error message. | |||
115 | </p> | 107 | </p> |
116 | 108 | ||
117 | <p class=note> | 109 | <p class=note> |
118 | Note: The function <tt>socket.bind</tt> is available and is a short | 110 | Note: The function <a href=#socket.bind><tt>socket.bind</tt></a> |
119 | for <a href=#socket.tcp><tt>socket.tcp</tt></a> followed by the <tt>bind</tt> method. | 111 | is available and is a shortcut for the creation server sockets. |
120 | </p> | 112 | </p> |
121 | 113 | ||
122 | <!-- close ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 114 | <!-- close ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
@@ -150,7 +142,8 @@ master:<b>connect(</b>address, port<b>)</b> | |||
150 | 142 | ||
151 | <p class=description> | 143 | <p class=description> |
152 | Attempts to connect a master object to a remote host, transforming it into a | 144 | Attempts to connect a master object to a remote host, transforming it into a |
153 | client object. Client objects support methods | 145 | client object. |
146 | Client objects support methods | ||
154 | <a href=#send><tt>send</tt></a>, | 147 | <a href=#send><tt>send</tt></a>, |
155 | <a href=#receive><tt>receive</tt></a>, | 148 | <a href=#receive><tt>receive</tt></a>, |
156 | <a href=#getsockname><tt>getsockname</tt></a>, | 149 | <a href=#getsockname><tt>getsockname</tt></a>, |
@@ -170,8 +163,15 @@ describing the error. In case of success, the method returns 1. | |||
170 | </p> | 163 | </p> |
171 | 164 | ||
172 | <p class=note> | 165 | <p class=note> |
173 | Note: The function <tt>socket.connect</tt> is available and is a short | 166 | Note: The function <a href=#socket.connect><tt>socket.connect</tt></a> |
174 | for <a href=#socket.tcp><tt>socket.tcp</tt></a> followed by the <tt>connect</tt> method. | 167 | is available and is a shortcut for the creation of client sockets. |
168 | </p> | ||
169 | |||
170 | <p class=note> | ||
171 | Note: Starting with LuaSocket 2.0, | ||
172 | the <a href=#settimeout><tt>settimeout</tt></a> | ||
173 | function affects the behavior of connect, causing it to return in case of | ||
174 | a timeout error. | ||
175 | </p> | 175 | </p> |
176 | 176 | ||
177 | <!-- getpeername ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 177 | <!-- getpeername ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
@@ -210,12 +210,32 @@ The method returns a string with local IP address and a number with | |||
210 | the port. In case of error, the method returns <b><tt>nil</tt></b>. | 210 | the port. In case of error, the method returns <b><tt>nil</tt></b>. |
211 | </p> | 211 | </p> |
212 | 212 | ||
213 | <p class=note> | 213 | <!-- listen ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
214 | Note: Naturally, for a server object, the address and port returned are | 214 | |
215 | those passed to the <a href=#bind>bind</a> method. If the port value | 215 | <p class=name id=listen> |
216 | passed to bind was 0, the OS assigned ephemeral port is returned. For | 216 | master:<b>listen(</b>backlog<b>)</b> |
217 | client objects, both the address and port are ephemeral and these are the | 217 | </p> |
218 | values returned. | 218 | |
219 | <p class=description> | ||
220 | Specifies the socket is willing to receive connections, transforming the | ||
221 | object into a server object. Server objects support the | ||
222 | <a href=#accept><tt>accept</tt></a>, | ||
223 | <a href=#getsockname><tt>getsockname</tt></a>, | ||
224 | <a href=#setoption><tt>setoption</tt></a>, | ||
225 | <a href=#settimeout><tt>settimeout</tt></a>, | ||
226 | and <a href=#close><tt>close</tt></a> methods. | ||
227 | </p> | ||
228 | |||
229 | <p class=parameters> | ||
230 | The parameter <tt>backlog</tt> specifies the number of client | ||
231 | connections that can | ||
232 | be queued waiting for service. If the queue is full and another client | ||
233 | attempts connection, the connection is refused. | ||
234 | </p> | ||
235 | |||
236 | <p class=return> | ||
237 | In case of success, the method returns 1. In case of error, the | ||
238 | method returns <b><tt>nil</tt></b> followed by an error message. | ||
219 | </p> | 239 | </p> |
220 | 240 | ||
221 | <!-- receive ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 241 | <!-- receive ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
@@ -242,8 +262,8 @@ closed. No end-of-line translation is performed; | |||
242 | terminated by a LF character (ASCII 10), optionally preceded by a | 262 | terminated by a LF character (ASCII 10), optionally preceded by a |
243 | CR character (ASCII 13). The CR and LF characters are not included in | 263 | CR character (ASCII 13). The CR and LF characters are not included in |
244 | the returned line. This is the default pattern; | 264 | the returned line. This is the default pattern; |
245 | <li> <tt>number</tt>: causes the method to read <tt>number</tt> raw | 265 | <li> <tt>number</tt>: causes the method to read a specified <tt>number</tt> |
246 | bytes from the socket. | 266 | of bytes from the socket. |
247 | </ul> | 267 | </ul> |
248 | 268 | ||
249 | <p class=return> | 269 | <p class=return> |
@@ -311,22 +331,30 @@ are sure you need it. | |||
311 | depends on the option being set: | 331 | depends on the option being set: |
312 | 332 | ||
313 | <ul> | 333 | <ul> |
314 | <li> '<tt>tcp-nodelay</tt>': Setting this option to <tt>true</tt> disables the | 334 | |
315 | Nagle's algorithm for the connection; | 335 | <li> '<tt>keepalive</tt>': Setting this option to <tt>true</tt> enables |
336 | the periodic transmission of messages on a connected socket. Should the | ||
337 | connected party fail to respond to these messages, the connection is | ||
338 | considered broken and processes using the socket are notified; | ||
339 | |||
316 | <li> '<tt>linger</tt>': Controls the action taken when unsent data are | 340 | <li> '<tt>linger</tt>': Controls the action taken when unsent data are |
317 | queued on a socket and a close is performed. The value is a table with a | 341 | queued on a socket and a close is performed. The value is a table with a |
318 | boolean entry '<tt>on</tt>' and a numeric entry for the time interval | 342 | boolean entry '<tt>on</tt>' and a numeric entry for the time interval |
319 | '<tt>timeout</tt>' in seconds. | 343 | '<tt>timeout</tt>' in seconds. If the '<tt>on</tt>' field is set to |
320 | If the '<tt>on</tt>' field is set to <tt>true</tt>, | 344 | <tt>true</tt>, the system will block the process on the close attempt until |
321 | the system will block the process on the close attempt until it is able to | 345 | it is able to transmit the data or until '<tt>timeout</tt>' has passed. If |
322 | transmit the data or until '<tt>timeout</tt>' has passed. If '<tt>on</tt>' | 346 | '<tt>on</tt>' is <tt>false</tt> and a close is issued, the system will |
323 | is <tt>false</tt> and a close is issued, the system will process the close | 347 | process the close in a manner that allows the process to continue as |
324 | in a manner that allows the process to continue as quickly as possible. I | 348 | quickly as possible. I do not advise you to set this to anything other than |
325 | do not advise you to set this to anything other than zero. | 349 | zero; |
326 | <li> '<tt>keepalive</tt>': Setting this option to <tt>true</tt> enables | 350 | |
327 | the periodic transmission of messages on a connected socket. Should the | 351 | <li> '<tt>reuseaddr</tt>': Setting this option indicates that the rules |
328 | connected party fail to respond to these messages, the connection is | 352 | used in validating addresses supplied in a call to |
329 | considered broken and processes using the socket are notified. | 353 | <a href=#bind><tt>bind</tt></a> should allow reuse of local addresses; |
354 | |||
355 | <li> '<tt>tcp-nodelay</tt>': Setting this option to <tt>true</tt> | ||
356 | disables the Nagle's algorithm for the connection. | ||
357 | |||
330 | </ul> | 358 | </ul> |
331 | 359 | ||
332 | <p class=return> | 360 | <p class=return> |
@@ -382,7 +410,9 @@ indefinitely. Negative timeout values have the same effect. | |||
382 | Note: although timeout values have millisecond precision in LuaSocket, | 410 | Note: although timeout values have millisecond precision in LuaSocket, |
383 | large blocks can cause I/O functions not to respect timeout values due | 411 | large blocks can cause I/O functions not to respect timeout values due |
384 | to the time the library takes to transfer blocks to and from the OS | 412 | to the time the library takes to transfer blocks to and from the OS |
385 | and to and from the Lua interpreter. | 413 | and to and from the Lua interpreter. Also, function that accept host names |
414 | and perform automatic name resolution might be blocked by the resolver for | ||
415 | longer than the specified timeout value. | ||
386 | </p> | 416 | </p> |
387 | 417 | ||
388 | <p class=note> | 418 | <p class=note> |
@@ -391,6 +421,30 @@ changed for sake of uniformity, since all other method names already | |||
391 | contained verbs making their imperative nature obvious. | 421 | contained verbs making their imperative nature obvious. |
392 | </p> | 422 | </p> |
393 | 423 | ||
424 | <!-- shutdown +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
425 | |||
426 | <p class=name id=shutdown> | ||
427 | client:<b>shutdown(</b>mode<b>)</b><br> | ||
428 | </p> | ||
429 | |||
430 | <p class=description> | ||
431 | Shuts down part of a full duplex connection. | ||
432 | </p> | ||
433 | |||
434 | <p class=parameters> | ||
435 | Mode tells which way of the connection should be shut down and can | ||
436 | take the value: | ||
437 | <ul> | ||
438 | <li>"<tt>both</tt>": disallow further sends and receives on the object. | ||
439 | This is the default mode; | ||
440 | <li>"<tt>send</tt>": disallow further sends on the object; | ||
441 | <li>"<tt>receive</tt>": disallow further receives on the object. | ||
442 | </ul> | ||
443 | |||
444 | <p class=return> | ||
445 | This function returns 1. | ||
446 | </p> | ||
447 | |||
394 | <!-- footer +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 448 | <!-- footer +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
395 | 449 | ||
396 | <div class=footer> | 450 | <div class=footer> |
diff --git a/doc/url.html b/doc/url.html index 0eafafa..f3a7cb7 100644 --- a/doc/url.html +++ b/doc/url.html | |||
@@ -241,6 +241,50 @@ returning a list with all the parsed segments, the function unescapes all | |||
241 | of them. | 241 | of them. |
242 | </p> | 242 | </p> |
243 | 243 | ||
244 | <!-- escape +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
245 | |||
246 | <p class=name id="escape"> | ||
247 | socket.url.<b>escape(</b>content<b>)</b> | ||
248 | </p> | ||
249 | |||
250 | <p class=description> | ||
251 | Applies the URL escaping content coding to a string | ||
252 | Each byte is encoded as a percent character followed | ||
253 | by the two byte hexadecimal representation of its integer | ||
254 | value. | ||
255 | </p> | ||
256 | |||
257 | <p class=parameters> | ||
258 | <tt>Content</tt> is the string to be encoded. | ||
259 | </p> | ||
260 | |||
261 | <p class=result> | ||
262 | The function returns the encoded string. | ||
263 | </p> | ||
264 | |||
265 | <pre class=example> | ||
266 | code = socket.url.escape("/#?;") | ||
267 | -- code = "%2f%23%3f%3b" | ||
268 | </pre> | ||
269 | |||
270 | <!-- unescape +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
271 | |||
272 | <p class=name id="unescape"> | ||
273 | socket.url.<b>unescape(</b>content<b>)</b> | ||
274 | </p> | ||
275 | |||
276 | <p class=description> | ||
277 | Removes the URL escaping content coding from a string. | ||
278 | </p> | ||
279 | |||
280 | <p class=parameters> | ||
281 | <tt>Content</tt> is the string to be decoded. | ||
282 | </p> | ||
283 | |||
284 | <p class=return> | ||
285 | The function returns the decoded string. | ||
286 | </p> | ||
287 | |||
244 | <!-- footer +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | 288 | <!-- footer +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> |
245 | 289 | ||
246 | <div class=footer> | 290 | <div class=footer> |