blob: 096b28fe5030d58918e5c8298ea11717ed601ddf (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
#include <mlvalues.h>
#include <alloc.h>
#include <memory.h>
#include <fail.h>
#include "unix.h"
#ifdef HAS_SOCKETS
#include "socketaddr.h"
#include <netdb.h>
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
|