getaddrinfo.h 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #ifndef _getaddrinfo_h
  2. #define _getaddrinfo_h
  3. /*
  4. * This file is part of libESMTP, a library for submission of RFC 2822
  5. * formatted electronic mail messages using the SMTP protocol described
  6. * in RFC 2821.
  7. *
  8. * Copyright (C) 2001,2002 Brian Stafford <brian@stafford.uklinux.net>
  9. *
  10. * This library is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU Lesser General Public
  12. * License as published by the Free Software Foundation; either
  13. * version 2.1 of the License, or (at your option) any later version.
  14. *
  15. * This library is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  18. * Lesser General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU Lesser General Public
  21. * License along with this library; if not, write to the Free Software
  22. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  23. */
  24. /* Structure and prototypes aken from RFC 2553 */
  25. struct addrinfo
  26. {
  27. int ai_flags; /* AI_PASSIVE, AI_CANONNAME, AI_NUMERICHOST */
  28. int ai_family; /* PF_xxx */
  29. int ai_socktype; /* SOCK_xxx */
  30. int ai_protocol; /* 0 or IPPROTO_xxx for IPv4 and IPv6 */
  31. size_t ai_addrlen; /* length of ai_addr */
  32. char *ai_canonname; /* canonical name for nodename */
  33. struct sockaddr *ai_addr; /* binary address */
  34. struct addrinfo *ai_next; /* next structure in linked list */
  35. };
  36. /* Supposed to be defined in <netdb.h> */
  37. #define AI_PASSIVE 1 /* Socket address is intended for `bind'. */
  38. #define AI_CANONNAME 2 /* Request for canonical name. */
  39. #define AI_NUMERICHOST 4 /* Don't use name resolution. */
  40. /* Supposed to be defined in <netdb.h> */
  41. #define EAI_ADDRFAMILY 1 /* address family for nodename not supported */
  42. #define EAI_AGAIN 2 /* temporary failure in name resolution */
  43. #define EAI_BADFLAGS 3 /* invalid value for ai_flags */
  44. #define EAI_FAIL 4 /* non-recoverable failure in name resolution */
  45. #define EAI_FAMILY 5 /* ai_family not supported */
  46. #define EAI_MEMORY 6 /* memory allocation failure */
  47. #define EAI_NODATA 7 /* no address associated with nodename */
  48. #define EAI_NONAME 8 /* nodename nor servname provided, or not known */
  49. #define EAI_SERVICE 9 /* servname not supported for ai_socktype */
  50. #define EAI_SOCKTYPE 10 /* ai_socktype not supported */
  51. #define EAI_SYSTEM 11 /* system error returned in errno */
  52. /* RFC 2553 / Posix resolver */
  53. int getaddrinfo (const char *nodename, const char *servname,
  54. const struct addrinfo *hints, struct addrinfo **res);
  55. /* Free addrinfo structure and associated storage */
  56. void freeaddrinfo (struct addrinfo *ai);
  57. /* Convert error return from getaddrinfo() to string */
  58. const char *gai_strerror (int code);
  59. #endif