|  | 
typedef basic_raw_socket< icmp > socket;
| Name | Description | 
|---|---|
| Rebinds the socket type to another executor. | |
| Socket option to permit sending of broadcast messages. | |
| IO control command to get the amount of data that can be read without blocking. | |
| Socket option to enable socket-level debugging. | |
| Socket option to prevent routing, use local interfaces only. | |
| Socket option to report aborted connections on accept. | |
| The endpoint type. | |
| The type of the executor associated with the object. | |
| Socket option to send keep-alives. | |
| Socket option to specify whether the socket lingers on close if unsent data is present. | |
| A basic_socket is always the lowest layer. | |
| Bitmask type for flags that can be passed to send and receive operations. | |
| The native representation of a socket. | |
| Socket option for putting received out-of-band data inline. | |
| The protocol type. | |
| Socket option for the receive buffer size of a socket. | |
| Socket option for the receive low watermark. | |
| Socket option to allow the socket to be bound to an address that is already in use. | |
| Socket option for the send buffer size of a socket. | |
| Socket option for the send low watermark. | |
| Different ways a socket may be shutdown. | |
| Wait types. | 
| Name | Description | 
|---|---|
| Assign an existing native socket to the socket. | |
| Start an asynchronous connect. | |
| Start an asynchronous receive on a connected socket. | |
| Start an asynchronous receive. | |
| Start an asynchronous send on a connected socket. | |
| Start an asynchronous send. | |
| Asynchronously wait for the socket to become ready to read, ready to write, or to have pending error conditions. | |
| Determine whether the socket is at the out-of-band data mark. | |
| Determine the number of bytes available for reading. | |
| basic_raw_socket [constructor] | 
                    Construct a basic_raw_socket without opening it.  | 
| Bind the socket to the given local endpoint. | |
| Cancel all asynchronous operations associated with the socket. | |
| Close the socket. | |
| Connect the socket to the specified endpoint. | |
| Get the executor associated with the object. | |
| Get an option from the socket. | |
| Perform an IO control command on the socket. | |
| Determine whether the socket is open. | |
| Get the local endpoint of the socket. | |
| 
                    Get a reference to the lowest layer.  | |
| Get the native socket representation. | |
| 
                    Gets the non-blocking mode of the native socket implementation.
                     | |
| 
                    Gets the non-blocking mode of the socket.  | |
| Open the socket using the specified protocol. | |
| 
                    Move-assign a basic_raw_socket from another.  | |
| Receive some data on a connected socket. | |
| Receive raw data with the endpoint of the sender. | |
| Release ownership of the underlying native socket. | |
| Get the remote endpoint of the socket. | |
| Send some data on a connected socket. | |
| Send raw data to the specified endpoint. | |
| Set an option on the socket. | |
| Disable sends or receives on the socket. | |
| Wait for the socket to become ready to read, ready to write, or to have pending error conditions. | |
| ~basic_raw_socket [destructor] | Destroys the socket. | 
| Name | Description | 
|---|---|
| max_listen_connections [static] | The maximum length of the queue of pending incoming connections. | 
| message_do_not_route [static] | Specify that the data should not be subject to routing. | 
| message_end_of_record [static] | Specifies that the data marks the end of a record. | 
| message_out_of_band [static] | Process out-of-band data. | 
| message_peek [static] | Peek at incoming data without removing it from the input queue. | 
          The basic_raw_socket
          class template provides asynchronous and blocking raw-oriented socket functionality.
        
Distinct objects: Safe.
Shared objects: Unsafe.
          Synchronous send, send_to, receive,
          receive_from, connect, and shutdown
          operations are thread safe with respect to each other, if the underlying
          operating system calls are also thread safe. This means that it is permitted
          to perform concurrent calls to these synchronous operations on a single
          socket object. Other synchronous operations, such as open
          or close, are not thread
          safe.
        
          Header: asio/ip/icmp.hpp
        
          Convenience header: asio.hpp