summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorTomoyuki Sahara <[email protected]>2016-01-18 16:12:35 +0900
committerTomoyuki Sahara <[email protected]>2016-01-18 16:12:35 +0900
commitc165e501932f8a3bf542d7643fc56713d3aedb7e (patch)
tree42fb1a0b9cd2b839a2fabfc5a7b55ecf3c6aaec3
parenta25ec0a749ea5540c0875eb7aa35f75230d7eeb9 (diff)
parentbdc118304c6076f1e338201d4c2b410f21894f93 (diff)
downloadmruby-c165e501932f8a3bf542d7643fc56713d3aedb7e.tar.gz
mruby-c165e501932f8a3bf542d7643fc56713d3aedb7e.zip
Merge pull request #28 from zzak/port-ntop-pton-win32
Port inet_ntop and inet_pton for WIN32
-rw-r--r--src/socket.c53
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)
{