|
|
| version 1.11, 2012/05/14 12:49:21 | version 1.13, 2012/05/19 00:00:12 |
|---|---|
| Line 420 io_n2port(io_sockaddr_t * __restrict addr) | Line 420 io_n2port(io_sockaddr_t * __restrict addr) |
| case AF_INET6: | case AF_INET6: |
| return ntohs(addr->sin6.sin6_port); | return ntohs(addr->sin6.sin6_port); |
| default: | default: |
| io_SetErr(ESOCKTNOSUPPORT, "Unsuported address family %d", | |
| addr->sa.sa_family); | |
| break; | break; |
| } | } |
| Line 444 io_n2addr(io_sockaddr_t * __restrict addr, ait_val_t * | Line 442 io_n2addr(io_sockaddr_t * __restrict addr, ait_val_t * |
| if (!addr || !val) | if (!addr || !val) |
| return ret; | return ret; |
| AIT_INIT_VAL(val); | |
| switch (addr->sa.sa_family) { | switch (addr->sa.sa_family) { |
| case AF_INET: | case AF_INET: |
| if (!inet_ntop(AF_INET, &addr->sin.sin_addr, str, INET_ADDRSTRLEN)) { | if (!inet_ntop(AF_INET, &addr->sin.sin_addr, str, INET_ADDRSTRLEN)) { |
| Line 459 io_n2addr(io_sockaddr_t * __restrict addr, ait_val_t * | Line 458 io_n2addr(io_sockaddr_t * __restrict addr, ait_val_t * |
| } else | } else |
| ret = str; | ret = str; |
| break; | break; |
| case AF_LOCAL: | |
| ret = addr->sun.sun_path; | |
| break; | |
| default: | default: |
| io_SetErr(EPROTONOSUPPORT, "Unsuported address family %d", | io_SetErr(EPROTONOSUPPORT, "Unsuported address family %d", |
| addr->sa.sa_family); | addr->sa.sa_family); |
| Line 480 io_n2addr(io_sockaddr_t * __restrict addr, ait_val_t * | Line 482 io_n2addr(io_sockaddr_t * __restrict addr, ait_val_t * |
| io_sockaddr_t * | io_sockaddr_t * |
| io_gethostbyname(const char *psHost, u_short port, io_sockaddr_t * __restrict addr) | io_gethostbyname(const char *psHost, u_short port, io_sockaddr_t * __restrict addr) |
| { | { |
| struct hostent *host; | struct hostent *host = NULL; |
| if (!psHost || !addr) | if (!psHost || !addr) |
| return NULL; | return NULL; |
| /* resolver */ | |
| if (!addr->sa.sa_family) | |
| host = gethostbyname(psHost); | |
| else | else |
| host = gethostbyname2(psHost, addr->sa.sa_family); | memset(addr, 0, sizeof(io_sockaddr_t)); |
| if (!host) { | |
| io_SetErr(EINVAL, "Resolver #%d - %s", h_errno, hstrerror(h_errno)); | |
| return NULL; | |
| } | |
| memset(addr, 0, sizeof(io_sockaddr_t)); | if (*psHost != '/') { |
| switch (host->h_addrtype) { | /* resolver */ |
| if (!addr->sa.sa_family) | |
| host = gethostbyname(psHost); | |
| else | |
| host = gethostbyname2(psHost, addr->sa.sa_family); | |
| if (!host) { | |
| io_SetErr(EINVAL, "Resolver #%d - %s", h_errno, hstrerror(h_errno)); | |
| return NULL; | |
| } else | |
| addr->sa.sa_family = host->h_addrtype; | |
| } else | |
| addr->sa.sa_family = AF_LOCAL; | |
| switch (addr->sa.sa_family) { | |
| case AF_INET: | case AF_INET: |
| addr->sin.sin_len = sizeof(struct sockaddr_in); | addr->sin.sin_len = sizeof(struct sockaddr_in); |
| addr->sin.sin_family = AF_INET; | addr->sin.sin_family = AF_INET; |
| Line 509 io_gethostbyname(const char *psHost, u_short port, io_ | Line 516 io_gethostbyname(const char *psHost, u_short port, io_ |
| addr->sin6.sin6_port = htons(port); | addr->sin6.sin6_port = htons(port); |
| memcpy(&addr->sin6.sin6_addr, host->h_addr, sizeof addr->sin6.sin6_addr); | memcpy(&addr->sin6.sin6_addr, host->h_addr, sizeof addr->sin6.sin6_addr); |
| return addr; | return addr; |
| case AF_LOCAL: | |
| addr->sun.sun_len = sizeof(struct sockaddr_un); | |
| addr->sun.sun_family = AF_LOCAL; | |
| memset(addr->sun.sun_path, 0, sizeof addr->sun.sun_path); | |
| snprintf(addr->sun.sun_path, sizeof addr->sun.sun_path, "%s-%hu", psHost, port); | |
| return addr; | |
| default: | default: |
| io_SetErr(EPROTONOSUPPORT, "Unsuported address family %d", | io_SetErr(EPROTONOSUPPORT, "Unsuported address family %d", addr->sa.sa_family); |
| host->h_addrtype); | |
| break; | break; |
| } | } |