File: StreamSocketService.html

package info (click to toggle)
boost1.42 1.42.0-4
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 277,864 kB
  • ctags: 401,076
  • sloc: cpp: 1,235,659; xml: 74,142; ansic: 41,313; python: 26,756; sh: 11,840; cs: 2,118; makefile: 655; perl: 494; yacc: 456; asm: 353; csh: 6
file content (230 lines) | stat: -rwxr-xr-x 17,350 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<title>Stream socket service requirements</title>
<link rel="stylesheet" href="../../boostbook.css" type="text/css">
<meta name="generator" content="DocBook XSL Stylesheets V1.75.2">
<link rel="home" href="../../boost_asio.html" title="Boost.Asio">
<link rel="up" href="../reference.html" title="Reference">
<link rel="prev" href="StreamHandleService.html" title="Stream handle service requirements">
<link rel="next" href="SyncRandomAccessReadDevice.html" title="Buffer-oriented synchronous random-access read device requirements">
</head>
<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
<table cellpadding="2" width="100%"><tr>
<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../boost.png"></td>
<td align="center"><a href="../../../../index.html">Home</a></td>
<td align="center"><a href="../../../../libs/libraries.htm">Libraries</a></td>
<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
<td align="center"><a href="../../../../more/index.htm">More</a></td>
</tr></table>
<hr>
<div class="spirit-nav">
<a accesskey="p" href="StreamHandleService.html"><img src="../../../../doc/html/images/prev.png" alt="Prev"></a><a accesskey="u" href="../reference.html"><img src="../../../../doc/html/images/up.png" alt="Up"></a><a accesskey="h" href="../../boost_asio.html"><img src="../../../../doc/html/images/home.png" alt="Home"></a><a accesskey="n" href="SyncRandomAccessReadDevice.html"><img src="../../../../doc/html/images/next.png" alt="Next"></a>
</div>
<div class="section" title="Stream socket service requirements">
<div class="titlepage"><div><div><h3 class="title">
<a name="boost_asio.reference.StreamSocketService"></a><a class="link" href="StreamSocketService.html" title="Stream socket service requirements"> Stream socket
      service requirements</a>
</h3></div></div></div>
<p>
        A stream socket service must meet the requirements for a <a class="link" href="SocketService.html" title="Socket service requirements">socket
        service</a>, as well as the additional requirements listed below.
      </p>
<p>
        In the table below, <code class="computeroutput"><span class="identifier">X</span></code> denotes
        a stream socket service class, <code class="computeroutput"><span class="identifier">a</span></code>
        denotes a value of type <code class="computeroutput"><span class="identifier">X</span></code>,
        <code class="computeroutput"><span class="identifier">b</span></code> denotes a value of type
        <code class="computeroutput"><span class="identifier">X</span><span class="special">::</span><span class="identifier">implementation_type</span></code>, <code class="computeroutput"><span class="identifier">ec</span></code>
        denotes a value of type <code class="computeroutput"><span class="identifier">error_code</span></code>,
        <code class="computeroutput"><span class="identifier">f</span></code> denotes a value of type
        <code class="computeroutput"><span class="identifier">socket_base</span><span class="special">::</span><span class="identifier">message_flags</span></code>, <code class="computeroutput"><span class="identifier">mb</span></code>
        denotes a value satisfying <a class="link" href="MutableBufferSequence.html" title="Mutable buffer sequence requirements">mutable
        buffer sequence</a> requirements, <code class="computeroutput"><span class="identifier">rh</span></code>
        denotes a value meeting <a class="link" href="ReadHandler.html" title="Read handler requirements"><code class="computeroutput"><span class="identifier">ReadHandler</span></code></a> requirements, <code class="computeroutput"><span class="identifier">cb</span></code> denotes a value satisfying <a class="link" href="ConstBufferSequence.html" title="Constant buffer sequence requirements">constant
        buffer sequence</a> requirements, and <code class="computeroutput"><span class="identifier">wh</span></code>
        denotes a value meeting <a class="link" href="WriteHandler.html" title="Write handler requirements"><code class="computeroutput"><span class="identifier">WriteHandler</span></code></a> requirements.
      </p>
<div class="table">
<a name="id654537"></a><p class="title"><b>Table&#160;30.&#160;StreamSocketService requirements</b></p>
<div class="table-contents"><table class="table" summary="StreamSocketService requirements">
<colgroup>
<col>
<col>
<col>
</colgroup>
<thead><tr>
<th>
            <p>
              expression
            </p>
            </th>
<th>
            <p>
              return type
            </p>
            </th>
<th>
            <p>
              assertion/note<br> pre/post-condition
            </p>
            </th>
</tr></thead>
<tbody>
<tr>
<td>
            <p>
              <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">receive</span><span class="special">(</span><span class="identifier">b</span><span class="special">,</span> <span class="identifier">mb</span><span class="special">,</span> <span class="identifier">f</span><span class="special">,</span> <span class="identifier">ec</span><span class="special">);</span></code>
            </p>
            </td>
<td>
            <p>
              <code class="computeroutput"><span class="identifier">size_t</span></code>
            </p>
            </td>
<td>
            <p>
              pre: <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">is_open</span><span class="special">(</span><span class="identifier">b</span><span class="special">)</span></code>.<br>
              <br> Reads one or more bytes of data from a connected socket <code class="computeroutput"><span class="identifier">b</span></code>.<br> <br> The mutable buffer
              sequence <code class="computeroutput"><span class="identifier">mb</span></code> specifies
              memory where the data should be placed. The operation shall always
              fill a buffer in the sequence completely before proceeding to the next.<br>
              <br> If successful, returns the number of bytes read. Otherwise returns
              <code class="computeroutput"><span class="number">0</span></code>. If the total size of
              all buffers in the sequence <code class="computeroutput"><span class="identifier">mb</span></code>
              is <code class="computeroutput"><span class="number">0</span></code>, the function shall
              return <code class="computeroutput"><span class="number">0</span></code> immediately.<br>
              <br> If the operation completes due to graceful connection closure
              by the peer, the operation shall fail with <code class="computeroutput"><span class="identifier">error</span><span class="special">::</span><span class="identifier">eof</span></code>.
            </p>
            </td>
</tr>
<tr>
<td>
            <p>
              <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">async_receive</span><span class="special">(</span><span class="identifier">b</span><span class="special">,</span> <span class="identifier">mb</span><span class="special">,</span> <span class="identifier">f</span><span class="special">,</span> <span class="identifier">rh</span><span class="special">);</span></code>
            </p>
            </td>
<td>
            <p>
              <code class="computeroutput"><span class="keyword">void</span></code>
            </p>
            </td>
<td>
            <p>
              pre: <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">is_open</span><span class="special">(</span><span class="identifier">b</span><span class="special">)</span></code>.<br>
              <br> Initiates an asynchronous operation to read one or more bytes
              of data from a connected socket <code class="computeroutput"><span class="identifier">b</span></code>.
              The operation is performed via the <code class="computeroutput"><span class="identifier">io_service</span></code>
              object <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">io_service</span><span class="special">()</span></code>
              and behaves according to <a class="link" href="asynchronous_operations.html" title="Requirements on asynchronous operations">asynchronous
              operation</a> requirements.<br> <br> The mutable buffer sequence
              <code class="computeroutput"><span class="identifier">mb</span></code> specifies memory
              where the data should be placed. The operation shall always fill a
              buffer in the sequence completely before proceeding to the next.<br>
              <br> The implementation shall maintain one or more copies of <code class="computeroutput"><span class="identifier">mb</span></code> until such time as the read operation
              no longer requires access to the memory specified by the buffers in
              the sequence. The program must ensure the memory is valid until:<br>
              <br> &#8212; the last copy of <code class="computeroutput"><span class="identifier">mb</span></code>
              is destroyed, or<br> <br> &#8212; the handler for the asynchronous operation
              is invoked,<br> <br> whichever comes first. If the total size of
              all buffers in the sequence <code class="computeroutput"><span class="identifier">mb</span></code>
              is <code class="computeroutput"><span class="number">0</span></code>, the asynchronous
              read operation shall complete immediately and pass <code class="computeroutput"><span class="number">0</span></code>
              as the argument to the handler that specifies the number of bytes read.<br>
              <br> If the operation completes due to graceful connection closure
              by the peer, the operation shall fail with <code class="computeroutput"><span class="identifier">error</span><span class="special">::</span><span class="identifier">eof</span></code>.<br>
              <br> If the operation completes successfully, the <code class="computeroutput"><span class="identifier">ReadHandler</span></code>
              object <code class="computeroutput"><span class="identifier">rh</span></code> is invoked
              with the number of bytes transferred. Otherwise it is invoked with
              <code class="computeroutput"><span class="number">0</span></code>.
            </p>
            </td>
</tr>
<tr>
<td>
            <p>
              <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">send</span><span class="special">(</span><span class="identifier">b</span><span class="special">,</span> <span class="identifier">cb</span><span class="special">,</span> <span class="identifier">f</span><span class="special">,</span> <span class="identifier">ec</span><span class="special">);</span></code>
            </p>
            </td>
<td>
            <p>
              <code class="computeroutput"><span class="identifier">size_t</span></code>
            </p>
            </td>
<td>
            <p>
              pre: <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">is_open</span><span class="special">(</span><span class="identifier">b</span><span class="special">)</span></code>.<br>
              <br> Writes one or more bytes of data to a connected socket <code class="computeroutput"><span class="identifier">b</span></code>.<br> <br> The constant buffer
              sequence <code class="computeroutput"><span class="identifier">cb</span></code> specifies
              memory where the data to be written is located. The operation shall
              always write a buffer in the sequence completely before proceeding
              to the next.<br> <br> If successful, returns the number of bytes
              written. Otherwise returns <code class="computeroutput"><span class="number">0</span></code>.
              If the total size of all buffers in the sequence <code class="computeroutput"><span class="identifier">cb</span></code>
              is <code class="computeroutput"><span class="number">0</span></code>, the function shall
              return <code class="computeroutput"><span class="number">0</span></code> immediately.
            </p>
            </td>
</tr>
<tr>
<td>
            <p>
              <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">async_send</span><span class="special">(</span><span class="identifier">b</span><span class="special">,</span> <span class="identifier">cb</span><span class="special">,</span> <span class="identifier">f</span><span class="special">,</span> <span class="identifier">wh</span><span class="special">);</span></code>
            </p>
            </td>
<td>
            <p>
              <code class="computeroutput"><span class="keyword">void</span></code>
            </p>
            </td>
<td>
            <p>
              pre: <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">is_open</span><span class="special">(</span><span class="identifier">b</span><span class="special">)</span></code>.<br>
              <br> Initiates an asynchronous operation to write one or more bytes
              of data to a connected socket <code class="computeroutput"><span class="identifier">b</span></code>.
              The operation is performed via the <code class="computeroutput"><span class="identifier">io_service</span></code>
              object <code class="computeroutput"><span class="identifier">a</span><span class="special">.</span><span class="identifier">io_service</span><span class="special">()</span></code>
              and behaves according to <a class="link" href="asynchronous_operations.html" title="Requirements on asynchronous operations">asynchronous
              operation</a> requirements.<br> <br> The constant buffer sequence
              <code class="computeroutput"><span class="identifier">cb</span></code> specifies memory
              where the data to be written is located. The operation shall always
              write a buffer in the sequence completely before proceeding to the
              next.<br> <br> The implementation shall maintain one or more copies
              of <code class="computeroutput"><span class="identifier">cb</span></code> until such time
              as the write operation no longer requires access to the memory specified
              by the buffers in the sequence. The program must ensure the memory
              is valid until:<br> <br> &#8212; the last copy of <code class="computeroutput"><span class="identifier">cb</span></code>
              is destroyed, or<br> <br> &#8212; the handler for the asynchronous operation
              is invoked,<br> <br> whichever comes first. If the total size of
              all buffers in the sequence <code class="computeroutput"><span class="identifier">cb</span></code>
              is <code class="computeroutput"><span class="number">0</span></code>, the asynchronous
              operation shall complete immediately and pass <code class="computeroutput"><span class="number">0</span></code>
              as the argument to the handler that specifies the number of bytes read.<br>
              <br> If the operation completes successfully, the <code class="computeroutput"><span class="identifier">WriteHandler</span></code>
              object <code class="computeroutput"><span class="identifier">wh</span></code> is invoked
              with the number of bytes transferred. Otherwise it is invoked with
              <code class="computeroutput"><span class="number">0</span></code>.
            </p>
            </td>
</tr>
</tbody>
</table></div>
</div>
<br class="table-break">
</div>
<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
<td align="left"></td>
<td align="right"><div class="copyright-footer">Copyright &#169; 2003 - 2010 Christopher M. Kohlhoff<p>
        Distributed under the Boost Software License, Version 1.0. (See accompanying
        file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
      </p>
</div></td>
</tr></table>
<hr>
<div class="spirit-nav">
<a accesskey="p" href="StreamHandleService.html"><img src="../../../../doc/html/images/prev.png" alt="Prev"></a><a accesskey="u" href="../reference.html"><img src="../../../../doc/html/images/up.png" alt="Up"></a><a accesskey="h" href="../../boost_asio.html"><img src="../../../../doc/html/images/home.png" alt="Home"></a><a accesskey="n" href="SyncRandomAccessReadDevice.html"><img src="../../../../doc/html/images/next.png" alt="Next"></a>
</div>
</body>
</html>