diff options
| author | Tomoyuki Sahara <[email protected]> | 2016-01-18 16:12:35 +0900 |
|---|---|---|
| committer | Tomoyuki Sahara <[email protected]> | 2016-01-18 16:12:35 +0900 |
| commit | c165e501932f8a3bf542d7643fc56713d3aedb7e (patch) | |
| tree | 42fb1a0b9cd2b839a2fabfc5a7b55ecf3c6aaec3 /src | |
| parent | a25ec0a749ea5540c0875eb7aa35f75230d7eeb9 (diff) | |
| parent | bdc118304c6076f1e338201d4c2b410f21894f93 (diff) | |
| download | mruby-c165e501932f8a3bf542d7643fc56713d3aedb7e.tar.gz mruby-c165e501932f8a3bf542d7643fc56713d3aedb7e.zip | |
Merge pull request #28 from zzak/port-ntop-pton-win32
Port inet_ntop and inet_pton for WIN32
Diffstat (limited to 'src')
| -rw-r--r-- | src/socket.c | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/src/socket.c b/src/socket.c index 0a4efcd87..142562de2 100644 --- a/src/socket.c +++ b/src/socket.c @@ -41,6 +41,59 @@ #define mrb_cptr_p(o) mrb_voidp_p(o) #endif +#ifdef _WIN32 +const char *inet_ntop(int af, const void *src, char *dst, socklen_t cnt) +{ + if (af == AF_INET) + { + struct sockaddr_in in; + memset(&in, 0, sizeof(in)); + in.sin_family = AF_INET; + memcpy(&in.sin_addr, src, sizeof(struct in_addr)); + getnameinfo((struct sockaddr *)&in, sizeof(struct + sockaddr_in), dst, cnt, NULL, 0, NI_NUMERICHOST); + return dst; + } + else if (af == AF_INET6) + { + struct sockaddr_in6 in; + memset(&in, 0, sizeof(in)); + in.sin6_family = AF_INET6; + memcpy(&in.sin6_addr, src, sizeof(struct in_addr6)); + getnameinfo((struct sockaddr *)&in, sizeof(struct + sockaddr_in6), dst, cnt, NULL, 0, NI_NUMERICHOST); + return dst; + } + return NULL; +} + +int inet_pton(int af, const char *src, void *dst) +{ + struct addrinfo hints, *res, *ressave; + + memset(&hints, 0, sizeof(struct addrinfo)); + hints.ai_family = af; + + if (getaddrinfo(src, NULL, &hints, &res) != 0) + { + printf("Couldn't resolve host %s\n", src); + return -1; + } + + ressave = res; + + while (res) + { + memcpy(dst, res->ai_addr, res->ai_addrlen); + res = res->ai_next; + } + + freeaddrinfo(ressave); + return 0; +} + +#endif + static mrb_value mrb_addrinfo_getaddrinfo(mrb_state *mrb, mrb_value klass) { |
