Compare commits
	
		
			3 Commits
		
	
	
		
			release-1.
			...
			release-1.
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ba837a528f | ||
|   | 078f3f8faf | ||
|   | 1eeaf99b83 | 
							
								
								
									
										47
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										47
									
								
								ChangeLog
									
									
									
									
									
								
							| @@ -1,3 +1,50 @@ | |||||||
|  | ******************************************************************************* | ||||||
|  | Version 1.6.5 | ||||||
|  | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2008-02-02 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Peter Hartley's fix for wrong sized variable beeing passed to | ||||||
|  | 	http_MakeMessage() on 64 bit architectures. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ******************************************************************************* | ||||||
|  | Version 1.6.4 | ||||||
|  | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2008-01-23 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Workaround for a problem with the new automake AM_CONDITIONAL macro | ||||||
|  | 	from autotools-1.10. Thanks to Ingo Hofmann for helping with debugging | ||||||
|  | 	this one. | ||||||
|  |  | ||||||
|  | 2008-01-22 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Added quoting to macros AC_CONFIG_AUX_DIR, AC_CONFIG_MACRO_DIR and | ||||||
|  | 	AC_CONFIG_SRCDIR in configure.ac. Also changed the name of the | ||||||
|  | 	auxiliary directory in AC_CONFIG_AUX_DIR to build-aux. | ||||||
|  |  | ||||||
|  | 2008-01-22 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Fix for setsockopt() in Threadpool.c to allow more than one process | ||||||
|  | 	to join the multicast-group on OSX. Thanks to Ingo Hofmann. | ||||||
|  |  | ||||||
|  | 2008-01-22 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Using defined(__OSX__) || defined(__APPLE__) instead of just | ||||||
|  | 	defined(__OSX__) in the code. Thanks to Ingo Hofmann and Chris | ||||||
|  | 	Pickel. | ||||||
|  |  | ||||||
|  | 2008-01-21 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Fix for isFileInVirtualDir. Thanks to Peter Hartley for the patch. | ||||||
|  |  | ||||||
|  | 2008-01-07 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Putting back a "defined(__OSX__)" that has been removed in the | ||||||
|  | 	previous *BSD patch. Thanks to Chris Pickel for pointing it out. | ||||||
|  |  | ||||||
|  | 2008-01-07 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* SF Patches Tracker [ 1865812 ] typo in docs comment | ||||||
|  | 	Submitted By: Hartmut Holzgraefe - hholzgra | ||||||
|  | 	typo in docs comment ACCAPTED instead of ACCEPTED in | ||||||
|  | 	@name UPNP_E_UNSUBSCRIBE_UNACCAPTED [-302] | ||||||
|  | 	Also, the documentation file name was mispelled and was corrected in | ||||||
|  | 	the Makefile.am. | ||||||
|  |  | ||||||
| ******************************************************************************* | ******************************************************************************* | ||||||
| Version 1.6.3 | Version 1.6.3 | ||||||
| ******************************************************************************* | ******************************************************************************* | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								THANKS
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								THANKS
									
									
									
									
									
								
							| @@ -10,6 +10,7 @@ exempt of errors. | |||||||
| - Arno Willig | - Arno Willig | ||||||
| - Bob Ciora | - Bob Ciora | ||||||
| - Chaos | - Chaos | ||||||
|  | - Chris Pickel | ||||||
| - Craig Nelson | - Craig Nelson | ||||||
| - David Maass | - David Maass | ||||||
| - Emil Ljungdahl | - Emil Ljungdahl | ||||||
| @@ -20,6 +21,8 @@ exempt of errors. | |||||||
| - Fabrice Fontaine | - Fabrice Fontaine | ||||||
| - Fredrik Svensson | - Fredrik Svensson | ||||||
| - Glen Masgai | - Glen Masgai | ||||||
|  | - Hartmut Holzgraefe - hholzgra | ||||||
|  | - Ingo Hofmann | ||||||
| - Jiri Zouhar | - Jiri Zouhar | ||||||
| - John Dennis | - John Dennis | ||||||
| - Jonathan Casiot (no_dice) | - Jonathan Casiot (no_dice) | ||||||
| @@ -34,6 +37,7 @@ exempt of errors. | |||||||
| - Oskar Liljeblad | - Oskar Liljeblad | ||||||
| - Michael (oxygenic) | - Michael (oxygenic) | ||||||
| - Paul Vixie | - Paul Vixie | ||||||
|  | - Peter Hartley | ||||||
| - Rene Hexel | - Rene Hexel | ||||||
| - Robert Gingher (robsbox) | - Robert Gingher (robsbox) | ||||||
| - Siva Chandran | - Siva Chandran | ||||||
|   | |||||||
							
								
								
									
										36
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -9,7 +9,7 @@ | |||||||
|  |  | ||||||
| AC_PREREQ(2.60) | AC_PREREQ(2.60) | ||||||
|  |  | ||||||
| AC_INIT([libupnp], [1.6.3], [mroberto@users.sourceforge.net]) | AC_INIT([libupnp], [1.6.5], [mroberto@users.sourceforge.net]) | ||||||
| dnl ############################################################################ | dnl ############################################################################ | ||||||
| dnl # *Independently* of the above libupnp package version, the libtool version | dnl # *Independently* of the above libupnp package version, the libtool version | ||||||
| dnl # of the 3 libraries need to be updated whenever there is a change released: | dnl # of the 3 libraries need to be updated whenever there is a change released: | ||||||
| @@ -107,9 +107,33 @@ dnl #AC_SUBST([LT_VERSION_THREADUTIL], [4:1:2]) | |||||||
| dnl #AC_SUBST([LT_VERSION_UPNP],       [3:2:0]) | dnl #AC_SUBST([LT_VERSION_UPNP],       [3:2:0]) | ||||||
| dnl # | dnl # | ||||||
| dnl ############################################################################ | dnl ############################################################################ | ||||||
|  | dnl # Release 1.6.4: | ||||||
|  | dnl # "current:revision:age" | ||||||
|  | dnl # | ||||||
|  | dnl # - Code has changed in threadutil | ||||||
|  | dnl #	revision: 1 -> 2 | ||||||
|  | dnl # - Code has changed in upnp | ||||||
|  | dnl #	revision: 2 -> 3 | ||||||
|  | dnl # | ||||||
|  | dnl #AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | ||||||
|  | dnl #AC_SUBST([LT_VERSION_THREADUTIL], [4:2:2]) | ||||||
|  | dnl #AC_SUBST([LT_VERSION_UPNP],       [3:3:0]) | ||||||
|  | dnl # | ||||||
|  | dnl ############################################################################ | ||||||
|  | dnl # Release 1.6.5: | ||||||
|  | dnl # "current:revision:age" | ||||||
|  | dnl # | ||||||
|  | dnl # - Code has changed in upnp | ||||||
|  | dnl #	revision: 3 -> 4 | ||||||
|  | dnl # | ||||||
|  | dnl #AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | ||||||
|  | dnl #AC_SUBST([LT_VERSION_THREADUTIL], [4:2:2]) | ||||||
|  | dnl #AC_SUBST([LT_VERSION_UPNP],       [3:4:0]) | ||||||
|  | dnl # | ||||||
|  | dnl ############################################################################ | ||||||
| AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | ||||||
| AC_SUBST([LT_VERSION_THREADUTIL], [4:1:2]) | AC_SUBST([LT_VERSION_THREADUTIL], [4:2:2]) | ||||||
| AC_SUBST([LT_VERSION_UPNP],       [3:2:0]) | AC_SUBST([LT_VERSION_UPNP],       [3:4:0]) | ||||||
| dnl ############################################################################ | dnl ############################################################################ | ||||||
| dnl # Repeating the algorithm to place it closer to the modificatin place: | dnl # Repeating the algorithm to place it closer to the modificatin place: | ||||||
| dnl # 	- library code modified:		revision++ | dnl # 	- library code modified:		revision++ | ||||||
| @@ -120,9 +144,9 @@ dnl # *please update only once, before a formal release, not for each change* | |||||||
| dnl ############################################################################ | dnl ############################################################################ | ||||||
|  |  | ||||||
|  |  | ||||||
| AC_CONFIG_AUX_DIR(config.aux) | AC_CONFIG_AUX_DIR([build-aux]) | ||||||
| AC_CONFIG_MACRO_DIR(m4) | AC_CONFIG_MACRO_DIR([m4]) | ||||||
| AC_CONFIG_SRCDIR(upnp/inc/upnp.h) | AC_CONFIG_SRCDIR([upnp/inc/upnp.h]) | ||||||
|  |  | ||||||
|  |  | ||||||
| AM_INIT_AUTOMAKE([1.8 -Wall foreign subdir-objects dist-bzip2]) | AM_INIT_AUTOMAKE([1.8 -Wall foreign subdir-objects dist-bzip2]) | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								docs/dist/Makefile.am
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								docs/dist/Makefile.am
									
									
									
									
										vendored
									
									
								
							| @@ -39,7 +39,7 @@ EXTRA_DIST = \ | |||||||
|     ./html/upnp/UPNP_E_SOCKET_ERROR-208.html \ |     ./html/upnp/UPNP_E_SOCKET_ERROR-208.html \ | ||||||
|     ./html/upnp/UPNP_E_CANCELED-210.html \ |     ./html/upnp/UPNP_E_CANCELED-210.html \ | ||||||
|     ./html/upnp/UPNP_E_SUBSCRIBE_UNACCEPTED-301.html \ |     ./html/upnp/UPNP_E_SUBSCRIBE_UNACCEPTED-301.html \ | ||||||
|     ./html/upnp/UPNP_E_UNSUBSCRIBE_UNACCAPTED-302.html \ |     ./html/upnp/UPNP_E_UNSUBSCRIBE_UNACCEPTED-302.html \ | ||||||
|     ./html/upnp/UPNP_E_NOTIFY_UNACCEPTED-303.html \ |     ./html/upnp/UPNP_E_NOTIFY_UNACCEPTED-303.html \ | ||||||
|     ./html/upnp/UPNP_E_INVALID_ARGUMENT-501.html \ |     ./html/upnp/UPNP_E_INVALID_ARGUMENT-501.html \ | ||||||
|     ./html/upnp/UPNP_E_FILE_NOT_FOUND-502.html \ |     ./html/upnp/UPNP_E_FILE_NOT_FOUND-502.html \ | ||||||
| @@ -295,7 +295,7 @@ if WITH_DOCUMENTATION | |||||||
|         ./html/upnp/UPNP_E_SOCKET_ERROR-208.html \ |         ./html/upnp/UPNP_E_SOCKET_ERROR-208.html \ | ||||||
|         ./html/upnp/UPNP_E_CANCELED-210.html \ |         ./html/upnp/UPNP_E_CANCELED-210.html \ | ||||||
|         ./html/upnp/UPNP_E_SUBSCRIBE_UNACCEPTED-301.html \ |         ./html/upnp/UPNP_E_SUBSCRIBE_UNACCEPTED-301.html \ | ||||||
|         ./html/upnp/UPNP_E_UNSUBSCRIBE_UNACCAPTED-302.html \ |         ./html/upnp/UPNP_E_UNSUBSCRIBE_UNACCEPTED-302.html \ | ||||||
|         ./html/upnp/UPNP_E_NOTIFY_UNACCEPTED-303.html \ |         ./html/upnp/UPNP_E_NOTIFY_UNACCEPTED-303.html \ | ||||||
|         ./html/upnp/UPNP_E_INVALID_ARGUMENT-501.html \ |         ./html/upnp/UPNP_E_INVALID_ARGUMENT-501.html \ | ||||||
|         ./html/upnp/UPNP_E_FILE_NOT_FOUND-502.html \ |         ./html/upnp/UPNP_E_FILE_NOT_FOUND-502.html \ | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| Version: 1.6.2 | Version: 1.6.5 | ||||||
| Summary: Universal Plug and Play (UPnP) SDK | Summary: Universal Plug and Play (UPnP) SDK | ||||||
| Name: libupnp | Name: libupnp | ||||||
| Release: 1%{?dist} | Release: 1%{?dist} | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ AC_DEFUN([RT_BOOL_ARG_ENABLE],[ | |||||||
| 		               )]) | 		               )]) | ||||||
| 	test "x$enable_[$1]" != [x]m4_if([$2],[yes],[no],[yes]) dnl | 	test "x$enable_[$1]" != [x]m4_if([$2],[yes],[no],[yes]) dnl | ||||||
| 		&& enable_[]Name=[$2] | 		&& enable_[]Name=[$2] | ||||||
| 	AC_MSG_RESULT($enable_[]Name)dnl | 	AC_MSG_RESULT($enable_[]Name) | ||||||
| 	AM_CONDITIONAL([ENABLE_]NAME, test x"$enable_[]Name" = xyes) | 	AM_CONDITIONAL([ENABLE_]NAME, test x"$enable_[]Name" = xyes) | ||||||
| 	dnl | 	dnl | ||||||
| 	m4_popdef([NAME])dnl | 	m4_popdef([NAME])dnl | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ | |||||||
|  |  | ||||||
| #include "LinkedList.h" | #include "LinkedList.h" | ||||||
| #include <sys/param.h> | #include <sys/param.h> | ||||||
| #if (defined(BSD) && BSD >= 199306) || defined(__OSX__) | #if (defined(BSD) && BSD >= 199306) || defined(__OSX__) || defined(__APPLE__) | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #else | #else | ||||||
| #include <malloc.h> | #include <malloc.h> | ||||||
|   | |||||||
| @@ -229,7 +229,7 @@ static int SetPolicyType( PolicyType in ) | |||||||
| #ifdef __CYGWIN__ | #ifdef __CYGWIN__ | ||||||
| 	/* TODO not currently working... */ | 	/* TODO not currently working... */ | ||||||
| 	return 0; | 	return 0; | ||||||
| #elif defined(__OSX__) | #elif defined(__OSX__) || defined(__APPLE__) | ||||||
| 	setpriority( PRIO_PROCESS, 0, 0 ); | 	setpriority( PRIO_PROCESS, 0, 0 ); | ||||||
| 	return 0; | 	return 0; | ||||||
| #elif defined(WIN32) | #elif defined(WIN32) | ||||||
| @@ -389,7 +389,7 @@ static void SetSeed() | |||||||
| 	gettimeofday(&t, NULL); | 	gettimeofday(&t, NULL); | ||||||
| #if defined(WIN32) | #if defined(WIN32) | ||||||
|  	srand( ( unsigned int )t.tv_usec + (unsigned int)ithread_get_current_thread_id().p ); |  	srand( ( unsigned int )t.tv_usec + (unsigned int)ithread_get_current_thread_id().p ); | ||||||
| #elif defined(__FreeBSD__) | #elif defined(__FreeBSD__) || defined(__OSX__) || defined(__APPLE__) | ||||||
|  	srand( ( unsigned int )t.tv_usec + (unsigned int)ithread_get_current_thread_id() ); |  	srand( ( unsigned int )t.tv_usec + (unsigned int)ithread_get_current_thread_id() ); | ||||||
| #elif defined(__linux__) | #elif defined(__linux__) | ||||||
|  	srand( ( unsigned int )t.tv_usec + ithread_get_current_thread_id() ); |  	srand( ( unsigned int )t.tv_usec + ithread_get_current_thread_id() ); | ||||||
|   | |||||||
| @@ -413,7 +413,7 @@ | |||||||
| #define UPNP_E_SUBSCRIBE_UNACCEPTED   -301 | #define UPNP_E_SUBSCRIBE_UNACCEPTED   -301 | ||||||
| /*! @} */ | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_UNSUBSCRIBE_UNACCAPTED [-302] | /** @name UPNP_E_UNSUBSCRIBE_UNACCEPTED [-302] | ||||||
|  *  {\tt UPNP_E_UNSUBSCRIBE_UNACCEPTED} signifies that an unsubscribe |  *  {\tt UPNP_E_UNSUBSCRIBE_UNACCEPTED} signifies that an unsubscribe | ||||||
|  *  request was rejected from the remote side. |  *  request was rejected from the remote side. | ||||||
|  */ |  */ | ||||||
|   | |||||||
| @@ -745,7 +745,7 @@ isFileInVirtualDir( IN char *filePath ) | |||||||
|                 return TRUE; |                 return TRUE; | ||||||
|         } else { |         } else { | ||||||
|             if( ( strncmp( pCurVirtualDir->dirName, filePath, webDirLen ) |             if( ( strncmp( pCurVirtualDir->dirName, filePath, webDirLen ) | ||||||
|                   == 0 ) && ( filePath[webDirLen] == '/' ) ) |                   == 0 ) && ( filePath[webDirLen] == '/' || filePath[webDirLen] == '\0' || filePath[webDirLen] == '?' ) ) | ||||||
|                 return TRUE; |                 return TRUE; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -555,7 +555,7 @@ parse_hostport( const char *in, | |||||||
|     int begin_port; |     int begin_port; | ||||||
|     int hostport_size = 0; |     int hostport_size = 0; | ||||||
|     int host_size = 0; |     int host_size = 0; | ||||||
| #if !defined(WIN32) && !defined(__OSX__) | #if !defined(WIN32) && !(defined(__OSX__) || defined(__APPLE__)) | ||||||
|     char temp_hostbyname_buff[BUFFER_SIZE]; |     char temp_hostbyname_buff[BUFFER_SIZE]; | ||||||
|     struct hostent h_buf; |     struct hostent h_buf; | ||||||
| #endif | #endif | ||||||
| @@ -642,7 +642,7 @@ parse_hostport( const char *in, | |||||||
|         if ( h == NULL ) { |         if ( h == NULL ) { | ||||||
|                 errCode = 1; |                 errCode = 1; | ||||||
|         } |         } | ||||||
| #elif defined(__OSX__) | #elif defined(__OSX__) || defined(__APPLE__) | ||||||
|         h = gethostbyname(temp_host_name); |         h = gethostbyname(temp_host_name); | ||||||
|         if ( h == NULL ) { |         if ( h == NULL ) { | ||||||
|                 errCode = 1; |                 errCode = 1; | ||||||
|   | |||||||
| @@ -126,18 +126,18 @@ int web_server_set_alias( IN const char* alias_name, | |||||||
| int web_server_set_root_dir( IN const char* root_dir ); | int web_server_set_root_dir( IN const char* root_dir ); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function: web_server_callback											* | * Function: web_server_callback	 | ||||||
| *																		* | * | ||||||
| * Parameters:															* | * Parameters: | ||||||
| *	IN http_parser_t *parser,											* | *	IN http_parser_t *parser, | ||||||
| *	INOUT http_message_t* req,											* | *	INOUT http_message_t* req, | ||||||
| *	IN SOCKINFO *info													* | *	IN SOCKINFO *info | ||||||
| *																		* | * | ||||||
| * Description: main entry point into web server;						* | * Description: main entry point into web server; | ||||||
| *	handles HTTP GET and HEAD requests									* | *	handles HTTP GET and HEAD requests | ||||||
| *																		* | * | ||||||
| * Returns:																* | * Returns: | ||||||
| *	void																* | *	void | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| void web_server_callback( IN http_parser_t *parser, IN http_message_t* req, INOUT SOCKINFO *info ); | void web_server_callback( IN http_parser_t *parser, IN http_message_t* req, INOUT SOCKINFO *info ); | ||||||
|  |  | ||||||
| @@ -148,3 +148,4 @@ void web_server_callback( IN http_parser_t *parser, IN http_message_t* req, INOU | |||||||
|  |  | ||||||
|  |  | ||||||
| #endif // GENLIB_NET_HTTP_WEBSERVER_H | #endif // GENLIB_NET_HTTP_WEBSERVER_H | ||||||
|  |  | ||||||
|   | |||||||
| @@ -335,7 +335,7 @@ CreateServicePacket( IN int msg_type, | |||||||
|             &buf, 1, 1, |             &buf, 1, 1, | ||||||
|             "Q" "sssdc" "sdc" "ssc" "ssc" "ssc" "S" "Xc" "sscc", |             "Q" "sssdc" "sdc" "ssc" "ssc" "ssc" "S" "Xc" "sscc", | ||||||
|             HTTPMETHOD_NOTIFY, "*", |             HTTPMETHOD_NOTIFY, "*", | ||||||
|             1, "HOST: ", SSDP_IP, ":", SSDP_PORT, |             (size_t)1, "HOST: ", SSDP_IP, ":", SSDP_PORT, | ||||||
|             "CACHE-CONTROL: max-age=", duration, |             "CACHE-CONTROL: max-age=", duration, | ||||||
|             "LOCATION: ", location, |             "LOCATION: ", location, | ||||||
|             "NT: ", nt, |             "NT: ", nt, | ||||||
|   | |||||||
| @@ -870,6 +870,7 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|         UpnpPrintf( UPNP_CRITICAL, |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|             SSDP, __FILE__, __LINE__, |             SSDP, __FILE__, __LINE__, | ||||||
|             "Error in socket operation !!!\n" ); |             "Error in socket operation !!!\n" ); | ||||||
|  |  | ||||||
|             return UPNP_E_OUTOF_SOCKET; |             return UPNP_E_OUTOF_SOCKET; | ||||||
|     } |     } | ||||||
|     setsockopt( ssdpReqSock, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, sizeof( ttl ) ); |     setsockopt( ssdpReqSock, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, sizeof( ttl ) ); | ||||||
| @@ -884,6 +885,7 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|             "Error in socket operation !!!\n" ); |             "Error in socket operation !!!\n" ); | ||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) | ||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) | ||||||
|  |  | ||||||
|         return UPNP_E_OUTOF_SOCKET; |         return UPNP_E_OUTOF_SOCKET; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -897,10 +899,11 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) | ||||||
|         shutdown( ssdpSock, SD_BOTH ); |         shutdown( ssdpSock, SD_BOTH ); | ||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
|  |  | ||||||
|         return UPNP_E_SOCKET_ERROR; |         return UPNP_E_SOCKET_ERROR; | ||||||
|     } |     } | ||||||
|      |      | ||||||
| #ifdef __FreeBSD__ | #if defined(__FreeBSD__) || defined(__OSX__) || defined(__APPLE__) | ||||||
|     if( setsockopt( ssdpSock, SOL_SOCKET, SO_REUSEPORT, |     if( setsockopt( ssdpSock, SOL_SOCKET, SO_REUSEPORT, | ||||||
|             ( char * )&onOff, sizeof( onOff ) ) != 0 ) { |             ( char * )&onOff, sizeof( onOff ) ) != 0 ) { | ||||||
|         UpnpPrintf( UPNP_CRITICAL, |         UpnpPrintf( UPNP_CRITICAL, | ||||||
| @@ -910,6 +913,7 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) | ||||||
|         shutdown( ssdpSock, SD_BOTH ); |         shutdown( ssdpSock, SD_BOTH ); | ||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
|  |  | ||||||
|         return UPNP_E_SOCKET_ERROR; |         return UPNP_E_SOCKET_ERROR; | ||||||
|     } |     } | ||||||
| #endif /* __FreeBSD__ */ | #endif /* __FreeBSD__ */ | ||||||
| @@ -928,6 +932,7 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) | ||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) | ||||||
|  |  | ||||||
|         return UPNP_E_SOCKET_BIND; |         return UPNP_E_SOCKET_BIND; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -943,6 +948,7 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) | ||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) | ||||||
|  |  | ||||||
|         return UPNP_E_SOCKET_ERROR; |         return UPNP_E_SOCKET_ERROR; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -968,11 +974,13 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ); ) | ||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ); ) | ||||||
|  |  | ||||||
|         return UPNP_E_NETWORK_ERROR; |         return UPNP_E_NETWORK_ERROR; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     CLIENTONLY( out->ssdpReqSock = ssdpReqSock; ) |     CLIENTONLY( out->ssdpReqSock = ssdpReqSock; ) | ||||||
|     out->ssdpSock = ssdpSock; |     out->ssdpSock = ssdpSock; | ||||||
|  |  | ||||||
|     return UPNP_E_SUCCESS; |     return UPNP_E_SUCCESS; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user