Source: ../../xrl/targets/socket_server_base.hh
|
|
|
|
/*
* Copyright (c) 2001-2005 International Computer Science Institute
* See LICENSE file for licensing, conditions, and warranties on use.
*
* DO NOT EDIT THIS FILE - IT IS PROGRAMMATICALLY GENERATED
*
* Generated by 'tgt-gen'.
*
* $XORP: xorp/xrl/targets/socket_server_base.hh,v 1.8 2005/03/25 02:55:09 pavlin Exp $
*/
#ifndef __XRL_INTERFACES_SOCKET_SERVER_BASE_HH__
#define __XRL_INTERFACES_SOCKET_SERVER_BASE_HH__
#undef XORP_LIBRARY_NAME
#define XORP_LIBRARY_NAME "XrlSocketServerTarget"
#include "libxorp/xlog.h"
#include "libxipc/xrl_cmd_map.hh"
class XrlSocketServerTargetBase {
protected:
XrlCmdMap* _cmds;
public:
/**
* Constructor.
*
* @param cmds an XrlCmdMap that the commands associated with the target
* should be added to. This is typically the XrlRouter
* associated with the target.
*/
XrlSocketServerTargetBase(XrlCmdMap* cmds = 0);
/**
* Destructor.
*
* Dissociates instance commands from command map.
*/
virtual ~XrlSocketServerTargetBase();
/**
* Set command map.
*
* @param cmds pointer to command map to associate commands with. This
* argument is typically a pointer to the XrlRouter associated with the
* target.
*
* @return true on success, false if cmds is null or a command map has
* already been supplied.
*/
bool set_command_map(XrlCmdMap* cmds);
/**
* Get Xrl instance name associated with command map.
*/
inline const string& name() const { return _cmds->name(); }
/**
* Get version string of instance.
*/
inline const char* version() const { return "socket_server/0.0"; }
protected:
/**
* Pure-virtual function that needs to be implemented to:
*
* Get name of Xrl Target
*/
virtual XrlCmdError common_0_1_get_target_name(
// Output values,
string& name) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Get version string from Xrl Target
*/
virtual XrlCmdError common_0_1_get_version(
// Output values,
string& version) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Get status of Xrl Target
*/
virtual XrlCmdError common_0_1_get_status(
// Output values,
uint32_t& status,
string& reason) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Request clean shutdown of Xrl Target
*/
virtual XrlCmdError common_0_1_shutdown() = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Announce target birth to observer.
*
* @param target_class the target class name.
*
* @param target_instance the target instance name.
*/
virtual XrlCmdError finder_event_observer_0_1_xrl_target_birth(
// Input values,
const string& target_class,
const string& target_instance) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Announce target death to observer.
*
* @param target_class the target class name.
*
* @param target_instance the target instance name.
*/
virtual XrlCmdError finder_event_observer_0_1_xrl_target_death(
// Input values,
const string& target_class,
const string& target_instance) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound TCP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket4_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket4_0_1_tcp_open_and_bind(
// Input values,
const string& creator,
const IPv4& local_addr,
const uint32_t& local_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound UDP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket4_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket4_0_1_udp_open_and_bind(
// Input values,
const string& creator,
const IPv4& local_addr,
const uint32_t& local_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound UDP multicast socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket4_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param mcast_addr the multicast group address to join.
*
* @param ttl the ttl to use for this multicast socket.
*
* @param reuse allow other sockets to bind to same multicast group.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket4_0_1_udp_open_bind_join(
// Input values,
const string& creator,
const IPv4& local_addr,
const uint32_t& local_port,
const IPv4& mcast_addr,
const uint32_t& ttl,
const bool& reuse,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound and connected TCP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket4_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param remote_addr the address to connect to.
*
* @param remote_port the remote port to connect to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket4_0_1_tcp_open_bind_connect(
// Input values,
const string& creator,
const IPv4& local_addr,
const uint32_t& local_port,
const IPv4& remote_addr,
const uint32_t& remote_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound and connected UDP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket4_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param remote_addr the address to connect to.
*
* @param remote_port the remote port to connect to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket4_0_1_udp_open_bind_connect(
// Input values,
const string& creator,
const IPv4& local_addr,
const uint32_t& local_port,
const IPv4& remote_addr,
const uint32_t& remote_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Join multicast group on already bound socket.
*
* @param sockid unique socket id.
*
* @param mcast_addr group to join.
*
* @param join_if_addr interface address to perform join on.
*/
virtual XrlCmdError socket4_0_1_udp_join_group(
// Input values,
const string& sockid,
const IPv4& mcast_addr,
const IPv4& join_if_addr) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Leave multicast group on already bound socket.
*
* @param sockid unique socket id.
*
* @param mcast_addr group to leave.
*
* @param leave_if_addr interface address to perform leave on.
*/
virtual XrlCmdError socket4_0_1_udp_leave_group(
// Input values,
const string& sockid,
const IPv4& mcast_addr,
const IPv4& leave_if_addr) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Close socket.
*
* @param sockid unique socket id of socket to be closed.
*/
virtual XrlCmdError socket4_0_1_close(
// Input values,
const string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Listen for inbound connections on socket. When a connection request
* received the socket creator will receive notification through
* socket4_user/0.1/connect_event.
*
* @param sockid the unique socket id of the socket to perform listen.
*
* @param backlog the maximum number of pending connections.
*/
virtual XrlCmdError socket4_0_1_tcp_listen(
// Input values,
const string& sockid,
const uint32_t& backlog) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket.
*
* @param sockid unique socket id.
*
* @param data block of data to be sent.
*/
virtual XrlCmdError socket4_0_1_send(
// Input values,
const string& sockid,
const vector<uint8_t>& data) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket with optional flags. These flags provide hints to
* the forwarding engine on how to send the packets, they are not
* guaranteed to work. NB: There is no flag for "do not route" as this is
* always true since the particular forwarding engine sending the data may
* not have access to the full routing table.
*
* @param sockid unique socket id.
*
* @param data block of data to be sent.
*
* @param out_of_band mark data as out of band.
*
* @param end_of_record data completes record.
*
* @param end_of_file data completes file.
*/
virtual XrlCmdError socket4_0_1_send_with_flags(
// Input values,
const string& sockid,
const vector<uint8_t>& data,
const bool& out_of_band,
const bool& end_of_record,
const bool& end_of_file) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket to a given destination. The packet is not routed as
* the forwarding engine sending the packet may not have access to the
* full routing table.
*
* @param sockid unique socket id.
*
* @param remote_addr destination address for data.
*
* @param remote_port destination port for data.
*
* @param data block of data to be sent.
*/
virtual XrlCmdError socket4_0_1_send_to(
// Input values,
const string& sockid,
const IPv4& remote_addr,
const uint32_t& remote_port,
const vector<uint8_t>& data) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket to a given destination. The packet is not routed as
* the forwarding engine sending the packet may not have access to the
* full routing table.
*
* @param sockid unique socket id.
*
* @param remote_addr destination address for data.
*
* @param remote_port destination port for data.
*
* @param data block of data to be sent.
*
* @param out_of_band mark data as out of band.
*
* @param end_of_record data completes record.
*
* @param end_of_file data completes file.
*/
virtual XrlCmdError socket4_0_1_send_to_with_flags(
// Input values,
const string& sockid,
const IPv4& remote_addr,
const uint32_t& remote_port,
const vector<uint8_t>& data,
const bool& out_of_band,
const bool& end_of_record,
const bool& end_of_file) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket to a given multicast group from a given interface.
*
* @param sockid unique socket id.
*
* @param group_addr destination address for data.
*
* @param group_port destination port for data.
*
* @param ifaddr interface address
*/
virtual XrlCmdError socket4_0_1_send_from_multicast_if(
// Input values,
const string& sockid,
const IPv4& group_addr,
const uint32_t& group_port,
const IPv4& ifaddr,
const vector<uint8_t>& data) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Set a named socket option.
*
* @param sockid unique socket id.
*
* @param optname name of option to be set. Valid values are:
* "multicast_loopback" "multicast_ttl"
*
* @param optval value of option to be set. If value is logically boolean
* then zero represents false and any non-zero value true.
*/
virtual XrlCmdError socket4_0_1_set_socket_option(
// Input values,
const string& sockid,
const string& optname,
const uint32_t& optval) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Get a named socket option.
*
* @param sockid unique socket id.
*
* @param optname name of option to be set. Valid values are documented in
* set_socket_option.
*
* @param optval value of option to be set. If value is logically boolean
* then zero represents false and any non-zero value true.
*/
virtual XrlCmdError socket4_0_1_get_socket_option(
// Input values,
const string& sockid,
const string& optname,
// Output values,
uint32_t& optval) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound TCP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket6_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket6_0_1_tcp_open_and_bind(
// Input values,
const string& creator,
const IPv6& local_addr,
const uint32_t& local_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound UDP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket6_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket6_0_1_udp_open_and_bind(
// Input values,
const string& creator,
const IPv6& local_addr,
const uint32_t& local_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound UDP multicast socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket6_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param mcast_addr the multicast group address to join.
*
* @param ttl the ttl to use for this multicast socket.
*
* @param reuse allow other sockets to bind to same multicast group.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket6_0_1_udp_open_bind_join(
// Input values,
const string& creator,
const IPv6& local_addr,
const uint32_t& local_port,
const IPv6& mcast_addr,
const uint32_t& ttl,
const bool& reuse,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound and connected TCP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket6_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param remote_addr the address to connect to.
*
* @param remote_port the remote port to connect to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket6_0_1_tcp_open_bind_connect(
// Input values,
const string& creator,
const IPv6& local_addr,
const uint32_t& local_port,
const IPv6& remote_addr,
const uint32_t& remote_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Create a bound and connected UDP socket.
*
* @param creator the Xrl Target instance name of the socket creator. The
* named target must implement socket6_user/0.1.
*
* @param local_addr the interface address to bind socket to.
*
* @param local_port the port to bind socket to.
*
* @param remote_addr the address to connect to.
*
* @param remote_port the remote port to connect to.
*
* @param is_blocking if true then the socket will be blocking, otherwise
* non-blocking.
*
* @param sockid return parameter that contains unique socket id when
* socket instantiation is successful.
*/
virtual XrlCmdError socket6_0_1_udp_open_bind_connect(
// Input values,
const string& creator,
const IPv6& local_addr,
const uint32_t& local_port,
const IPv6& remote_addr,
const uint32_t& remote_port,
const bool& is_blocking,
// Output values,
string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Join multicast group on already bound socket.
*
* @param sockid unique socket id.
*
* @param mcast_addr group to join.
*
* @param join_if_addr interface address to perform join on.
*/
virtual XrlCmdError socket6_0_1_udp_join_group(
// Input values,
const string& sockid,
const IPv6& mcast_addr,
const IPv6& join_if_addr) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Leave multicast group on already bound socket.
*
* @param sockid unique socket id.
*
* @param mcast_addr group to leave.
*
* @param leave_if_addr interface address to perform leave on.
*/
virtual XrlCmdError socket6_0_1_udp_leave_group(
// Input values,
const string& sockid,
const IPv6& mcast_addr,
const IPv6& leave_if_addr) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Close socket.
*
* @param sockid unique socket id of socket to be closed.
*/
virtual XrlCmdError socket6_0_1_close(
// Input values,
const string& sockid) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Listen for inbound connections on socket. When a connection request
* received the socket creator will receive notification through
* socket6_user/0.1/connect_event.
*
* @param sockid the unique socket id of the socket to perform listen.
*
* @param backlog the maximum number of pending connections.
*/
virtual XrlCmdError socket6_0_1_tcp_listen(
// Input values,
const string& sockid,
const uint32_t& backlog) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket.
*
* @param sockid unique socket id.
*
* @param data block of data to be sent.
*/
virtual XrlCmdError socket6_0_1_send(
// Input values,
const string& sockid,
const vector<uint8_t>& data) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket with optional flags. These flags provide hints to
* the forwarding engine on how to send the packets, they are not
* guaranteed to work. NB: There is no flag for "do not route" as this is
* always true since the particular forwarding engine sending the data may
* not have access to the full routing table.
*
* @param sockid unique socket id.
*
* @param data block of data to be sent.
*
* @param out_of_band mark data as out of band.
*
* @param end_of_record data completes record.
*
* @param end_of_file data completes file.
*/
virtual XrlCmdError socket6_0_1_send_with_flags(
// Input values,
const string& sockid,
const vector<uint8_t>& data,
const bool& out_of_band,
const bool& end_of_record,
const bool& end_of_file) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket to a given destination. The packet is not routed as
* the forwarding engine sending the packet may not have access to the
* full routing table.
*
* @param sockid unique socket id.
*
* @param remote_addr destination address for data.
*
* @param remote_port destination port for data.
*
* @param data block of data to be sent.
*/
virtual XrlCmdError socket6_0_1_send_to(
// Input values,
const string& sockid,
const IPv6& remote_addr,
const uint32_t& remote_port,
const vector<uint8_t>& data) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket to a given destination. The packet is not routed as
* the forwarding engine sending the packet may not have access to the
* full routing table.
*
* @param sockid unique socket id.
*
* @param remote_addr destination address for data.
*
* @param remote_port destination port for data.
*
* @param data block of data to be sent.
*
* @param out_of_band mark data as out of band.
*
* @param end_of_record data completes record.
*
* @param end_of_file data completes file.
*/
virtual XrlCmdError socket6_0_1_send_to_with_flags(
// Input values,
const string& sockid,
const IPv6& remote_addr,
const uint32_t& remote_port,
const vector<uint8_t>& data,
const bool& out_of_band,
const bool& end_of_record,
const bool& end_of_file) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Send data on socket to a given multicast group from a given interface.
*
* @param sockid unique socket id.
*
* @param group_addr destination address for data.
*
* @param group_port destination port for data.
*
* @param ifaddr interface address
*/
virtual XrlCmdError socket6_0_1_send_from_multicast_if(
// Input values,
const string& sockid,
const IPv6& group_addr,
const uint32_t& group_port,
const IPv6& ifaddr,
const vector<uint8_t>& data) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Set a named socket option.
*
* @param sockid unique socket id.
*
* @param optname name of option to be set. Valid values are:
* "multicast_loopback" "multicast_hops"
*
* @param optval value of option to be set. If value is logically boolean
* then zero represents false and any non-zero value true.
*/
virtual XrlCmdError socket6_0_1_set_socket_option(
// Input values,
const string& sockid,
const string& optname,
const uint32_t& optval) = 0;
/**
* Pure-virtual function that needs to be implemented to:
*
* Get a named socket option.
*
* @param sockid unique socket id.
*
* @param optname name of option to be set. Valid values are documented in
* set_socket_option.
*
* @param optval value of option to be set. If value is logically boolean
* then zero represents false and any non-zero value true.
*/
virtual XrlCmdError socket6_0_1_get_socket_option(
// Input values,
const string& sockid,
const string& optname,
// Output values,
uint32_t& optval) = 0;
private:
const XrlCmdError handle_common_0_1_get_target_name(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_common_0_1_get_version(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_common_0_1_get_status(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_common_0_1_shutdown(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_finder_event_observer_0_1_xrl_target_birth(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_finder_event_observer_0_1_xrl_target_death(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_tcp_open_and_bind(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_udp_open_and_bind(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_udp_open_bind_join(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_tcp_open_bind_connect(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_udp_open_bind_connect(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_udp_join_group(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_udp_leave_group(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_close(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_tcp_listen(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_send(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_send_with_flags(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_send_to(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_send_to_with_flags(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_send_from_multicast_if(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_set_socket_option(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket4_0_1_get_socket_option(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_tcp_open_and_bind(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_udp_open_and_bind(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_udp_open_bind_join(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_tcp_open_bind_connect(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_udp_open_bind_connect(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_udp_join_group(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_udp_leave_group(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_close(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_tcp_listen(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_send(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_send_with_flags(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_send_to(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_send_to_with_flags(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_send_from_multicast_if(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_set_socket_option(const XrlArgs& in, XrlArgs* out);
const XrlCmdError handle_socket6_0_1_get_socket_option(const XrlArgs& in, XrlArgs* out);
void add_handlers();
void remove_handlers();
};
#endif /* __XRL_INTERFACES_SOCKET_SERVER_BASE_HH__ */
Generated by: pavlin on possum.icir.org on Thu Mar 9 04:42:51 2006, using kdoc $.