Skip to content

socket_create

NAME

socket_create() - create an efun socket

SYNOPSIS

#include <socket_err.h>

int socket_create( int mode, string read_callback,
                   void | string close_callback );

DESCRIPTION

socket_create()  creates  an efun socket. mode determines which type of
socket is created. Currently supported socket modes are:

0  MUD             for sending LPC data types using TCP protocol.

1  STREAM          for sending raw data using TCP protocol.

2  DATAGRAM        for using UDP protocol.

3  STREAM_BINARY   for exchange binary message with TCP protocol.

4  DATAGRAM_BINARY for exchange binary message with UDP protocol.

The argument read_callback is the name of a function for the driver  to
call  when the socket gets data from its peer. The read callback should
follow this format:

    void read_callback(int fd, mixed message, string addr)

Where fd is the socket which received the data, and message is the data
which was received, addr is the client address.

In non-binary mode, message will be sanitized with UTF8 encoding and returned as an string.

In binary mode, raw messages will be returned as a buffer.

The argument close_callback is the name of a function for the driver to
call if the socket closes unexpectedly, i.e. not as  the  result  of  a
socket_close(3) call. The close callback should follow this format:

    void close_callback(int fd)

Where  fd  is the socket which has closed.  NOTE: close_callback is not
used with DATAGRAM mode sockets.

RETURN VALUES

socket_create() returns:

    a non-negative descriptor on success.

    a negative value indicated below on error.

ERRORS

EEMODENOTSUPP  Socket mode not supported.

EESOCKET       Problem creating socket.

EESETSOCKOPT   Problem with setsockopt.

EENONBLOCK     Problem setting non-blocking mode.

EENOSOCKS      No more available efun sockets.

EESECURITY     Security violation attempted.

SEE ALSO

socket_accept(3), socket_bind(3),  socket_close(3),  socket_connect(3),
socket_listen(3), socket_write(3)