#include #include #include #include #include "unix.h" #ifdef HAS_SOCKETS #include "socketaddr.h" #include static int entry_h_length; extern int socket_domain_table[]; static value alloc_one_addr(a) char * a; { bcopy(a, &sock_addr.s_inet.sin_addr, entry_h_length); return alloc_inet_addr(sock_addr.s_inet.sin_addr.s_addr); } static value alloc_host_entry(entry) struct hostent * entry; { value res; Push_roots(r, 4); r[0] = copy_string(entry->h_name); r[1] = copy_string_array(entry->h_aliases); entry_h_length = entry->h_length; #ifdef h_addr r[2] = alloc_array(alloc_one_addr, entry->h_addr_list); #else r[3] = alloc_one_addr(entry->h_addr); r[2] = alloc_tuple(1); Field(r[2], 0) = r[3]; #endif res = alloc_tuple(4); Field(res, 0) = r[0]; Field(res, 1) = r[1]; Field(res, 2) = entry->h_addrtype == PF_UNIX ? Atom(0) : Atom(1); Field(res, 3) = r[2]; Pop_roots(); return res; } value unix_gethostbyaddr(a) /* ML */ value a; { struct in_addr in_addr; struct hostent * entry; in_addr.s_addr = GET_INET_ADDR(a); entry = gethostbyaddr((char *) &in_addr, sizeof(in_addr), 0); if (entry == (struct hostent *) NULL) mlraise(Atom(NOT_FOUND_EXN)); return alloc_host_entry(entry); } value unix_gethostbyname(name) /* ML */ value name; { struct hostent * entry; entry = gethostbyname(String_val(name)); if (entry == (struct hostent *) NULL) mlraise(Atom(NOT_FOUND_EXN)); return alloc_host_entry(entry); } #else value unix_gethostbyaddr() { invalid_argument("gethostbyaddr not implemented"); } value unix_gethostbyname() { invalid_argument("gethostbyname not implemented"); } #endif