inet.h 4.6 KB

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