Don't include <sys/types.h>. Define socklen_t if not already happened.
[kopensolaris-gnu/glibc.git] / inet / arpa / inet.h
1 /* Copyright (C) 1997, 1999, 2000, 2001 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3
4    The GNU C Library is free software; you can redistribute it and/or
5    modify it under the terms of the GNU Library General Public License as
6    published by the Free Software Foundation; either version 2 of the
7    License, or (at your option) any later version.
8
9    The GNU C Library is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12    Library General Public License for more details.
13
14    You should have received a copy of the GNU Library General Public
15    License along with the GNU C Library; see the file COPYING.LIB.  If not,
16    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17    Boston, MA 02111-1307, USA.  */
18
19 #ifndef _ARPA_INET_H
20 #define _ARPA_INET_H    1
21
22 #include <features.h>
23 #include <netinet/in.h>         /* To define `struct in_addr'.  */
24
25 /* Type for length arguments in socket calls.  */
26 #ifndef __socklen_t_defined
27 typedef __socklen_t socklen_t;
28 # define __socklen_t_defined
29 #endif
30
31 __BEGIN_DECLS
32
33 /* Convert Internet host address from numbers-and-dots notation in CP
34    into binary data in network byte order.  */
35 extern in_addr_t inet_addr (__const char *__cp) __THROW;
36
37 /* Return the local host address part of the Internet address in IN.  */
38 extern in_addr_t inet_lnaof (struct in_addr __in) __THROW;
39
40 /* Make Internet host address in network byte order by combining the
41    network number NET with the local address HOST.  */
42 extern struct in_addr inet_makeaddr (in_addr_t __net, in_addr_t __host)
43      __THROW;
44
45 /* Return network number part of the Internet address IN.  */
46 extern in_addr_t inet_netof (struct in_addr __in) __THROW;
47
48 /* Extract the network number in network byte order from the address
49    in numbers-and-dots natation starting at CP.  */
50 extern in_addr_t inet_network (__const char *__cp) __THROW;
51
52 /* Convert Internet number in IN to ASCII representation.  The return value
53    is a pointer to an internal array containing the string.  */
54 extern char *inet_ntoa (struct in_addr __in) __THROW;
55
56 /* Convert from presentation format of an Internet number in buffer
57    starting at CP to the binary network format and store result for
58    interface type AF in buffer starting at BUF.  */
59 extern int inet_pton (int __af, __const char *__restrict __cp,
60                       void *__restrict __buf) __THROW;
61
62 /* Convert a Internet address in binary network format for interface
63    type AF in buffer starting at CP to presentation form and place
64    result in buffer of length LEN astarting at BUF.  */
65 extern __const char *inet_ntop (int __af, __const void *__restrict __cp,
66                                 char *__restrict __buf, socklen_t __len)
67      __THROW;
68
69
70 /* The following functions are not part of XNS 5.2.  */
71 #ifdef __USE_MISC
72 /* Convert Internet host address from numbers-and-dots notation in CP
73    into binary data and store the result in the structure INP.  */
74 extern in_addr_t inet_aton (__const char *__cp, struct in_addr *__inp) __THROW;
75
76 /* Format a network number NET into presentation format and place result
77    in buffer starting at BUF with length of LEN bytes.  */
78 extern char *inet_neta (in_addr_t __net, char *__buf, size_t __len) __THROW;
79
80 /* Convert network number for interface type AF in buffer starting at
81    CP to presentation format.  The result will specifiy BITS bits of
82    the number.  */
83 extern char *inet_net_ntop (int __af, __const void *__cp, int __bits,
84                             char *__buf, size_t __len) __THROW;
85
86 /* Convert network number for interface type AF from presentation in
87    buffer starting at CP to network format and store result int
88    buffer starting at BUF of size LEN.  */
89 extern int inet_net_pton (int __af, __const char *__cp,
90                           void *__buf, size_t __len) __THROW;
91
92 /* Convert ASCII representation in hexadecimal form of the Internet
93    address to binary form and place result in buffer of length LEN
94    starting at BUF.  */
95 extern unsigned int inet_nsap_addr (__const char *__cp,
96                                     unsigned char *__buf, int __len) __THROW;
97
98 /* Convert internet address in binary form in LEN bytes starting at CP
99    a presentation form and place result in BUF.  */
100 extern char *inet_nsap_ntoa (int __len, __const unsigned char *__cp,
101                              char *__buf) __THROW;
102 #endif
103
104 __END_DECLS
105
106 #endif /* arpa/inet.h */