|  |  |  | libnice Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Properties | ||||
#include <pseudotcp.h>
                    PseudoTcpSocket;
enum                PseudoTcpState;
enum                PseudoTcpWriteResult;
                    PseudoTcpCallbacks;
enum                PseudoTcpDebugLevel;
PseudoTcpSocket *   pseudo_tcp_socket_new               (guint32 conversation,
                                                         PseudoTcpCallbacks *callbacks);
gboolean            pseudo_tcp_socket_connect           (PseudoTcpSocket *self);
gint                pseudo_tcp_socket_recv              (PseudoTcpSocket *self,
                                                         char *buffer,
                                                         size_t len);
gint                pseudo_tcp_socket_send              (PseudoTcpSocket *self,
                                                         const char *buffer,
                                                         guint32 len);
void                pseudo_tcp_socket_close             (PseudoTcpSocket *self,
                                                         gboolean force);
int                 pseudo_tcp_socket_get_error         (PseudoTcpSocket *self);
gboolean            pseudo_tcp_socket_get_next_clock    (PseudoTcpSocket *self,
                                                         guint64 *timeout);
void                pseudo_tcp_socket_notify_clock      (PseudoTcpSocket *self);
void                pseudo_tcp_socket_notify_mtu        (PseudoTcpSocket *self,
                                                         guint16 mtu);
gboolean            pseudo_tcp_socket_notify_packet     (PseudoTcpSocket *self,
                                                         const gchar *buffer,
                                                         guint32 len);
void                pseudo_tcp_set_debug_level          (PseudoTcpDebugLevel level);
gint                pseudo_tcp_socket_get_available_bytes
                                                        (PseudoTcpSocket *self);
gboolean            pseudo_tcp_socket_can_send          (PseudoTcpSocket *self);
gsize               pseudo_tcp_socket_get_available_send_space
                                                        (PseudoTcpSocket *self);
gboolean            pseudo_tcp_socket_notify_message    (PseudoTcpSocket *self,
                                                         NiceInputMessage *message);
"ack-delay" guint : Read / Write "callbacks" gpointer : Read / Write "conversation" guint : Read / Write / Construct Only "no-delay" gboolean : Read / Write "rcv-buf" guint : Read / Write "snd-buf" guint : Read / Write "state" guint : Read
The PseudoTcpSocket is an object implementing a Pseudo Tcp Socket for use over UDP. The socket will implement a subset of the TCP stack to allow for a reliable transport over non-reliable sockets (such as UDP).
See the file tests/test-pseudotcp.c in the source package for an example of how to use the object.
typedef struct _PseudoTcpSocket PseudoTcpSocket;
The PseudoTcpSocket is the GObject implementing the Pseudo TCP Socket
Since 0.0.11
typedef enum {
  TCP_LISTEN,
  TCP_SYN_SENT,
  TCP_SYN_RECEIVED,
  TCP_ESTABLISHED,
  TCP_CLOSED
} PseudoTcpState;
An enum representing the state of the PseudoTcpSocket.
See also: "state"
| The socket's initial state. The socket isn't connected and is listening for an incoming connection | |
| The socket has sent a connection request (SYN) packet and is waiting for an answer | |
| The socket has received a connection request (SYN) packet. | |
| The socket is connected | |
| The socket has been closed | 
Since 0.0.11
typedef enum {
  WR_SUCCESS,
  WR_TOO_LARGE,
  WR_FAIL
} PseudoTcpWriteResult;
An enum representing the result value of the write operation requested by the PseudoTcpSocket.
 See also: PseudoTcpCallbacks:WritePacket 
| The write operation was successful | |
| The socket type requires that message be sent atomically and the size of the message to be sent made this impossible. | |
| There was an error sending the message | 
Since 0.0.11
typedef struct {
  gpointer user_data;
  void  (*PseudoTcpOpened) (PseudoTcpSocket *tcp, gpointer data);
  void  (*PseudoTcpReadable) (PseudoTcpSocket *tcp, gpointer data);
  void  (*PseudoTcpWritable) (PseudoTcpSocket *tcp, gpointer data);
  void  (*PseudoTcpClosed) (PseudoTcpSocket *tcp, guint32 error, gpointer data);
  PseudoTcpWriteResult (*WritePacket) (PseudoTcpSocket *tcp,
      const gchar * buffer, guint32 len, gpointer data);
} PseudoTcpCallbacks;
A structure containing callbacks functions that will be called by the PseudoTcpSocket when some events happen.
See also: PseudoTcpWriteResult
| A user defined pointer to be passed to the callbacks | |
| The PseudoTcpSocket is now connected | |
| The socket is readable | |
| The socket is writable | |
| The socket was closed | |
| This callback is called when the socket needs to send data. | 
Since 0.0.11
typedef enum {
  PSEUDO_TCP_DEBUG_NONE = 0,
  PSEUDO_TCP_DEBUG_NORMAL,
  PSEUDO_TCP_DEBUG_VERBOSE,
} PseudoTcpDebugLevel;
Valid values of debug levels to be set.
| Disable debug messages | |
| Enable basic debug messages | |
| Enable verbose debug messages | 
Since 0.0.11
PseudoTcpSocket * pseudo_tcp_socket_new (guint32 conversation,PseudoTcpCallbacks *callbacks);
Creates a new PseudoTcpSocket for the specified conversation
     The callbacks must be non-NULL, in order to get notified of packets the
     socket needs to send.
   
     If the callbacks structure was dynamicly allocated, it can be freed
     after the call pseudo_tcp_socket_new
   
| 
 | The conversation id for the socket. | 
| 
 | A pointer to the PseudoTcpCallbacks structure for getting notified of the PseudoTcpSocket events. | 
| Returns : | The new PseudoTcpSocket object, NULLon error | 
Since 0.0.11
gboolean            pseudo_tcp_socket_connect           (PseudoTcpSocket *self);
Connects the PseudoTcpSocket to the peer with the same conversation id.
The connection will only be successful after the
PseudoTcpCallbacks:PseudoTcpOpened callback is called
| 
 | The PseudoTcpSocket object. | 
| Returns : | TRUEon success,FALSEon failure (not inTCP_LISTENstate) See also:  | 
Since 0.0.11
gint pseudo_tcp_socket_recv (PseudoTcpSocket *self,char *buffer,size_t len);
Receive data from the socket.
     Only call this on the PseudoTcpCallbacks:PseudoTcpReadable callback.
   
     This function should be called in a loop. If this function does not
     return -1 with EWOULDBLOCK as the error, the
     PseudoTcpCallbacks:PseudoTcpReadable callback will not be called again.
   
| 
 | The PseudoTcpSocket object. | 
| 
 | The buffer to fill with received data | 
| 
 | The length of buffer | 
| Returns : | The number of bytes received or -1 in case of error  See also:  | 
Since 0.0.11
gint pseudo_tcp_socket_send (PseudoTcpSocket *self,const char *buffer,guint32 len);
Send data on the socket.
     If this function return -1 with EWOULDBLOCK as the error, or if the return
     value is lower than len, then the PseudoTcpCallbacks:PseudoTcpWritable
     callback will be called when the socket will become writable.
   
| 
 | The PseudoTcpSocket object. | 
| 
 | The buffer with data to send | 
| 
 | The length of buffer | 
| Returns : | The number of bytes sent or -1 in case of error  See also:  | 
Since 0.0.11
void pseudo_tcp_socket_close (PseudoTcpSocket *self,gboolean force);
Close the socket. IF force is set to FALSE, the socket will finish sending
pending data before closing.
     The PseudoTcpCallbacks:PseudoTcpClosed callback will not be called once
     the socket gets closed. It is only used for aborted connection.
     Instead, the socket gets closed when the pseudo_tcp_socket_get_next_clock()
     function returns FALSE.
   
 See also: pseudo_tcp_socket_get_next_clock() 
| 
 | The PseudoTcpSocket object. | 
| 
 | TRUEto close the socket forcefully,FALSEto close it gracefully | 
Since 0.0.11
int                 pseudo_tcp_socket_get_error         (PseudoTcpSocket *self);
Return the last encountered error.
The return value can be :
       EINVAL (for pseudo_tcp_socket_connect()).
     
       EWOULDBLOCK or ENOTCONN (for pseudo_tcp_socket_recv() and
       pseudo_tcp_socket_send()).
     
| 
 | The PseudoTcpSocket object. | 
| Returns : | The error code  See also:   See also:   See also:  | 
Since 0.0.11
gboolean pseudo_tcp_socket_get_next_clock (PseudoTcpSocket *self,guint64 *timeout);
Call this to determine the timeout needed before the next time call
to pseudo_tcp_socket_notify_clock() should be made.
| 
 | The PseudoTcpSocket object. | 
| 
 | A pointer to be filled with the new timeout. | 
| Returns : | TRUEiftimeoutwas filled,FALSEif the socket is closed and
ready to be destroyed. See also:  | 
Since 0.0.11
void                pseudo_tcp_socket_notify_clock      (PseudoTcpSocket *self);
Start the processing of receiving data, pending data or syn/acks.
Call this based on timeout value returned by
pseudo_tcp_socket_get_next_clock().
It's ok to call this too frequently.
 See also: pseudo_tcp_socket_get_next_clock() 
| 
 | The PseudoTcpSocket object. | 
Since 0.0.11
void pseudo_tcp_socket_notify_mtu (PseudoTcpSocket *self,guint16 mtu);
Set the MTU of the socket
| 
 | The PseudoTcpSocket object. | 
| 
 | The new MTU of the socket | 
Since 0.0.11
gboolean pseudo_tcp_socket_notify_packet (PseudoTcpSocket *self,const gchar *buffer,guint32 len);
Notify the PseudoTcpSocket when a new packet arrives
| 
 | The PseudoTcpSocket object. | 
| 
 | The buffer containing the received data | 
| 
 | The length of buffer | 
| Returns : | TRUEif the packet was processed successfully,FALSEotherwise | 
Since 0.0.11
void                pseudo_tcp_set_debug_level          (PseudoTcpDebugLevel level);
Sets the debug level to enable/disable normal/verbose debug messages.
| 
 | The level of debug to set | 
Since 0.0.11
gint                pseudo_tcp_socket_get_available_bytes
                                                        (PseudoTcpSocket *self);
Gets the number of bytes of data in the buffer that can be read without receiving more packets from the network.
| 
 | The PseudoTcpSocket object. | 
| Returns : | The number of bytes or -1 if the connection is not established | 
Since 0.1.5
gboolean            pseudo_tcp_socket_can_send          (PseudoTcpSocket *self);
Returns if there is space in the send buffer to send any data.
| 
 | The PseudoTcpSocket object. | 
| Returns : | TRUEif data can be sent,FALSEotherwise | 
Since 0.1.5
gsize               pseudo_tcp_socket_get_available_send_space
                                                        (PseudoTcpSocket *self);
Gets the number of bytes of space available in the transmission buffer.
| 
 | The PseudoTcpSocket object. | 
| Returns : | The numbero f bytes, or 0 if the connection is not established. | 
Since 0.1.5
gboolean pseudo_tcp_socket_notify_message (PseudoTcpSocket *self,NiceInputMessage *message);
Notify the PseudoTcpSocket that a new message has arrived, and enqueue the data in its buffers to the PseudoTcpSocket’s receive buffer.
| 
 | The PseudoTcpSocket object. | 
| 
 | A NiceInputMessage containing the received data. | 
| Returns : | TRUEif the packet was processed successfully,FALSEotherwise | 
Since 0.1.5
"ack-delay" property  "ack-delay"                guint                 : Read / Write
Delayed ACK timeout (in milliseconds).
Default value: 100
"callbacks" property  "callbacks"                gpointer              : Read / Write
Structure with the callbacks to call when PseudoTcp events happen.
"conversation" property  "conversation"             guint                 : Read / Write / Construct Only
The TCP Conversation ID.
Default value: 0
"no-delay" property  "no-delay"                 gboolean              : Read / Write
Disable the Nagle algorithm (like the TCP_NODELAY option).
Default value: FALSE
"rcv-buf" property  "rcv-buf"                  guint                 : Read / Write
Receive Buffer size.
Allowed values: >= 1
Default value: 61440
"snd-buf" property  "snd-buf"                  guint                 : Read / Write
Send Buffer size.
Allowed values: >= 1
Default value: 92160