diff options
Diffstat (limited to 'doc/tcp.html')
-rw-r--r-- | doc/tcp.html | 697 |
1 files changed, 0 insertions, 697 deletions
diff --git a/doc/tcp.html b/doc/tcp.html deleted file mode 100644 index fb627a1..0000000 --- a/doc/tcp.html +++ /dev/null | |||
@@ -1,697 +0,0 @@ | |||
1 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" | ||
2 | "http://www.w3.org/TR/html4/strict.dtd"> | ||
3 | <html> | ||
4 | |||
5 | <head> | ||
6 | <meta name="description" content="LuaSocket: The TCP/IP support"> | ||
7 | <meta name="keywords" content="Lua, LuaSocket, Socket, TCP, Library, Network, Support"> | ||
8 | <title>LuaSocket: TCP/IP support</title> | ||
9 | <link rel="stylesheet" href="reference.css" type="text/css"> | ||
10 | </head> | ||
11 | |||
12 | <body> | ||
13 | |||
14 | <!-- header +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
15 | |||
16 | <div class=header> | ||
17 | <hr> | ||
18 | <center> | ||
19 | <table summary="LuaSocket logo"> | ||
20 | <tr><td align=center><a href="http://www.lua.org"> | ||
21 | <img width=128 height=128 border=0 alt="LuaSocket" src="luasocket.png"> | ||
22 | </a></td></tr> | ||
23 | <tr><td align=center valign=top>Network support for the Lua language | ||
24 | </td></tr> | ||
25 | </table> | ||
26 | <p class=bar> | ||
27 | <a href="index.html">home</a> · | ||
28 | <a href="index.html#download">download</a> · | ||
29 | <a href="installation.html">installation</a> · | ||
30 | <a href="introduction.html">introduction</a> · | ||
31 | <a href="reference.html">reference</a> | ||
32 | </p> | ||
33 | </center> | ||
34 | <hr> | ||
35 | </div> | ||
36 | |||
37 | <!-- tcp ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
38 | |||
39 | <h2 id="tcp">TCP</h2> | ||
40 | |||
41 | <!-- socket.tcp +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
42 | |||
43 | <p class=name id="socket.tcp"> | ||
44 | socket.<b>tcp()</b> | ||
45 | </p> | ||
46 | |||
47 | <p class=description> | ||
48 | Creates and returns an TCP master object. A master object can | ||
49 | be transformed into a server object with the method | ||
50 | <a href=#listen><tt>listen</tt></a> (after a call to <a | ||
51 | href=#bind><tt>bind</tt></a>) or into a client object with | ||
52 | the method <a href=#connect><tt>connect</tt></a>. The only other | ||
53 | method supported by a master object is the | ||
54 | <a href=#close><tt>close</tt></a> method.</p> | ||
55 | |||
56 | <p class=return> | ||
57 | In case of success, a new master object is returned. In case of error, | ||
58 | <b><tt>nil</tt></b> is returned, followed by an error message. | ||
59 | </p> | ||
60 | |||
61 | <p class=note> | ||
62 | Note: The choice between IPv4 and IPv6 happens during a call to | ||
63 | <a href=#bind><tt>bind</tt></a> or <a | ||
64 | href=#bind><tt>connect</tt></a>, depending on the address | ||
65 | family obtained from the resolver. | ||
66 | </p> | ||
67 | |||
68 | <p class=note> | ||
69 | Note: Before the choice between IPv4 and IPv6 happens, | ||
70 | the internal socket object is invalid and therefore <a | ||
71 | href=#setoption><tt>setoption</tt></a> will fail. | ||
72 | </p> | ||
73 | |||
74 | <!-- socket.tcp +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
75 | |||
76 | <p class=name id="socket.tcp4"> | ||
77 | socket.<b>tcp4()</b> | ||
78 | </p> | ||
79 | |||
80 | <p class=description> | ||
81 | Creates and returns an IPv4 TCP master object. A master object can | ||
82 | be transformed into a server object with the method | ||
83 | <a href=#listen><tt>listen</tt></a> (after a call to <a | ||
84 | href=#bind><tt>bind</tt></a>) or into a client object with | ||
85 | the method <a href=#connect><tt>connect</tt></a>. The only other | ||
86 | method supported by a master object is the | ||
87 | <a href=#close><tt>close</tt></a> method.</p> | ||
88 | |||
89 | <p class=return> | ||
90 | In case of success, a new master object is returned. In case of error, | ||
91 | <b><tt>nil</tt></b> is returned, followed by an error message. | ||
92 | </p> | ||
93 | |||
94 | <!-- socket.tcp6 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
95 | |||
96 | <p class=name id="socket.tcp6"> | ||
97 | socket.<b>tcp6()</b> | ||
98 | </p> | ||
99 | |||
100 | <p class=description> | ||
101 | Creates and returns an IPv6 TCP master object. A master object can | ||
102 | be transformed into a server object with the method | ||
103 | <a href=#listen><tt>listen</tt></a> (after a call to <a | ||
104 | href=#bind><tt>bind</tt></a>) or into a client object with | ||
105 | the method <a href=#connect><tt>connect</tt></a>. The only other | ||
106 | method supported by a master object is the | ||
107 | <a href=#close><tt>close</tt></a> method.</p> | ||
108 | |||
109 | <p class=return> | ||
110 | In case of success, a new master object is returned. In case of error, | ||
111 | <b><tt>nil</tt></b> is returned, followed by an error message. | ||
112 | </p> | ||
113 | |||
114 | <p class=note> | ||
115 | Note: The TCP object returned will have the option | ||
116 | "<tt>ipv6-v6only</tt>" set to <tt><b>true</b></tt>. | ||
117 | </p> | ||
118 | |||
119 | <!-- accept +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
120 | |||
121 | <p class=name id="accept"> | ||
122 | server:<b>accept()</b> | ||
123 | </p> | ||
124 | |||
125 | <p class=description> | ||
126 | Waits for a remote connection on the server | ||
127 | object and returns a client object representing that connection. | ||
128 | </p> | ||
129 | |||
130 | <p class=return> | ||
131 | If a connection is successfully initiated, a client object is returned. | ||
132 | If a timeout condition is met, the method returns <b><tt>nil</tt></b> | ||
133 | followed by the error string '<tt>timeout</tt>'. Other errors are | ||
134 | reported by <b><tt>nil</tt></b> followed by a message describing the error. | ||
135 | </p> | ||
136 | |||
137 | <p class=note> | ||
138 | Note: calling <a href=socket.html#select><tt>socket.select</tt></a> | ||
139 | with a server object in | ||
140 | the <tt>recvt</tt> parameter before a call to <tt>accept</tt> does | ||
141 | <em>not</em> guarantee <tt>accept</tt> will return immediately. Use the <a | ||
142 | href=#settimeout><tt>settimeout</tt></a> method or <tt>accept</tt> | ||
143 | might block until <em>another</em> client shows up. | ||
144 | </p> | ||
145 | |||
146 | <!-- bind +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
147 | |||
148 | <p class=name id="bind"> | ||
149 | master:<b>bind(</b>address, port<b>)</b> | ||
150 | </p> | ||
151 | |||
152 | <p class=description> | ||
153 | Binds a master object to <tt>address</tt> and <tt>port</tt> on the | ||
154 | local host. | ||
155 | |||
156 | <p class=parameters> | ||
157 | <tt>Address</tt> can be an IP address or a host name. | ||
158 | <tt>Port</tt> must be an integer number in the range [0..64K). | ||
159 | If <tt>address</tt> | ||
160 | is '<tt>*</tt>', the system binds to all local interfaces | ||
161 | using the <tt>INADDR_ANY</tt> constant or | ||
162 | <tt>IN6ADDR_ANY_INIT</tt>, according to the family. | ||
163 | If <tt>port</tt> is 0, the system automatically | ||
164 | chooses an ephemeral port. | ||
165 | </p> | ||
166 | |||
167 | <p class=return> | ||
168 | In case of success, the method returns 1. In case of error, the | ||
169 | method returns <b><tt>nil</tt></b> followed by an error message. | ||
170 | </p> | ||
171 | |||
172 | <p class=note> | ||
173 | Note: The function <a href=socket.html#bind><tt>socket.bind</tt></a> | ||
174 | is available and is a shortcut for the creation of server sockets. | ||
175 | </p> | ||
176 | |||
177 | <!-- close ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
178 | |||
179 | <p class=name id="close"> | ||
180 | master:<b>close()</b><br> | ||
181 | client:<b>close()</b><br> | ||
182 | server:<b>close()</b> | ||
183 | </p> | ||
184 | |||
185 | <p class=description> | ||
186 | Closes a TCP object. The internal socket used by the object is closed | ||
187 | and the local address to which the object was | ||
188 | bound is made available to other applications. No further operations | ||
189 | (except for further calls to the <tt>close</tt> method) are allowed on | ||
190 | a closed socket. | ||
191 | </p> | ||
192 | |||
193 | <p class=note> | ||
194 | Note: It is important to close all used sockets once they are not | ||
195 | needed, since, in many systems, each socket uses a file descriptor, | ||
196 | which are limited system resources. Garbage-collected objects are | ||
197 | automatically closed before destruction, though. | ||
198 | </p> | ||
199 | |||
200 | <!-- connect ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
201 | |||
202 | <p class=name id="connect"> | ||
203 | master:<b>connect(</b>address, port<b>)</b> | ||
204 | </p> | ||
205 | |||
206 | <p class=description> | ||
207 | Attempts to connect a master object to a remote host, transforming it into a | ||
208 | client object. | ||
209 | Client objects support methods | ||
210 | <a href=#send><tt>send</tt></a>, | ||
211 | <a href=#receive><tt>receive</tt></a>, | ||
212 | <a href=#getsockname><tt>getsockname</tt></a>, | ||
213 | <a href=#getpeername><tt>getpeername</tt></a>, | ||
214 | <a href=#settimeout><tt>settimeout</tt></a>, | ||
215 | and <a href=#close><tt>close</tt></a>. | ||
216 | </p> | ||
217 | |||
218 | <p class=parameters> | ||
219 | <tt>Address</tt> can be an IP address or a host name. | ||
220 | <tt>Port</tt> must be an integer number in the range [1..64K). | ||
221 | </p> | ||
222 | |||
223 | <p class=return> | ||
224 | In case of error, the method returns <b><tt>nil</tt></b> followed by a string | ||
225 | describing the error. In case of success, the method returns 1. | ||
226 | </p> | ||
227 | |||
228 | <p class=note> | ||
229 | Note: The function <a href=socket.html#connect><tt>socket.connect</tt></a> | ||
230 | is available and is a shortcut for the creation of client sockets. | ||
231 | </p> | ||
232 | |||
233 | <p class=note> | ||
234 | Note: Starting with LuaSocket 2.0, | ||
235 | the <a href=#settimeout><tt>settimeout</tt></a> | ||
236 | method affects the behavior of <tt>connect</tt>, causing it to return | ||
237 | with an error in case of a timeout. If that happens, you can still call <a | ||
238 | href=socket.html#select><tt>socket.select</tt></a> with the socket in the | ||
239 | <tt>sendt</tt> table. The socket will be writable when the connection is | ||
240 | established. | ||
241 | </p> | ||
242 | |||
243 | <p class=note> | ||
244 | Note: Starting with LuaSocket 3.0, the host name resolution | ||
245 | depends on whether the socket was created by <a | ||
246 | href=#socket.tcp><tt>socket.tcp</tt></a> or <a | ||
247 | href=#socket.tcp6><tt>socket.tcp6</tt></a>. Addresses from | ||
248 | the appropriate family are tried in succession until the | ||
249 | first success or until the last failure. | ||
250 | </p> | ||
251 | |||
252 | <!-- getpeername ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
253 | |||
254 | <p class=name id="getpeername"> | ||
255 | client:<b>getpeername()</b> | ||
256 | </p> | ||
257 | |||
258 | <p class=description> | ||
259 | Returns information about the remote side of a connected client object. | ||
260 | </p> | ||
261 | |||
262 | <p class=return> | ||
263 | Returns a string with the IP address of the peer, the | ||
264 | port number that peer is using for the connection, | ||
265 | and a string with the family ("<tt>inet</tt>" or "<tt>inet6</tt>"). | ||
266 | In case of error, the method returns <b><tt>nil</tt></b>. | ||
267 | </p> | ||
268 | |||
269 | <p class=note> | ||
270 | Note: It makes no sense to call this method on server objects. | ||
271 | </p> | ||
272 | |||
273 | <!-- getsockname ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
274 | |||
275 | <p class=name id="getsockname"> | ||
276 | master:<b>getsockname()</b><br> | ||
277 | client:<b>getsockname()</b><br> | ||
278 | server:<b>getsockname()</b> | ||
279 | </p> | ||
280 | |||
281 | <p class=description> | ||
282 | Returns the local address information associated to the object. | ||
283 | </p> | ||
284 | |||
285 | <p class=return> | ||
286 | The method returns a string with local IP address, a number with | ||
287 | the local port, | ||
288 | and a string with the family ("<tt>inet</tt>" or "<tt>inet6</tt>"). | ||
289 | In case of error, the method returns <b><tt>nil</tt></b>. | ||
290 | </p> | ||
291 | |||
292 | <!-- getstats +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
293 | |||
294 | <p class=name id="getstats"> | ||
295 | master:<b>getstats()</b><br> | ||
296 | client:<b>getstats()</b><br> | ||
297 | server:<b>getstats()</b><br> | ||
298 | </p> | ||
299 | |||
300 | <p class=description> | ||
301 | Returns accounting information on the socket, useful for throttling | ||
302 | of bandwidth. | ||
303 | </p> | ||
304 | |||
305 | <p class=return> | ||
306 | The method returns the number of bytes received, the number of bytes sent, | ||
307 | and the age of the socket object in seconds. | ||
308 | </p> | ||
309 | |||
310 | <!-- listen ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
311 | |||
312 | <p class=name id="listen"> | ||
313 | master:<b>listen(</b>backlog<b>)</b> | ||
314 | </p> | ||
315 | |||
316 | <p class=description> | ||
317 | Specifies the socket is willing to receive connections, transforming the | ||
318 | object into a server object. Server objects support the | ||
319 | <a href=#accept><tt>accept</tt></a>, | ||
320 | <a href=#getsockname><tt>getsockname</tt></a>, | ||
321 | <a href=#setoption><tt>setoption</tt></a>, | ||
322 | <a href=#settimeout><tt>settimeout</tt></a>, | ||
323 | and <a href=#close><tt>close</tt></a> methods. | ||
324 | </p> | ||
325 | |||
326 | <p class=parameters> | ||
327 | The parameter <tt>backlog</tt> specifies the number of client | ||
328 | connections that can | ||
329 | be queued waiting for service. If the queue is full and another client | ||
330 | attempts connection, the connection is refused. | ||
331 | </p> | ||
332 | |||
333 | <p class=return> | ||
334 | In case of success, the method returns 1. In case of error, the | ||
335 | method returns <b><tt>nil</tt></b> followed by an error message. | ||
336 | </p> | ||
337 | |||
338 | <!-- receive ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
339 | |||
340 | <p class=name id="receive"> | ||
341 | client:<b>receive(</b>[pattern [, prefix]]<b>)</b> | ||
342 | </p> | ||
343 | |||
344 | <p class=description> | ||
345 | Reads data from a client object, according to the specified <em>read | ||
346 | pattern</em>. Patterns follow the Lua file I/O format, and the difference in performance between all patterns is negligible. | ||
347 | </p> | ||
348 | |||
349 | <p class=parameters> | ||
350 | <tt>Pattern</tt> can be any of the following: | ||
351 | </p> | ||
352 | |||
353 | <ul> | ||
354 | <li> '<tt>*a</tt>': reads from the socket until the connection is | ||
355 | closed. No end-of-line translation is performed; | ||
356 | <li> '<tt>*l</tt>': reads a line of text from the socket. The line is | ||
357 | terminated by a LF character (ASCII 10), optionally preceded by a | ||
358 | CR character (ASCII 13). The CR and LF characters are not included in | ||
359 | the returned line. In fact, <em>all</em> CR characters are | ||
360 | ignored by the pattern. This is the default pattern; | ||
361 | <li> <tt>number</tt>: causes the method to read a specified <tt>number</tt> | ||
362 | of bytes from the socket. | ||
363 | </ul> | ||
364 | |||
365 | <p class=parameters> | ||
366 | <tt>Prefix</tt> is an optional string to be concatenated to the beginning | ||
367 | of any received data before return. | ||
368 | </p> | ||
369 | |||
370 | <p class=return> | ||
371 | If successful, the method returns the received pattern. In case of error, | ||
372 | the method returns <tt><b>nil</b></tt> followed by an error | ||
373 | message, followed by a (possibly empty) string containing | ||
374 | the partial that was received. The error message can be | ||
375 | the string '<tt>closed</tt>' in case the connection was | ||
376 | closed before the transmission was completed or the string | ||
377 | '<tt>timeout</tt>' in case there was a timeout during the operation. | ||
378 | </p> | ||
379 | |||
380 | <p class=note> | ||
381 | <b>Important note</b>: This function was changed <em>severely</em>. It used | ||
382 | to support multiple patterns (but I have never seen this feature used) and | ||
383 | now it doesn't anymore. Partial results used to be returned in the same | ||
384 | way as successful results. This last feature violated the idea that all | ||
385 | functions should return <tt><b>nil</b></tt> on error. Thus it was changed | ||
386 | too. | ||
387 | </p> | ||
388 | |||
389 | <!-- send +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
390 | |||
391 | <p class=name id="send"> | ||
392 | client:<b>send(</b>data [, i [, j]]<b>)</b> | ||
393 | </p> | ||
394 | |||
395 | <p class=description> | ||
396 | Sends <tt>data</tt> through client object. | ||
397 | </p> | ||
398 | |||
399 | <p class=parameters> | ||
400 | <tt>Data</tt> is the string to be sent. The optional arguments | ||
401 | <tt>i</tt> and <tt>j</tt> work exactly like the standard | ||
402 | <tt>string.sub</tt> Lua function to allow the selection of a | ||
403 | substring to be sent. | ||
404 | </p> | ||
405 | |||
406 | <p class=return> | ||
407 | If successful, the method returns the index of the last byte | ||
408 | within <tt>[i, j]</tt> that has been sent. Notice that, if | ||
409 | <tt>i</tt> is 1 or absent, this is effectively the total | ||
410 | number of bytes sent. In case of error, the method returns | ||
411 | <b><tt>nil</tt></b>, followed by an error message, followed | ||
412 | by the index of the last byte within <tt>[i, j]</tt> that | ||
413 | has been sent. You might want to try again from the byte | ||
414 | following that. The error message can be '<tt>closed</tt>' | ||
415 | in case the connection was closed before the transmission | ||
416 | was completed or the string '<tt>timeout</tt>' in case | ||
417 | there was a timeout during the operation. | ||
418 | </p> | ||
419 | |||
420 | <p class=note> | ||
421 | Note: Output is <em>not</em> buffered. For small strings, | ||
422 | it is always better to concatenate them in Lua | ||
423 | (with the '<tt>..</tt>' operator) and send the result in one call | ||
424 | instead of calling the method several times. | ||
425 | </p> | ||
426 | |||
427 | <!-- setoption ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
428 | |||
429 | <p class=name id="setoption"> | ||
430 | client:<b>setoption(</b>option [, value]<b>)</b><br> | ||
431 | server:<b>setoption(</b>option [, value]<b>)</b> | ||
432 | </p> | ||
433 | |||
434 | <p class=description> | ||
435 | Sets options for the TCP object. Options are only needed by low-level or | ||
436 | time-critical applications. You should only modify an option if you | ||
437 | are sure you need it. | ||
438 | </p> | ||
439 | |||
440 | <p class=parameters> | ||
441 | <tt>Option</tt> is a string with the option name, and <tt>value</tt> | ||
442 | depends on the option being set: | ||
443 | |||
444 | <ul> | ||
445 | |||
446 | <li> '<tt>keepalive</tt>': Setting this option to <tt>true</tt> enables | ||
447 | the periodic transmission of messages on a connected socket. Should the | ||
448 | connected party fail to respond to these messages, the connection is | ||
449 | considered broken and processes using the socket are notified; | ||
450 | |||
451 | <li> '<tt>linger</tt>': Controls the action taken when unsent data are | ||
452 | queued on a socket and a close is performed. The value is a table with a | ||
453 | boolean entry '<tt>on</tt>' and a numeric entry for the time interval | ||
454 | '<tt>timeout</tt>' in seconds. If the '<tt>on</tt>' field is set to | ||
455 | <tt>true</tt>, the system will block the process on the close attempt until | ||
456 | it is able to transmit the data or until '<tt>timeout</tt>' has passed. If | ||
457 | '<tt>on</tt>' is <tt>false</tt> and a close is issued, the system will | ||
458 | process the close in a manner that allows the process to continue as | ||
459 | quickly as possible. I do not advise you to set this to anything other than | ||
460 | zero; | ||
461 | |||
462 | <li> '<tt>reuseaddr</tt>': Setting this option indicates that the rules | ||
463 | used in validating addresses supplied in a call to | ||
464 | <a href=#bind><tt>bind</tt></a> should allow reuse of local addresses; | ||
465 | |||
466 | <li> '<tt>tcp-nodelay</tt>': Setting this option to <tt>true</tt> | ||
467 | disables the Nagle's algorithm for the connection; | ||
468 | |||
469 | <li> '<tt>ipv6-v6only</tt>': | ||
470 | Setting this option to <tt>true</tt> restricts an <tt>inet6</tt> socket to | ||
471 | sending and receiving only IPv6 packets. | ||
472 | </ul> | ||
473 | |||
474 | <p class=return> | ||
475 | The method returns 1 in case of success, or <b><tt>nil</tt></b> | ||
476 | followed by an error message otherwise. | ||
477 | </p> | ||
478 | |||
479 | <p class=note> | ||
480 | Note: The descriptions above come from the man pages. | ||
481 | </p> | ||
482 | |||
483 | <!-- getoption ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
484 | |||
485 | <p class=name id="getoption"> | ||
486 | client:<b>getoption(</b>option)</b><br> | ||
487 | server:<b>getoption(</b>option)</b> | ||
488 | </p> | ||
489 | |||
490 | <p class=description> | ||
491 | Gets options for the TCP object. | ||
492 | See <a href=#setoption><tt>setoption</tt></a> for description of the | ||
493 | option names and values. | ||
494 | </p> | ||
495 | |||
496 | <p class=parameters> | ||
497 | <tt>Option</tt> is a string with the option name. | ||
498 | <ul> | ||
499 | |||
500 | <li> '<tt>keepalive</tt>' | ||
501 | <li> '<tt>linger</tt>' | ||
502 | <li> '<tt>reuseaddr</tt>' | ||
503 | <li> '<tt>tcp-nodelay</tt>' | ||
504 | </ul> | ||
505 | |||
506 | <p class=return> | ||
507 | The method returns the option <tt>value</tt> in case of success, or | ||
508 | <b><tt>nil</tt></b> followed by an error message otherwise. | ||
509 | </p> | ||
510 | |||
511 | <!-- setstats +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
512 | |||
513 | <p class=name id="setstats"> | ||
514 | master:<b>setstats(</b>received, sent, age<b>)</b><br> | ||
515 | client:<b>setstats(</b>received, sent, age<b>)</b><br> | ||
516 | server:<b>setstats(</b>received, sent, age<b>)</b><br> | ||
517 | </p> | ||
518 | |||
519 | <p class=description> | ||
520 | Resets accounting information on the socket, useful for throttling | ||
521 | of bandwidth. | ||
522 | </p> | ||
523 | |||
524 | <p class=parameters> | ||
525 | <tt>Received</tt> is a number with the new number of bytes received. | ||
526 | <tt>Sent</tt> is a number with the new number of bytes sent. | ||
527 | <tt>Age</tt> is the new age in seconds. | ||
528 | </p> | ||
529 | |||
530 | <p class=return> | ||
531 | The method returns 1 in case of success and <tt><b>nil</b></tt> otherwise. | ||
532 | </p> | ||
533 | |||
534 | <!-- settimeout +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
535 | |||
536 | <p class=name id="settimeout"> | ||
537 | master:<b>settimeout(</b>value [, mode]<b>)</b><br> | ||
538 | client:<b>settimeout(</b>value [, mode]<b>)</b><br> | ||
539 | server:<b>settimeout(</b>value [, mode]<b>)</b> | ||
540 | </p> | ||
541 | |||
542 | <p class=description> | ||
543 | Changes the timeout values for the object. By default, | ||
544 | all I/O operations are blocking. That is, any call to the methods | ||
545 | <a href=#send><tt>send</tt></a>, | ||
546 | <a href=#receive><tt>receive</tt></a>, and | ||
547 | <a href=#accept><tt>accept</tt></a> | ||
548 | will block indefinitely, until the operation completes. The | ||
549 | <tt>settimeout</tt> method defines a limit on the amount of time the | ||
550 | I/O methods can block. When a timeout is set and the specified amount of | ||
551 | time has elapsed, the affected methods give up and fail with an error code. | ||
552 | </p> | ||
553 | |||
554 | <p class=parameters> | ||
555 | The amount of time to wait is specified as the | ||
556 | <tt>value</tt> parameter, in seconds. There are two timeout modes and | ||
557 | both can be used together for fine tuning: | ||
558 | </p> | ||
559 | |||
560 | <ul> | ||
561 | <li> '<tt>b</tt>': <em>block</em> timeout. Specifies the upper limit on | ||
562 | the amount of time LuaSocket can be blocked by the operating system | ||
563 | while waiting for completion of any single I/O operation. This is the | ||
564 | default mode;</li> | ||
565 | |||
566 | <li> '<tt>t</tt>': <em>total</em> timeout. Specifies the upper limit on | ||
567 | the amount of time LuaSocket can block a Lua script before returning from | ||
568 | a call.</li> | ||
569 | </ul> | ||
570 | |||
571 | <p class=parameters> | ||
572 | The <b><tt>nil</tt></b> timeout <tt>value</tt> allows operations to block | ||
573 | indefinitely. Negative timeout values have the same effect. | ||
574 | </p> | ||
575 | |||
576 | <p class=note> | ||
577 | Note: although timeout values have millisecond precision in LuaSocket, | ||
578 | large blocks can cause I/O functions not to respect timeout values due | ||
579 | to the time the library takes to transfer blocks to and from the OS | ||
580 | and to and from the Lua interpreter. Also, function that accept host names | ||
581 | and perform automatic name resolution might be blocked by the resolver for | ||
582 | longer than the specified timeout value. | ||
583 | </p> | ||
584 | |||
585 | <p class=note> | ||
586 | Note: The old <tt>timeout</tt> method is deprecated. The name has been | ||
587 | changed for sake of uniformity, since all other method names already | ||
588 | contained verbs making their imperative nature obvious. | ||
589 | </p> | ||
590 | |||
591 | <!-- shutdown +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
592 | |||
593 | <p class=name id="shutdown"> | ||
594 | client:<b>shutdown(</b>mode<b>)</b><br> | ||
595 | </p> | ||
596 | |||
597 | <p class=description> | ||
598 | Shuts down part of a full-duplex connection. | ||
599 | </p> | ||
600 | |||
601 | <p class=parameters> | ||
602 | Mode tells which way of the connection should be shut down and can | ||
603 | take the value: | ||
604 | <ul> | ||
605 | <li>"<tt>both</tt>": disallow further sends and receives on the object. | ||
606 | This is the default mode; | ||
607 | <li>"<tt>send</tt>": disallow further sends on the object; | ||
608 | <li>"<tt>receive</tt>": disallow further receives on the object. | ||
609 | </ul> | ||
610 | |||
611 | <p class=return> | ||
612 | This function returns 1. | ||
613 | </p> | ||
614 | |||
615 | <!-- dirty +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
616 | |||
617 | <p class=name id="dirty"> | ||
618 | master:<b>dirty()</b><br> | ||
619 | client:<b>dirty()</b><br> | ||
620 | server:<b>dirty()</b> | ||
621 | </p> | ||
622 | |||
623 | <p class=description> | ||
624 | Check the read buffer status. | ||
625 | </p> | ||
626 | |||
627 | <p class=return> | ||
628 | Returns <tt>true</tt> if there is any data in the read buffer, <tt>false</tt> otherwise. | ||
629 | </p> | ||
630 | |||
631 | <p class=note> | ||
632 | Note: <b>This is an internal method, any use is unlikely to be portable.</b> | ||
633 | </p> | ||
634 | |||
635 | <!-- getfd +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
636 | |||
637 | <p class=name id="getfd"> | ||
638 | master:<b>getfd()</b><br> | ||
639 | client:<b>getfd()</b><br> | ||
640 | server:<b>getfd()</b> | ||
641 | </p> | ||
642 | |||
643 | <p class=description> | ||
644 | Returns the underling socket descriptor or handle associated to the object. | ||
645 | </p> | ||
646 | |||
647 | <p class=return> | ||
648 | The descriptor or handle. In case the object has been closed, the return will be -1. | ||
649 | </p> | ||
650 | |||
651 | <p class=note> | ||
652 | Note: <b>This is an internal method, any use is unlikely to be portable.</b> | ||
653 | </p> | ||
654 | |||
655 | <!-- setfd +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
656 | |||
657 | <p class=name id="setfd"> | ||
658 | master:<b>setfd(</b>fd<b>)</b><br> | ||
659 | client:<b>setfd(</b>fd<b>)</b><br> | ||
660 | server:<b>setfd(</b>fd<b>)</b> | ||
661 | </p> | ||
662 | |||
663 | <p class=description> | ||
664 | Sets the underling socket descriptor or handle associated to the object. The current one is simply replaced, not closed, and no other change to the object state is made. | ||
665 | </p> | ||
666 | |||
667 | <p class=return> | ||
668 | No return value. | ||
669 | </p> | ||
670 | |||
671 | <p class=note> | ||
672 | Note: <b>This is an internal method, any use is unlikely to be portable.</b> | ||
673 | </p> | ||
674 | |||
675 | <!-- footer +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ --> | ||
676 | |||
677 | <div class=footer> | ||
678 | <hr> | ||
679 | <center> | ||
680 | <p class=bar> | ||
681 | <a href="index.html">home</a> · | ||
682 | <a href="index.html#down">download</a> · | ||
683 | <a href="installation.html">installation</a> · | ||
684 | <a href="introduction.html">introduction</a> · | ||
685 | <a href="reference.html">reference</a> | ||
686 | </p> | ||
687 | <p> | ||
688 | <small> | ||
689 | Last modified by Diego Nehab on <br> | ||
690 | Thu Apr 20 00:25:57 EDT 2006 | ||
691 | </small> | ||
692 | </p> | ||
693 | </center> | ||
694 | </div> | ||
695 | |||
696 | </body> | ||
697 | </html> | ||