~ubuntu-branches/ubuntu/natty/ocamlnet/natty

« back to all changes in this revision

Viewing changes to doc/html-main/Netbuffer.html

  • Committer: Bazaar Package Importer
  • Author(s): Stefano Zacchiroli
  • Date: 2007-04-11 21:09:18 UTC
  • mfrom: (1.2.3 upstream)
  • Revision ID: james.westby@ubuntu.com-20070411210918-keupynp43rhwwbig
Tags: 2.2.7-1
* New upstream release
* Uploading ocamlnet 2.2.x to unstable
* debian/rules
  - removed -enable-modcaml, no longer supported upstream

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
 
2
<html>
 
3
<head>
 
4
<link rel="stylesheet" href="style.css" type="text/css">
 
5
<meta content="text/html; charset=iso-8859-1" http-equiv="Content-Type">
 
6
<link rel="Start" href="index.html">
 
7
<link rel="previous" href="Netaddress.html">
 
8
<link rel="next" href="Netdate.html">
 
9
<link rel="Up" href="index.html">
 
10
<link title="Index of types" rel=Appendix href="index_types.html">
 
11
<link title="Index of exceptions" rel=Appendix href="index_exceptions.html">
 
12
<link title="Index of values" rel=Appendix href="index_values.html">
 
13
<link title="Index of class attributes" rel=Appendix href="index_attributes.html">
 
14
<link title="Index of class methods" rel=Appendix href="index_methods.html">
 
15
<link title="Index of classes" rel=Appendix href="index_classes.html">
 
16
<link title="Index of class types" rel=Appendix href="index_class_types.html">
 
17
<link title="Index of modules" rel=Appendix href="index_modules.html">
 
18
<link title="Index of module types" rel=Appendix href="index_module_types.html">
 
19
<link title="Uq_gtk" rel="Chapter" href="Uq_gtk.html">
 
20
<link title="Equeue" rel="Chapter" href="Equeue.html">
 
21
<link title="Unixqueue" rel="Chapter" href="Unixqueue.html">
 
22
<link title="Uq_engines" rel="Chapter" href="Uq_engines.html">
 
23
<link title="Uq_socks5" rel="Chapter" href="Uq_socks5.html">
 
24
<link title="Unixqueue_mt" rel="Chapter" href="Unixqueue_mt.html">
 
25
<link title="Equeue_intro" rel="Chapter" href="Equeue_intro.html">
 
26
<link title="Uq_ssl" rel="Chapter" href="Uq_ssl.html">
 
27
<link title="Uq_tcl" rel="Chapter" href="Uq_tcl.html">
 
28
<link title="Netcgi_common" rel="Chapter" href="Netcgi_common.html">
 
29
<link title="Netcgi" rel="Chapter" href="Netcgi.html">
 
30
<link title="Netcgi_ajp" rel="Chapter" href="Netcgi_ajp.html">
 
31
<link title="Netcgi_scgi" rel="Chapter" href="Netcgi_scgi.html">
 
32
<link title="Netcgi_cgi" rel="Chapter" href="Netcgi_cgi.html">
 
33
<link title="Netcgi_fcgi" rel="Chapter" href="Netcgi_fcgi.html">
 
34
<link title="Netcgi_dbi" rel="Chapter" href="Netcgi_dbi.html">
 
35
<link title="Netcgi1_compat" rel="Chapter" href="Netcgi1_compat.html">
 
36
<link title="Netcgi_test" rel="Chapter" href="Netcgi_test.html">
 
37
<link title="Netcgi_porting" rel="Chapter" href="Netcgi_porting.html">
 
38
<link title="Netcgi_plex" rel="Chapter" href="Netcgi_plex.html">
 
39
<link title="Http_client" rel="Chapter" href="Http_client.html">
 
40
<link title="Telnet_client" rel="Chapter" href="Telnet_client.html">
 
41
<link title="Ftp_data_endpoint" rel="Chapter" href="Ftp_data_endpoint.html">
 
42
<link title="Ftp_client" rel="Chapter" href="Ftp_client.html">
 
43
<link title="Nethttpd_types" rel="Chapter" href="Nethttpd_types.html">
 
44
<link title="Nethttpd_kernel" rel="Chapter" href="Nethttpd_kernel.html">
 
45
<link title="Nethttpd_reactor" rel="Chapter" href="Nethttpd_reactor.html">
 
46
<link title="Nethttpd_engine" rel="Chapter" href="Nethttpd_engine.html">
 
47
<link title="Nethttpd_services" rel="Chapter" href="Nethttpd_services.html">
 
48
<link title="Nethttpd_plex" rel="Chapter" href="Nethttpd_plex.html">
 
49
<link title="Nethttpd_intro" rel="Chapter" href="Nethttpd_intro.html">
 
50
<link title="Netplex_types" rel="Chapter" href="Netplex_types.html">
 
51
<link title="Netplex_mp" rel="Chapter" href="Netplex_mp.html">
 
52
<link title="Netplex_mt" rel="Chapter" href="Netplex_mt.html">
 
53
<link title="Netplex_log" rel="Chapter" href="Netplex_log.html">
 
54
<link title="Netplex_controller" rel="Chapter" href="Netplex_controller.html">
 
55
<link title="Netplex_container" rel="Chapter" href="Netplex_container.html">
 
56
<link title="Netplex_sockserv" rel="Chapter" href="Netplex_sockserv.html">
 
57
<link title="Netplex_workload" rel="Chapter" href="Netplex_workload.html">
 
58
<link title="Netplex_main" rel="Chapter" href="Netplex_main.html">
 
59
<link title="Netplex_config" rel="Chapter" href="Netplex_config.html">
 
60
<link title="Netplex_kit" rel="Chapter" href="Netplex_kit.html">
 
61
<link title="Rpc_netplex" rel="Chapter" href="Rpc_netplex.html">
 
62
<link title="Netplex_cenv" rel="Chapter" href="Netplex_cenv.html">
 
63
<link title="Netplex_intro" rel="Chapter" href="Netplex_intro.html">
 
64
<link title="Netshm" rel="Chapter" href="Netshm.html">
 
65
<link title="Netshm_data" rel="Chapter" href="Netshm_data.html">
 
66
<link title="Netshm_hashtbl" rel="Chapter" href="Netshm_hashtbl.html">
 
67
<link title="Netshm_array" rel="Chapter" href="Netshm_array.html">
 
68
<link title="Netshm_intro" rel="Chapter" href="Netshm_intro.html">
 
69
<link title="Netconversion" rel="Chapter" href="Netconversion.html">
 
70
<link title="Netchannels" rel="Chapter" href="Netchannels.html">
 
71
<link title="Netstream" rel="Chapter" href="Netstream.html">
 
72
<link title="Mimestring" rel="Chapter" href="Mimestring.html">
 
73
<link title="Netmime" rel="Chapter" href="Netmime.html">
 
74
<link title="Netsendmail" rel="Chapter" href="Netsendmail.html">
 
75
<link title="Neturl" rel="Chapter" href="Neturl.html">
 
76
<link title="Netaddress" rel="Chapter" href="Netaddress.html">
 
77
<link title="Netbuffer" rel="Chapter" href="Netbuffer.html">
 
78
<link title="Netdate" rel="Chapter" href="Netdate.html">
 
79
<link title="Netencoding" rel="Chapter" href="Netencoding.html">
 
80
<link title="Netulex" rel="Chapter" href="Netulex.html">
 
81
<link title="Netaccel" rel="Chapter" href="Netaccel.html">
 
82
<link title="Netaccel_link" rel="Chapter" href="Netaccel_link.html">
 
83
<link title="Nethtml" rel="Chapter" href="Nethtml.html">
 
84
<link title="Netstring_str" rel="Chapter" href="Netstring_str.html">
 
85
<link title="Netstring_pcre" rel="Chapter" href="Netstring_pcre.html">
 
86
<link title="Netstring_mt" rel="Chapter" href="Netstring_mt.html">
 
87
<link title="Netmappings" rel="Chapter" href="Netmappings.html">
 
88
<link title="Netaux" rel="Chapter" href="Netaux.html">
 
89
<link title="Nethttp" rel="Chapter" href="Nethttp.html">
 
90
<link title="Netchannels_tut" rel="Chapter" href="Netchannels_tut.html">
 
91
<link title="Netmime_tut" rel="Chapter" href="Netmime_tut.html">
 
92
<link title="Netsendmail_tut" rel="Chapter" href="Netsendmail_tut.html">
 
93
<link title="Netulex_tut" rel="Chapter" href="Netulex_tut.html">
 
94
<link title="Neturl_tut" rel="Chapter" href="Neturl_tut.html">
 
95
<link title="Netsys" rel="Chapter" href="Netsys.html">
 
96
<link title="Netpop" rel="Chapter" href="Netpop.html">
 
97
<link title="Rpc_auth_dh" rel="Chapter" href="Rpc_auth_dh.html">
 
98
<link title="Rpc_key_service" rel="Chapter" href="Rpc_key_service.html">
 
99
<link title="Rpc_time" rel="Chapter" href="Rpc_time.html">
 
100
<link title="Rpc_auth_local" rel="Chapter" href="Rpc_auth_local.html">
 
101
<link title="Rtypes" rel="Chapter" href="Rtypes.html">
 
102
<link title="Xdr" rel="Chapter" href="Xdr.html">
 
103
<link title="Rpc" rel="Chapter" href="Rpc.html">
 
104
<link title="Rpc_program" rel="Chapter" href="Rpc_program.html">
 
105
<link title="Rpc_portmapper_aux" rel="Chapter" href="Rpc_portmapper_aux.html">
 
106
<link title="Rpc_packer" rel="Chapter" href="Rpc_packer.html">
 
107
<link title="Rpc_transport" rel="Chapter" href="Rpc_transport.html">
 
108
<link title="Rpc_client" rel="Chapter" href="Rpc_client.html">
 
109
<link title="Rpc_simple_client" rel="Chapter" href="Rpc_simple_client.html">
 
110
<link title="Rpc_portmapper_clnt" rel="Chapter" href="Rpc_portmapper_clnt.html">
 
111
<link title="Rpc_portmapper" rel="Chapter" href="Rpc_portmapper.html">
 
112
<link title="Rpc_server" rel="Chapter" href="Rpc_server.html">
 
113
<link title="Rpc_auth_sys" rel="Chapter" href="Rpc_auth_sys.html">
 
114
<link title="Rpc_intro" rel="Chapter" href="Rpc_intro.html">
 
115
<link title="Rpc_mapping_ref" rel="Chapter" href="Rpc_mapping_ref.html">
 
116
<link title="Rpc_ssl" rel="Chapter" href="Rpc_ssl.html">
 
117
<link title="Rpc_xti_client" rel="Chapter" href="Rpc_xti_client.html">
 
118
<link title="Shell_sys" rel="Chapter" href="Shell_sys.html">
 
119
<link title="Shell" rel="Chapter" href="Shell.html">
 
120
<link title="Shell_uq" rel="Chapter" href="Shell_uq.html">
 
121
<link title="Shell_mt" rel="Chapter" href="Shell_mt.html">
 
122
<link title="Shell_intro" rel="Chapter" href="Shell_intro.html">
 
123
<link title="Netsmtp" rel="Chapter" href="Netsmtp.html"><title>Ocamlnet 2 Reference Manual : Netbuffer</title>
 
124
</head>
 
125
<body>
 
126
<div class="navbar"><a href="Netaddress.html">Previous</a>
 
127
&nbsp;<a href="index.html">Up</a>
 
128
&nbsp;<a href="Netdate.html">Next</a>
 
129
</div>
 
130
<center><h1>Module <a href="type_Netbuffer.html">Netbuffer</a></h1></center>
 
131
<br>
 
132
<pre><span class="keyword">module</span> Netbuffer: <code class="code">sig</code> <a href="Netbuffer.html">..</a> <code class="code">end</code></pre>A Netbuffer.t is a buffer that can grow and shrink dynamically.<br>
 
133
<hr width="100%">
 
134
<pre><span class="keyword">type</span> <a name="TYPEt"></a><code class="type"></code>t </pre>
 
135
 
 
136
<pre><span class="keyword">val</span> <a name="VALcreate"></a>create : <code class="type">int -> <a href="Netbuffer.html#TYPEt">t</a></code></pre><div class="info">
 
137
Creates a netbuffer which allocates initially this number of bytes. 
 
138
 The logical length is zero.<br>
 
139
</div>
 
140
<pre><span class="keyword">val</span> <a name="VALcontents"></a>contents : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> string</code></pre><div class="info">
 
141
Returns the contents of the buffer as fresh string.<br>
 
142
</div>
 
143
<pre><span class="keyword">val</span> <a name="VALsub"></a>sub : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int -> int -> string</code></pre><div class="info">
 
144
<code class="code">sub nb k n</code>: returns the n characters starting at position <code class="code">n</code> from 
 
145
 netbuffer <code class="code">nb</code> as fresh string<br>
 
146
</div>
 
147
<pre><span class="keyword">val</span> <a name="VALblit"></a>blit : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int -> string -> int -> int -> unit</code></pre><div class="info">
 
148
<code class="code">blit nb srcpos dest destpos len</code>: Copies the <code class="code">len</code> bytes at
 
149
 position <code class="code">srcpos</code> from <code class="code">nb</code> to the string <code class="code">dest</code> at position <code class="code">destpos</code>.<br>
 
150
</div>
 
151
<pre><span class="keyword">val</span> <a name="VALlength"></a>length : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int</code></pre><div class="info">
 
152
Returns the logical length of the buffer<br>
 
153
</div>
 
154
<pre><span class="keyword">val</span> <a name="VALadd_string"></a>add_string : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> string -> unit</code></pre><div class="info">
 
155
<code class="code">add_string nb s</code>: Adds a copy of the string <code class="code">s</code> to the logical end of
 
156
 the netbuffer <code class="code">nb</code>. If necessary, <code class="code">nb</code> grows.<br>
 
157
</div>
 
158
<pre><span class="keyword">val</span> <a name="VALadd_sub_string"></a>add_sub_string : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> string -> int -> int -> unit</code></pre><div class="info">
 
159
<code class="code">add_sub_string nb s k n</code>: Adds the substring of <code class="code">s</code> starting at position
 
160
 <code class="code">k</code> with length <code class="code">n</code> to the logical end of the netbuffer <code class="code">nb</code>. If necessary,
 
161
 <code class="code">nb</code> grows.
 
162
<p>
 
163
 
 
164
 This is semantically the same as
 
165
 <code class="code">add_string nb (String.sub s k n)</code>, but the extra copy is avoided.<br>
 
166
</div>
 
167
<pre><span class="keyword">val</span> <a name="VALadd_inplace"></a>add_inplace : <code class="type">?len:int -> <a href="Netbuffer.html#TYPEt">t</a> -> (string -> int -> int -> int) -> int</code></pre><div class="info">
 
168
<code class="code">add_inplace nb f</code>: Calls the function <code class="code">f</code> to add bytes to the
 
169
 netbuffer <code class="code">nb</code>. The arguments of <code class="code">f</code> are the buffer, the position
 
170
 in the buffer, and the maximum length. The function <code class="code">f</code> must return
 
171
 the actual number of added bytes; this number is also returned by
 
172
 <code class="code">add_inplace</code>.
 
173
<p>
 
174
 
 
175
 Example: let n = add_inplace nb (Pervasives.input ch)
 
176
<p>
 
177
 
 
178
 The argument <code class="code">len</code> is the number of bytes to add (second argument of
 
179
 <code class="code">f</code>). It defaults to the number of free bytes in the buffer after space
 
180
 for at least one byte has been allocated.<br>
 
181
</div>
 
182
<pre><span class="keyword">val</span> <a name="VALinsert_string"></a>insert_string : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int -> string -> unit</code></pre><div class="info">
 
183
<code class="code">insert_string nb p s</code>: Inserts the value of string <code class="code">s</code> at position
 
184
 <code class="code">p</code> into the netbuffer <code class="code">nb</code><br>
 
185
</div>
 
186
<pre><span class="keyword">val</span> <a name="VALinsert_sub_string"></a>insert_sub_string : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int -> string -> int -> int -> unit</code></pre><div class="info">
 
187
<code class="code">insert_string nb p s k n</code>: Inserts a substring of string <code class="code">s</code> at position
 
188
 <code class="code">p</code> into the netbuffer <code class="code">nb</code>. The substring is denoted by position <code class="code">k</code>
 
189
 and has length <code class="code">n</code><br>
 
190
</div>
 
191
<pre><span class="keyword">val</span> <a name="VALinsert_char"></a>insert_char : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int -> char -> unit</code></pre><div class="info">
 
192
<code class="code">insert_char nb p c</code>: Inserts character <code class="code">c</code> at position <code class="code">p</code> into
 
193
 the netbuffer <code class="code">nb</code><br>
 
194
</div>
 
195
<pre><span class="keyword">val</span> <a name="VALdelete"></a>delete : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int -> int -> unit</code></pre><div class="info">
 
196
<code class="code">delete nb k n</code>: Deletes the <code class="code">n</code> bytes at position <code class="code">k</code> of netbuffer 
 
197
 <code class="code">nb</code> in-place.
 
198
<p>
 
199
 
 
200
 The netbuffer does not shrink, however, i.e. the free space is not
 
201
 given back to the memory manager.<br>
 
202
</div>
 
203
<pre><span class="keyword">val</span> <a name="VALclear"></a>clear : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> unit</code></pre><div class="info">
 
204
Deletes all contents from the buffer. As <code class="code">delete</code>, the netbuffer does
 
205
 not shrink.<br>
 
206
</div>
 
207
<pre><span class="keyword">val</span> <a name="VALtry_shrinking"></a>try_shrinking : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> unit</code></pre><div class="info">
 
208
<code class="code">try_shrinking nb</code>: If the length of the buffer is less than half of
 
209
 the allocated space, the netbuffer is reallocated in order to save
 
210
 memory.<br>
 
211
</div>
 
212
<pre><span class="keyword">val</span> <a name="VALindex_from"></a>index_from : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> int -> char -> int</code></pre><div class="info">
 
213
<code class="code">index_from nb k c</code>: Searches the character <code class="code">c</code> in the netbuffer beginning
 
214
 at position <code class="code">k</code>. If found, the position of the left-most occurence is
 
215
 returned. Otherwise, <code class="code">Not_found</code> is raised.<br>
 
216
</div>
 
217
<pre><span class="keyword">val</span> <a name="VALunsafe_buffer"></a>unsafe_buffer : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> string</code></pre><div class="info">
 
218
<b>Warning! This is a low-level function!</b>
 
219
 Returns the current string that internally holds the buffer.
 
220
 The byte positions 0 to length - 1 actually store the contents of
 
221
 the buffer. You can directly read and modify the buffer. Note that
 
222
 there is no protection if you read or write positions beyond the
 
223
 length of the buffer.<br>
 
224
</div>
 
225
<pre><span class="keyword">val</span> <a name="VALprint_buffer"></a>print_buffer : <code class="type"><a href="Netbuffer.html#TYPEt">t</a> -> unit</code></pre><div class="info">
 
226
For the toploop<br>
 
227
</div>
 
228
</body></html>
 
 
b'\\ No newline at end of file'