| 
 | 
 | ||||||||||||||||
RoutingSocket class opens a routing socket and forwards data arriving on the socket to RoutingSocketObservers. The RoutingSocket hooks itself into the EventLoop and activity usually happens asynchronously.
| RoutingSocket (EventLoop& e) | RoutingSocket | 
| ~RoutingSocket () | ~RoutingSocket | 
| int  start (int af = AF_UNSPEC) | start | 
Start the routing socket operation.
Parameters:
| af | the address family. | 
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int  stop () | stop | 
Stop the routing socket operation.
Returns: XORP_OK on success, otherwise XORP_ERROR.
| inline bool  is_open () | is_open | 
[const]
Test if the routing socket is open.
This method is needed because RoutingSocket may fail to open routing socket during construction.
Returns: true if the routing socket is open, otherwise false.
| ssize_t  write (const void* data, size_t nbytes) | write | 
Write data to routing socket.
This method also updates the sequence number associated with this routing socket.
Returns: the number of bytes which were written, or -1 if error.
| inline uint32_t  seqno () | seqno | 
[const]
Get the sequence number for next message written into the kernel.
The sequence number is derived from the instance number of this routing socket and a 16-bit counter.
Returns: the sequence number for the next message written into the kernel.
| inline pid_t  pid () | pid | 
[const]
Get the cached process identifier value.
Returns: the cached process identifier value.
| void  force_read () | force_read | 
Force socket to read data.
This usually is performed after writing a request that the kernel will answer (e.g., after writing a route lookup). Use sparingly, with caution, and at your own risk.