Ported Peter Hartley's patch to compile with mingw.
git-svn-id: https://pupnp.svn.sourceforge.net/svnroot/pupnp/trunk@391 119443c7-1b9e-41f8-b6fc-b9c35fce742c
This commit is contained in:
		| @@ -2,6 +2,9 @@ | |||||||
| Version 1.8.0 | Version 1.8.0 | ||||||
| ******************************************************************************* | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2008-05-24 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Ported Peter Hartley's patch to compile with mingw. | ||||||
|  |  | ||||||
| 2008-05-24 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | 2008-05-24 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
| 	* Added some debug capability to ixml. | 	* Added some debug capability to ixml. | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										46
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -341,9 +341,26 @@ AC_DEFINE([_FILE_OFFSET_BITS], [64], [File Offset size]) | |||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| # Checks for header files | # Are we targetting Win32? | ||||||
|  | # | ||||||
|  | AC_MSG_CHECKING([for Win32]) | ||||||
|  | AC_COMPILE_IFELSE([AC_LANG_PROGRAM([ | ||||||
|  | #ifdef WIN32 | ||||||
|  | 	#error Yup | ||||||
|  | #endif | ||||||
|  | ],[])], [ac_cv_win32="no"], [ac_cv_win32="yes"]) | ||||||
|  | if test "$ac_cv_win32" = "yes"; then | ||||||
|  | 	AC_MSG_RESULT([yes]) | ||||||
|  | else | ||||||
|  | 	AC_MSG_RESULT([no]) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # | ||||||
|  | # Checks for header files (which aren't needed on Win32) | ||||||
| # | # | ||||||
| AC_HEADER_STDC | AC_HEADER_STDC | ||||||
|  | if test "$ac_cv_win32" = "no"; then | ||||||
| # libupnp code doesn't use autoconf variables yet, | # libupnp code doesn't use autoconf variables yet, | ||||||
| # so just abort if a header file is not found. | # so just abort if a header file is not found. | ||||||
| AC_CHECK_HEADERS( | AC_CHECK_HEADERS( | ||||||
| @@ -365,13 +382,38 @@ AC_CHECK_HEADERS( | |||||||
| 	], | 	], | ||||||
| 	[], | 	[], | ||||||
| 	[AC_MSG_ERROR([required header file missing])]) | 	[AC_MSG_ERROR([required header file missing])]) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| # Checks for typedefs, structures, and compiler characteristics | # Checks for typedefs, structures, and compiler characteristics | ||||||
| #	 | #	 | ||||||
| AC_C_CONST | AC_C_CONST | ||||||
| TYPE_SOCKLEN_T |  | ||||||
|  | # The test for socklen_t was getting it wrong when it exists but is in ws2tcpip.h, | ||||||
|  | # so we use a new test. | ||||||
|  | #TYPE_SOCKLEN_T | ||||||
|  |  | ||||||
|  | AC_CHECK_HEADERS([sys/types.h sys/socket.h ws2tcpip.h]) | ||||||
|  | AC_MSG_CHECKING(for socklen_t) | ||||||
|  | AC_COMPILE_IFELSE([AC_LANG_PROGRAM([ | ||||||
|  | #ifdef HAVE_SYS_TYPES_H | ||||||
|  | 	#include <sys/types.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_SOCKET_H | ||||||
|  | 	#include <sys/socket.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_WS2TCPIP_H | ||||||
|  | 	#include <ws2tcpip.h> | ||||||
|  | #endif | ||||||
|  | ],[ socklen_t t = 0; return t; ]) | ||||||
|  | ],[ac_cv_socklen_t="yes"],[ac_cv_socklen_t="no"]) | ||||||
|  | if test "$ac_cv_socklen_t" = "yes"; then | ||||||
|  | 	AC_MSG_RESULT([yes]) | ||||||
|  | else | ||||||
|  | 	AC_MSG_RESULT([no, using int]) | ||||||
|  | 	AC_DEFINE(socklen_t, int, [Type for storing the length of struct sockaddr]) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
|   | |||||||
| @@ -100,6 +100,16 @@ | |||||||
| 		#define PRId64 "I64d" | 		#define PRId64 "I64d" | ||||||
| 		#define PRIzu "zu" | 		#define PRIzu "zu" | ||||||
| 	#endif /* UPNP_USE_BCBPP */ | 	#endif /* UPNP_USE_BCBPP */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	#ifdef __GNUC__ | ||||||
|  | 		#define UPNP_INLINE inline | ||||||
|  | 		/* Note with PRIzu that in the case of Mingw32, it's the MS C | ||||||
|  | 		 * runtime printf which ends up getting called, not the glibc | ||||||
|  | 		 * printf, so it genuinely doesn't have "zu" | ||||||
|  | 		 */ | ||||||
|  | 		#define PRIzu "lu" | ||||||
|  | 	#endif | ||||||
| #else | #else | ||||||
| 	#define EXPORT_SPEC | 	#define EXPORT_SPEC | ||||||
| 	#define UPNP_INLINE inline | 	#define UPNP_INLINE inline | ||||||
|   | |||||||
| @@ -47,7 +47,7 @@ | |||||||
| #include "ssdplib.h" | #include "ssdplib.h" | ||||||
| #include "statcodes.h" | #include "statcodes.h" | ||||||
| #include "ThreadPool.h" | #include "ThreadPool.h" | ||||||
| #include "unixutil.h" | #include "unixutil.h" /* for socklen_t, EAFNOSUPPORT */ | ||||||
| #include "upnpapi.h" | #include "upnpapi.h" | ||||||
| #include "util.h" | #include "util.h" | ||||||
|  |  | ||||||
| @@ -60,21 +60,6 @@ | |||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef WIN32 |  | ||||||
| 	#include <winsock2.h> |  | ||||||
|  |  | ||||||
| 	typedef int socklen_t; |  | ||||||
| 	#define EAFNOSUPPORT 97 |  | ||||||
| #else |  | ||||||
| 	#include <arpa/inet.h> |  | ||||||
| 	#include <netinet/in.h> |  | ||||||
| 	#include <sys/socket.h> |  | ||||||
| 	#include <sys/wait.h> |  | ||||||
| 	#include <sys/time.h> |  | ||||||
| 	#include <unistd.h> |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #define APPLICATION_LISTENING_PORT 49152 | #define APPLICATION_LISTENING_PORT 49152 | ||||||
|  |  | ||||||
| struct mserv_request_t { | struct mserv_request_t { | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ | |||||||
| #include "sock.h" | #include "sock.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "unixutil.h" | #include "unixutil.h" /* for socklen_t, EAFNOSUPPORT */ | ||||||
| #include "upnp.h" | #include "upnp.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -51,18 +51,6 @@ | |||||||
| #include <string.h> | #include <string.h> | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef WIN32 |  | ||||||
| 	#include <winsock2.h> |  | ||||||
| #else |  | ||||||
| 	#include <arpa/inet.h> |  | ||||||
| 	#include <netinet/in.h> |  | ||||||
| 	#include <sys/types.h> |  | ||||||
| 	#include <sys/socket.h> |  | ||||||
| 	#include <sys/time.h> |  | ||||||
| 	#include <unistd.h> |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef MSG_NOSIGNAL | #ifndef MSG_NOSIGNAL | ||||||
| 	#define MSG_NOSIGNAL 0 | 	#define MSG_NOSIGNAL 0 | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,37 +1,39 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * - Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * - Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| /************************************************************************ |  | ||||||
|  | /******************************************************************************* | ||||||
|  * Purpose: This file contains functions for uri, url parsing utility.  |  * Purpose: This file contains functions for uri, url parsing utility.  | ||||||
| ************************************************************************/ |  ******************************************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __FreeBSD__ | #ifdef __FreeBSD__ | ||||||
| 	#include <osreldate.h> | 	#include <osreldate.h> | ||||||
| @@ -39,6 +41,8 @@ | |||||||
| 		#include <lwres/netdb.h> | 		#include <lwres/netdb.h> | ||||||
| 	#endif | 	#endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "config.h" | #include "config.h" | ||||||
| #include "uri.h" | #include "uri.h" | ||||||
| #include "upnpapi.h" | #include "upnpapi.h" | ||||||
| @@ -1044,3 +1048,4 @@ parse_uri_and_unescape( char *in, | |||||||
|         remove_escaped_chars( (char *)out->fragment.buff, &out->fragment.size ); |         remove_escaped_chars( (char *)out->fragment.buff, &out->fragment.size ); | ||||||
|     return HTTP_SUCCESS; |     return HTTP_SUCCESS; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,103 +1,100 @@ | |||||||
| #ifdef WIN32 |  | ||||||
|  |  | ||||||
| #ifndef INET_PTON | #ifndef INET_PTON | ||||||
| #define INET_PTON | #define INET_PTON | ||||||
|  |  | ||||||
| #include <winsock2.h> |  | ||||||
|  | #ifdef WIN32 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include "unixutil.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <errno.h> | #include <errno.h> | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| typedef int socklen_t; |  | ||||||
| #define EAFNOSUPPORT 97 |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * WARNING: Don't even consider trying to compile this on a system where | /*! | ||||||
|  |  * \file | ||||||
|  |  * | ||||||
|  |  * \author: Paul Vixie, 1996. | ||||||
|  |  * | ||||||
|  |  * \brief Network support routines missing in WIN32. | ||||||
|  |  * | ||||||
|  |  * \warning Don't even consider trying to compile this on a system where | ||||||
|  * sizeof(int) < 4.  sizeof(int) 4 is fine; all the world's not a VAX. |  * sizeof(int) < 4.  sizeof(int) 4 is fine; all the world's not a VAX. | ||||||
|  |  * | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* const char * | /*! | ||||||
|  * inet_ntop4(src, dst, size) |  * \brief format an IPv4 address | ||||||
|  *	format an IPv4 address |  * | ||||||
|  * return: |  * \return `dst' (as a const) | ||||||
|  *	`dst' (as a const) |  * | ||||||
|  * notes: |  * \note | ||||||
|  *	(1) uses no statics |  *	\li (1) uses no statics | ||||||
|  *	(2) takes a u_char* not an in_addr as input |  *	\li (2) takes a u_char* not an in_addr as input | ||||||
|  * author: |  * | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  */ | ||||||
| extern const char *inet_ntop4(const u_char src, char *dst, socklen_t size); | extern const char *inet_ntop4(const u_char src, char *dst, socklen_t size); | ||||||
|  |  | ||||||
| /* const char * |  | ||||||
|  * inet_ntop6(src, dst, size) | /*! | ||||||
|  *	convert IPv6 binary address into presentation (printable) format |  * \brief convert IPv6 binary address into presentation (printable) format | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifdef INET_IPV6 | #ifdef INET_IPV6 | ||||||
|  | extern const char *inet_ntop6(const u_char *src, char *dst, socklen_t size); | ||||||
| extern const char * inet_ntop6(src, dst, size); |  | ||||||
|  |  | ||||||
| #endif /* INET_IPV6 */ | #endif /* INET_IPV6 */ | ||||||
|  |  | ||||||
| /* int |  | ||||||
|  * inet_pton4(src, dst) | /*! | ||||||
|  *	like inet_aton() but without all the hexadecimal and shorthand. |  * \brief like inet_aton() but without all the hexadecimal and shorthand. | ||||||
|  * return: |  * | ||||||
|  *	1 if `src' is a valid dotted quad, else 0. |  * \return 1 if `src' is a valid dotted quad, else 0. | ||||||
|  * notice: |  * | ||||||
|  *	does not touch `dst' unless it's returning 1. |  * \note does not touch `dst' unless it's returning 1. | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  */ | ||||||
| extern inet_pton4(const char *src,u_char *dst); | extern inet_pton4(const char *src,u_char *dst); | ||||||
|  |  | ||||||
| /* int |  | ||||||
|  * inet_pton6(src, dst) | /*! | ||||||
|  *	convert presentation level address to network order binary form. |  * \brief convert presentation level address to network order binary form. | ||||||
|  * return: |  * | ||||||
|  *	1 if `src' is a valid [RFC1884 2.2] address, else 0. |  * \return 1 if `src' is a valid [RFC1884 2.2] address, else 0. | ||||||
|  * notice: |  * | ||||||
|  *	(1) does not touch `dst' unless it's returning 1. |  * \note | ||||||
|  *	(2) :: in a full address is silently ignored. |  *	\li (1) does not touch `dst' unless it's returning 1. | ||||||
|  * credit: |  *	\li (2) :: in a full address is silently ignored. | ||||||
|  *	inspired by Mark Andrews. |  | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifdef INET_IPV6 | #ifdef INET_IPV6 | ||||||
|  | extern int inet_pton6(const char *src, u_char *dst); | ||||||
| extern int inet_pton6(src, dst); |  | ||||||
|  |  | ||||||
| #endif /* INET_IPV6 */ | #endif /* INET_IPV6 */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /*! | ||||||
| /* char * |  * \brief convert a network format address to presentation format. | ||||||
|  * inet_ntop(af, src, dst, size) |  * | ||||||
|  *	convert a network format address to presentation format. |  * \return | ||||||
|  * return: |  | ||||||
|  *	pointer to presentation format address (`dst'), or NULL (see errno). |  *	pointer to presentation format address (`dst'), or NULL (see errno). | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  */ | ||||||
| extern const char *inet_ntop(int af,const void *src,char *dst,socklen_t size); | extern const char *inet_ntop(int af,const void *src,char *dst,socklen_t size); | ||||||
|  |  | ||||||
|  |  | ||||||
| /* int | /*! | ||||||
|  * inet_pton(af, src, dst) |  * \brief convert from presentation format (which usually means ASCII printable) | ||||||
|  *	convert from presentation format (which usually means ASCII printable) |  | ||||||
|  * to network format (which is usually some kind of binary format). |  * to network format (which is usually some kind of binary format). | ||||||
|  * return: |  * | ||||||
|  *	1 if the address was valid for the specified address family |  * \return | ||||||
|  *	0 if the address wasn't valid (`dst' is untouched in this case) |  *	\li 1 if the address was valid for the specified address family | ||||||
|  *	-1 if some other error occurred (`dst' is untouched in this case, too) |  *	\li 0 if the address wasn't valid (`dst' is untouched in this case) | ||||||
|  * author: |  *	\li -1 if some other error occurred (`dst' is untouched in this case, too) | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  */ | ||||||
| extern int inet_pton(int af,const char *src,void *dst); | extern int inet_pton(int af,const char *src,void *dst); | ||||||
|  |  | ||||||
| #endif |  | ||||||
| #endif | #endif /* WIN32 */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif /* INET_PTON */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| /************************************************************************** | /******************************************************************************* | ||||||
|  * |  * | ||||||
|  * Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
|  * All rights reserved.  |  * All rights reserved.  | ||||||
| @@ -27,7 +27,7 @@ | |||||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
|  * |  * | ||||||
|  **************************************************************************/ |  ******************************************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Unix-specific network utilities */ | /* Unix-specific network utilities */ | ||||||
| @@ -37,14 +37,17 @@ | |||||||
| #define	GENLIB_NET_UNIXUTIL_H | #define	GENLIB_NET_UNIXUTIL_H | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <sys/types.h> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
|  | 	#include <winsock2.h> | ||||||
| 	typedef int socklen_t; | 	typedef int socklen_t; | ||||||
| 	#define EAFNOSUPPORT 97 | 	#define EAFNOSUPPORT 97 | ||||||
| #else | #else | ||||||
|  | 	#include <arpa/inet.h> | ||||||
|  | 	#include <netinet/in.h> | ||||||
| 	#include <sys/socket.h> | 	#include <sys/socket.h> | ||||||
|  | 	#include <sys/time.h> | ||||||
|  | 	#include <sys/wait.h> | ||||||
|  | 	#include <unistd.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,3 @@ | |||||||
| #ifdef WIN32 |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 1996-1999 by Internet Software Consortium. |  * Copyright (c) 1996-1999 by Internet Software Consortium. | ||||||
|  * |  * | ||||||
| @@ -16,39 +15,15 @@ | |||||||
|  * SOFTWARE. |  * SOFTWARE. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /*#include <sys/param.h> |  | ||||||
| #include <sys/types.h> |  | ||||||
| #include <sys/socket.h> |  | ||||||
|  |  | ||||||
| #include <netinet/in.h> | /* This file is WIN32 only */ | ||||||
| #include <arpa/inet.h> | #ifdef WIN32 | ||||||
| #include <arpa/nameser.h>*/ |  | ||||||
| #include <winsock2.h> |  | ||||||
|  |  | ||||||
| #include <errno.h> |  | ||||||
| #include <stdio.h> |  | ||||||
| #include <string.h> |  | ||||||
| typedef int socklen_t; |  | ||||||
| #define EAFNOSUPPORT 97 |  | ||||||
| /* |  | ||||||
|  * WARNING: Don't even consider trying to compile this on a system where |  | ||||||
|  * sizeof(int) < 4.  sizeof(int) 4 is fine; all the world's not a VAX. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* const char * | #include "inet_pton.h" | ||||||
|  * inet_ntop4(src, dst, size) |  | ||||||
|  *	format an IPv4 address |  | ||||||
|  * return: | static const char *inet_ntop4(const u_char *src, char *dst, socklen_t size) | ||||||
|  *	`dst' (as a const) |  | ||||||
|  * notes: |  | ||||||
|  *	(1) uses no statics |  | ||||||
|  *	(2) takes a u_char* not an in_addr as input |  | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  | ||||||
| static const char * |  | ||||||
| inet_ntop4(const u_char *src, char *dst, socklen_t size) |  | ||||||
| { | { | ||||||
| 	char tmp[sizeof ("255.255.255.255") + 1] = "\0"; | 	char tmp[sizeof ("255.255.255.255") + 1] = "\0"; | ||||||
| 	int octet; | 	int octet; | ||||||
| @@ -82,20 +57,8 @@ inet_ntop4(const u_char *src, char *dst, socklen_t size) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| /* const char * |  | ||||||
|  * inet_ntop6(src, dst, size) |  | ||||||
|  *	convert IPv6 binary address into presentation (printable) format |  | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #ifdef INET_IPV6 | #ifdef INET_IPV6 | ||||||
|  | static const char *inet_ntop6(const u_char *src, char *dst, socklen_t size) | ||||||
| static const char * |  | ||||||
| inet_ntop6(src, dst, size) |  | ||||||
| 	const u_char *src; |  | ||||||
| 	char *dst; |  | ||||||
| 	socklen_t size; |  | ||||||
| { | { | ||||||
| 	/* | 	/* | ||||||
| 	 * Note that int32_t and int16_t need only be "at least" large enough | 	 * Note that int32_t and int16_t need only be "at least" large enough | ||||||
| @@ -182,18 +145,7 @@ inet_ntop6(src, dst, size) | |||||||
| #endif /* INET_IPV6 */ | #endif /* INET_IPV6 */ | ||||||
|  |  | ||||||
|  |  | ||||||
| /* int | static int inet_pton4(const char *src,u_char *dst) | ||||||
|  * inet_pton4(src, dst) |  | ||||||
|  *	like inet_aton() but without all the hexadecimal and shorthand. |  | ||||||
|  * return: |  | ||||||
|  *	1 if `src' is a valid dotted quad, else 0. |  | ||||||
|  * notice: |  | ||||||
|  *	does not touch `dst' unless it's returning 1. |  | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  | ||||||
| static int |  | ||||||
| inet_pton4(const char *src,u_char *dst) |  | ||||||
| { | { | ||||||
| 	int saw_digit, octets, ch; | 	int saw_digit, octets, ch; | ||||||
| 	u_char tmp[4], *tp; | 	u_char tmp[4], *tp; | ||||||
| @@ -225,29 +177,12 @@ inet_pton4(const char *src,u_char *dst) | |||||||
| 	if (octets < 4) | 	if (octets < 4) | ||||||
| 		return (0); | 		return (0); | ||||||
| 	memcpy(dst, tmp, 4); | 	memcpy(dst, tmp, 4); | ||||||
| 	return (1); | 	return 1; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* int |  | ||||||
|  * inet_pton6(src, dst) |  | ||||||
|  *	convert presentation level address to network order binary form. |  | ||||||
|  * return: |  | ||||||
|  *	1 if `src' is a valid [RFC1884 2.2] address, else 0. |  | ||||||
|  * notice: |  | ||||||
|  *	(1) does not touch `dst' unless it's returning 1. |  | ||||||
|  *	(2) :: in a full address is silently ignored. |  | ||||||
|  * credit: |  | ||||||
|  *	inspired by Mark Andrews. |  | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #ifdef INET_IPV6 | #ifdef INET_IPV6 | ||||||
|  | static int inet_pton6(const char *src, u_char *dst) | ||||||
| static int |  | ||||||
| inet_pton6(src, dst) |  | ||||||
| 	const char *src; |  | ||||||
| 	u_char *dst; |  | ||||||
| { | { | ||||||
| 	static const char xdigits[] = "0123456789abcdef"; | 	static const char xdigits[] = "0123456789abcdef"; | ||||||
| 	u_char tmp[16], *tp, *endp, *colonp; | 	u_char tmp[16], *tp, *endp, *colonp; | ||||||
| @@ -330,20 +265,10 @@ inet_pton6(src, dst) | |||||||
| 	memcpy(dst, tmp, 16); | 	memcpy(dst, tmp, 16); | ||||||
| 	return (1); | 	return (1); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif /* INET_IPV6 */ | #endif /* INET_IPV6 */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | const char *inet_ntop(int af,const void *src,char *dst,socklen_t size) | ||||||
| /* char * |  | ||||||
|  * inet_ntop(af, src, dst, size) |  | ||||||
|  *	convert a network format address to presentation format. |  | ||||||
|  * return: |  | ||||||
|  *	pointer to presentation format address (`dst'), or NULL (see errno). |  | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  | ||||||
| extern const char *inet_ntop(int af,const void *src,char *dst,socklen_t size) |  | ||||||
| { | { | ||||||
| 	switch (af) { | 	switch (af) { | ||||||
| 	case AF_INET: | 	case AF_INET: | ||||||
| @@ -353,24 +278,13 @@ extern const char *inet_ntop(int af,const void *src,char *dst,socklen_t size) | |||||||
| 		return (inet_ntop6(src, dst, size)); | 		return (inet_ntop6(src, dst, size)); | ||||||
| #endif | #endif | ||||||
| 	default: | 	default: | ||||||
| 		//__set_errno (EAFNOSUPPORT); | 		/*__set_errno(EAFNOSUPPORT);*/ | ||||||
| 		return (NULL); | 		return NULL; | ||||||
| 	} | 	} | ||||||
| 	/* NOTREACHED */ | 	/* NOTREACHED */ | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| /* int |  | ||||||
|  * inet_pton(af, src, dst) |  | ||||||
|  *	convert from presentation format (which usually means ASCII printable) |  | ||||||
|  *	to network format (which is usually some kind of binary format). |  | ||||||
|  * return: |  | ||||||
|  *	1 if the address was valid for the specified address family |  | ||||||
|  *	0 if the address wasn't valid (`dst' is untouched in this case) |  | ||||||
|  *	-1 if some other error occurred (`dst' is untouched in this case, too) |  | ||||||
|  * author: |  | ||||||
|  *	Paul Vixie, 1996. |  | ||||||
|  */ |  | ||||||
| int inet_pton(int af,const char *src,void *dst) | int inet_pton(int af,const char *src,void *dst) | ||||||
| { | { | ||||||
| 	switch (af) { | 	switch (af) { | ||||||
| @@ -381,9 +295,12 @@ int inet_pton(int af,const char *src,void *dst) | |||||||
| 		return (inet_pton6(src, dst)); | 		return (inet_pton6(src, dst)); | ||||||
| #endif | #endif | ||||||
| 	default: | 	default: | ||||||
| 		//__set_errno (EAFNOSUPPORT); | 		/*__set_errno(EAFNOSUPPORT);*/ | ||||||
| 		return (-1); | 		return -1; | ||||||
| 	} | 	} | ||||||
| 	/* NOTREACHED */ | 	/* NOTREACHED */ | ||||||
| } | } | ||||||
| #endif |  | ||||||
|  |  | ||||||
|  | #endif /* WIN32 */ | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Marcelo Roberto Jimenez
					Marcelo Roberto Jimenez