/* -*- C++ -*- */ // $Id$ // =========================================================================== // // = LIBRARY // ace // // = FILENAME // SOCK_Dgram.h // // = AUTHOR // Doug Schmidt // // =========================================================================== #ifndef ACE_SOCK_DGRAM_H #define ACE_SOCK_DGRAM_H #include "ace/SOCK.h" #include "ace/Addr.h" #if !defined (ACE_LACKS_PRAGMA_ONCE) #pragma once #endif /* ACE_LACKS_PRAGMA_ONCE */ class ACE_Export ACE_SOCK_Dgram : public ACE_SOCK { // = TITLE // Defines the member functions for the ACE_SOCK datagram // abstraction. public: // = Initialization routines. ACE_SOCK_Dgram (void); // Default constructor. ACE_SOCK_Dgram (const ACE_Addr &local, int protocol_family = PF_INET, int protocol = 0, int reuse_addr = 0); // Initiate a socket dgram. ~ACE_SOCK_Dgram (void); // Default dtor. int open (const ACE_Addr &local, int protocol_family = PF_INET, int protocol = 0, int reuse_addr = 0); // Initiate a socket dgram. // = Data transfer routines. ssize_t send (const void *buf, size_t n, const ACE_Addr &addr, int flags = 0) const; // Send an byte to the datagram socket (uses sendto(3)). ssize_t recv (void *buf, size_t n, ACE_Addr &addr, int flags = 0) const; // Receive an byte from the datagram socket (uses // recvfrom(3)). ssize_t recv (iovec *io_vec, ACE_Addr &addr, int flags = 0) const; // Allows a client to read from a socket without having to provide a // buffer to read. This method determines how much data is in the // socket, allocates a buffer of this size, reads in the data, and // returns the number of bytes read. The caller is responsible for // deleting the member in the field of using the // ``delete []'' syntax. ssize_t send (const iovec iov[], size_t n, const ACE_Addr &addr, int flags = 0) const; // Send an of size to the datagram socket (uses // sendmsg(3)). ssize_t recv (iovec iov[], size_t n, ACE_Addr &addr, int flags = 0) const; // Recv an of size to the datagram socket (uses // recvmsg(3)). ssize_t recv (void *buf, size_t n, ACE_Addr &addr, int flags, const ACE_Time_Value *timeout) const; // Wait up to amount of time to receive a datagram into // . The indicates how long to blocking // trying to receive. If == 0, the caller will block // until action is possible, else will wait until the relative time // specified in * elapses). If times out a -1 is // returned with . If it succeeds the number of // bytes received is returned. void dump (void) const; // Dump the state of an object. ACE_ALLOC_HOOK_DECLARE; // Declare the dynamic allocation hooks. protected: int shared_open (const ACE_Addr &local, int protocol_family); // Open is shared by this and by . private: int get_remote_addr (ACE_Addr &) const; // Do not allow this function to percolate up to this interface... }; #if !defined (ACE_LACKS_INLINE_FUNCTIONS) #include "ace/SOCK_Dgram.i" #endif #endif /* ACE_SOCK_DGRAM_H */