glibc (2.38)

(root)/
include/
arpa/
inet.h
       1  /* Copyright (C) 1997-2023 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 Lesser General Public
       6     License as published by the Free Software Foundation; either
       7     version 2.1 of the 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     Lesser General Public License for more details.
      13  
      14     You should have received a copy of the GNU Lesser General Public
      15     License along with the GNU C Library; if not, see
      16     <https://www.gnu.org/licenses/>.  */
      17  
      18  #ifndef _ARPA_INET_H
      19  #define	_ARPA_INET_H	1
      20  
      21  #include <features.h>
      22  #include <netinet/in.h>		/* To define `struct in_addr'.  */
      23  
      24  /* Type for length arguments in socket calls.  */
      25  #ifndef __socklen_t_defined
      26  typedef __socklen_t socklen_t;
      27  # define __socklen_t_defined
      28  #endif
      29  
      30  __BEGIN_DECLS
      31  
      32  /* Convert Internet host address from numbers-and-dots notation in CP
      33     into binary data in network byte order.  */
      34  extern in_addr_t inet_addr (const char *__cp) __THROW;
      35  
      36  /* Return the local host address part of the Internet address in IN.  */
      37  extern in_addr_t inet_lnaof (struct in_addr __in) __THROW;
      38  
      39  /* Make Internet host address in network byte order by combining the
      40     network number NET with the local address HOST.  */
      41  extern struct in_addr inet_makeaddr (in_addr_t __net, in_addr_t __host)
      42       __THROW;
      43  
      44  /* Return network number part of the Internet address IN.  */
      45  extern in_addr_t inet_netof (struct in_addr __in) __THROW;
      46  
      47  /* Extract the network number in network byte order from the address
      48     in numbers-and-dots natation starting at CP.  */
      49  extern in_addr_t inet_network (const char *__cp) __THROW;
      50  
      51  /* Convert Internet number in IN to ASCII representation.  The return value
      52     is a pointer to an internal array containing the string.  */
      53  extern char *inet_ntoa (struct in_addr __in) __THROW;
      54  
      55  /* Convert from presentation format of an Internet number in buffer
      56     starting at CP to the binary network format and store result for
      57     interface type AF in buffer starting at BUF.  */
      58  extern int inet_pton (int __af, const char *__restrict __cp,
      59  		      void *__restrict __buf) __THROW;
      60  
      61  /* Convert a Internet address in binary network format for interface
      62     type AF in buffer starting at CP to presentation form and place
      63     result in buffer of length LEN astarting at BUF.  */
      64  extern const char *inet_ntop (int __af, const void *__restrict __cp,
      65  			      char *__restrict __buf, socklen_t __len)
      66       __THROW;
      67  
      68  
      69  /* The following functions are not part of XNS 5.2.  */
      70  #ifdef __USE_MISC
      71  /* Convert Internet host address from numbers-and-dots notation in CP
      72     into binary data and store the result in the structure INP.  */
      73  extern int inet_aton (const char *__cp, struct in_addr *__inp) __THROW;
      74  
      75  /* Format a network number NET into presentation format and place result
      76     in buffer starting at BUF with length of LEN bytes.  */
      77  extern char *inet_neta (in_addr_t __net, char *__buf, size_t __len) __THROW
      78    __attribute_deprecated_msg__ ("Use inet_ntop instead");
      79  
      80  /* Convert network number for interface type AF in buffer starting at
      81     CP to presentation format.  The result will specify 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 */