|  | Home | Libraries | People | FAQ | More | 
The stream type when rebound to the specified executor.
using other = stream< typename next_layer_type::template rebind_executor< Executor1 >::other, deflateSupported >;
| Name | Description | 
|---|---|
| The type of the executor associated with the object. | |
| Indicates if the permessage-deflate extension is supported. | |
| The type of the next layer. | |
| rebind_executor [constructor] | Rebinds the stream type to another executor. | 
| Name | Description | 
|---|---|
| 
                    Perform the WebSocket handshake in the server role.  | |
| Perform the WebSocket handshake asynchronously in the server role. | |
| Perform the WebSocket closing handshake asynchronously and close the underlying stream. | |
| Perform the WebSocket handshake asynchronously in the client role. | |
| Send a websocket ping control frame asynchronously. | |
| Send a websocket pong control frame asynchronously. | |
| Read a complete message asynchronously. | |
| Read some message data asynchronously. | |
| Write a complete message asynchronously. | |
| Write some message data asynchronously. | |
| 
                    Set the automatic fragmentation option.  | |
| 
                    Set the binary message write option.  | |
| Perform the WebSocket closing handshake and close the underlying stream. | |
| 
                    Set the compress message write option.  | |
| 
                    Set a callback to be invoked on each incoming control frame.
                     | |
| Get the executor associated with the object. | |
| 
                    Get the option value.  | |
| Get the status of the permessage-deflate extension. | |
| 
                    Returns  | |
| 
                    Returns  | |
| Perform the WebSocket handshake in the client role. | |
| 
                    Returns  | |
| 
                    Returns  | |
| Get a reference to the next layer. | |
| Move assignment (deleted) | |
| Send a websocket ping control frame. | |
| Send a websocket pong control frame. | |
| Read a complete message. | |
| 
                    Set the maximum incoming message size option.  | |
| Returns a suggested maximum buffer size for the next call to read. | |
| Read some message data. | |
| Returns the close reason received from the remote peer. | |
| Set whether the PRNG is cryptographically secure. | |
| 
                    Set the option value.  | |
| 
                    Constructor.  | |
| 
                    Set the text message write option.  | |
| Write a complete message. | |
| 
                    Set the write buffer size option.  | |
| Write some message data. | |
| ~stream [destructor] | Destructor. | 
          The stream class template provides
          asynchronous and blocking message-oriented functionality necessary for
          clients and servers to utilize the WebSocket protocol.
        
For asynchronous operations, the application must ensure that they are are all performed within the same implicit or explicit strand.
Distinctobjects:Safe.
Sharedobjects:Unsafe. The application must also ensure that all asynchronous operations are performed within the same implicit or explicit strand.
          To declare the stream object with a tcp_stream in a multi-threaded
          asynchronous program using a strand, you may write:
        
websocket::stream<tcp_stream> ws{net::make_strand(ioc)};
Alternatively, for a single-threaded or synchronous application you may write:
websocket::stream<tcp_stream> ws(ioc);
| Type | Description | 
|---|---|
| 
                     | The type representing the next layer, to which data will be read and written during operations. For synchronous operations, the type must support the SyncStream concept. For asynchronous operations, the type must support the AsyncStream concept. | 
| 
                     | 
                    A  | 
A stream object must not be moved or destroyed while there are pending asynchronous operations associated with it.
| Name | Description | 
|---|---|
| The stream type when rebound to the specified executor. |