mirror of
https://gitlab.xiph.org/xiph/icecast-common.git
synced 2025-06-30 22:18:29 -04:00
Update: Added igloo_error_t argument to igloo_socket_new()
This commit is contained in:
parent
0150c49f73
commit
ecc4e721fb
@ -69,7 +69,7 @@ typedef enum {
|
||||
igloo_SOCKET_ENDPOINT_PEER_LOGICAL
|
||||
} igloo_socket_endpoint_t;
|
||||
|
||||
igloo_socket_t * igloo_socket_new(igloo_socketaddr_domain_t domain, igloo_socketaddr_type_t type, igloo_socketaddr_protocol_t protocol, const char *name, igloo_ro_t associated, igloo_ro_t instance);
|
||||
igloo_socket_t * igloo_socket_new(igloo_socketaddr_domain_t domain, igloo_socketaddr_type_t type, igloo_socketaddr_protocol_t protocol, const char *name, igloo_ro_t associated, igloo_ro_t instance, igloo_error_t *error);
|
||||
igloo_socket_t * igloo_socket_new_simple(igloo_socket_endpoint_t endpoint, igloo_socketaddr_t *addr, igloo_error_t *error);
|
||||
igloo_error_t igloo_socket_alter_address(igloo_socket_t *sock, igloo_socket_addressop_t op, igloo_socket_endpoint_t endpoint, igloo_socketaddr_t *addr);
|
||||
igloo_socketaddr_t * igloo_socket_get_main_address(igloo_socket_t *sock, igloo_socket_endpoint_t endpoint, igloo_error_t *error);
|
||||
|
13
src/socket.c
13
src/socket.c
@ -263,12 +263,15 @@ static igloo_error_t __bind_or_connect(igloo_socket_t *sock, igloo_socketaddr_t
|
||||
}
|
||||
}
|
||||
|
||||
igloo_socket_t * igloo_socket_new(igloo_socketaddr_domain_t domain, igloo_socketaddr_type_t type, igloo_socketaddr_protocol_t protocol, const char *name, igloo_ro_t associated, igloo_ro_t instance)
|
||||
igloo_socket_t * igloo_socket_new(igloo_socketaddr_domain_t domain, igloo_socketaddr_type_t type, igloo_socketaddr_protocol_t protocol, const char *name, igloo_ro_t associated, igloo_ro_t instance, igloo_error_t *error)
|
||||
{
|
||||
igloo_socket_t *sock = igloo_ro_new_raw(igloo_socket_t, name, associated, instance);
|
||||
|
||||
if (!sock)
|
||||
if (!sock) {
|
||||
if (error)
|
||||
*error = igloo_ERROR_NOMEM;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
sock->domain = domain;
|
||||
sock->type = type;
|
||||
@ -277,6 +280,8 @@ igloo_socket_t * igloo_socket_new(igloo_socketaddr_domain_t domain, igloo_socket
|
||||
sock->syssock = socket(igloo_socketaddr_get_sysid_domain(domain), igloo_socketaddr_get_sysid_type(type), igloo_socketaddr_get_sysid_protocol(protocol));
|
||||
if (sock->syssock == -1) {
|
||||
igloo_ro_unref(sock);
|
||||
if (error)
|
||||
*error = igloo_ERROR_GENERIC;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
@ -298,10 +303,10 @@ igloo_socket_t * igloo_socket_new_simple(igloo_socket_endpoint_t endpoint, igloo
|
||||
return NULL;
|
||||
}
|
||||
|
||||
sock = igloo_socket_new(domain, type, protocol, NULL, igloo_RO_NULL, addr);
|
||||
sock = igloo_socket_new(domain, type, protocol, NULL, igloo_RO_NULL, addr, &err);
|
||||
if (!sock) {
|
||||
if (error)
|
||||
*error = igloo_ERROR_GENERIC;
|
||||
*error = err;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user