Compare commits
	
		
			1 Commits
		
	
	
		
			release-1.
			...
			release-1.
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ce5ccd8edc | 
							
								
								
									
										105
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										105
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,105 +0,0 @@ | ||||
| # | ||||
| # NOTE! Don't add files that are generated in specific | ||||
| # subdirectories here. Add them in the ".gitignore" file | ||||
| # in that subdirectory instead. | ||||
| # | ||||
| # NOTE! Please use 'git ls-files -i --exclude-standard' | ||||
| # command after changing this file, to see if there are | ||||
| # any tracked files which get ignored after the change. | ||||
| # | ||||
| # Normal rules | ||||
| # | ||||
| .* | ||||
| *.o | ||||
| *.o.* | ||||
| *.a | ||||
| *.s | ||||
| *.ko | ||||
| *.so | ||||
| *.so.dbg | ||||
| *.mod.c | ||||
| *.i | ||||
| *.lst | ||||
| *.symtypes | ||||
| *.order | ||||
| modules.builtin | ||||
| *.elf | ||||
| *.bin | ||||
| *.gz | ||||
| *.bz2 | ||||
| *.lzma | ||||
| *.patch | ||||
| *.gcno | ||||
|  | ||||
| # | ||||
| # Top-level generic files | ||||
| # | ||||
| /tags | ||||
| /TAGS | ||||
| /linux | ||||
| /vmlinux | ||||
| /vmlinuz | ||||
| /System.map | ||||
| /Module.markers | ||||
| /Module.symvers | ||||
|  | ||||
| # | ||||
| # git files that we don't want to ignore even it they are dot-files | ||||
| # | ||||
| !.gitignore | ||||
| !.mailmap | ||||
|  | ||||
| # | ||||
| # Generated include files | ||||
| # | ||||
| include/config | ||||
| include/linux/version.h | ||||
| include/generated | ||||
|  | ||||
| # stgit generated dirs | ||||
| patches-* | ||||
|  | ||||
| # quilt's files | ||||
| patches | ||||
| series | ||||
|  | ||||
| # cscope files | ||||
| cscope.* | ||||
| ncscope.* | ||||
|  | ||||
| # gnu global files | ||||
| GPATH | ||||
| GRTAGS | ||||
| GSYMS | ||||
| GTAGS | ||||
|  | ||||
| *.orig | ||||
| *~ | ||||
| \#*# | ||||
| *.lo | ||||
| *.la | ||||
| Makefile | ||||
| Makefile.in | ||||
| aclocal.m4 | ||||
| autoconfig.h | ||||
| autoconfig.h.in | ||||
| autom4te.cache/ | ||||
| build-aux/ | ||||
| config.log | ||||
| config.status | ||||
| configure | ||||
| libtool | ||||
| libupnp.pc | ||||
| m4/libtool.m4 | ||||
| m4/ltoptions.m4 | ||||
| m4/ltsugar.m4 | ||||
| m4/ltversion.m4 | ||||
| m4/lt~obsolete.m4 | ||||
| stamp-h1 | ||||
| upnp/inc/stamp-h2 | ||||
| upnp/inc/upnpconfig.h | ||||
| upnp/sample/tv_combo | ||||
| upnp/sample/tv_ctrlpt | ||||
| upnp/sample/tv_device | ||||
| docs/doxygen | ||||
|  | ||||
							
								
								
									
										12
									
								
								Doxyfile
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								Doxyfile
									
									
									
									
									
								
							| @@ -31,7 +31,7 @@ PROJECT_NAME           = libUPnP | ||||
| # This could be handy for archiving the generated documentation or  | ||||
| # if some version control system is used. | ||||
|  | ||||
| PROJECT_NUMBER         = 1.6.10 | ||||
| PROJECT_NUMBER         = 1.4.7 | ||||
|  | ||||
| # The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute)  | ||||
| # base path where the generated documentation will be put.  | ||||
| @@ -91,7 +91,7 @@ ABBREVIATE_BRIEF       = | ||||
| # Doxygen will generate a detailed section even if there is only a brief  | ||||
| # description. | ||||
|  | ||||
| ALWAYS_DETAILED_SEC    = YES | ||||
| ALWAYS_DETAILED_SEC    = NO | ||||
|  | ||||
| # If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all  | ||||
| # inherited members of a class in the documentation of that class as if those  | ||||
| @@ -290,7 +290,7 @@ HIDE_IN_BODY_DOCS      = NO | ||||
| # to NO (the default) then the documentation will be excluded.  | ||||
| # Set it to YES to include the internal documentation. | ||||
|  | ||||
| INTERNAL_DOCS          = YES | ||||
| INTERNAL_DOCS          = NO | ||||
|  | ||||
| # If the CASE_SENSE_NAMES tag is set to NO then Doxygen will only generate  | ||||
| # file names in lower-case letters. If set to YES upper-case letters are also  | ||||
| @@ -462,7 +462,7 @@ WARN_LOGFILE           = | ||||
| # directories like "/usr/src/myproject". Separate the files or directories  | ||||
| # with spaces. | ||||
|  | ||||
| INPUT                  = upnp ixml threadutil | ||||
| INPUT                  = ./upnp ./ixml ./threadutil | ||||
|  | ||||
| # This tag can be used to specify the character encoding of the source files that  | ||||
| # doxygen parses. Internally doxygen uses the UTF-8 encoding, which is also the default  | ||||
| @@ -995,7 +995,7 @@ ENABLE_PREPROCESSING   = YES | ||||
| # compilation will be performed. Macro expansion can be done in a controlled  | ||||
| # way by setting EXPAND_ONLY_PREDEF to YES. | ||||
|  | ||||
| MACRO_EXPANSION        = YES | ||||
| MACRO_EXPANSION        = NO | ||||
|  | ||||
| # If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES  | ||||
| # then the macro expansion is limited to the macros specified with the  | ||||
| @@ -1029,7 +1029,7 @@ INCLUDE_FILE_PATTERNS  = | ||||
| # undefined via #undef or recursively expanded use the := operator  | ||||
| # instead of the = operator. | ||||
|  | ||||
| PREDEFINED             = DEBUG UPNP_HAVE_TOOLS INCLUDE_DEVICE_APIS INCLUDE_CLIENT_APIS EXCLUDE_GENA=0 EXCLUDE_DOM=0 | ||||
| PREDEFINED             =  | ||||
|  | ||||
| # If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then  | ||||
| # this tag can be used to specify a list of macro names that should be expanded.  | ||||
|   | ||||
							
								
								
									
										21
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | ||||
| # | ||||
| # Top-level "Makefile.am" for libupnp | ||||
| # | ||||
| # Copyright (C) 2005 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
| # Copyright (C) 2005 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
| # | ||||
|  | ||||
| ACLOCAL_AMFLAGS = -I m4 | ||||
| @@ -16,7 +16,6 @@ SUBDIRS = \ | ||||
|  | ||||
|  | ||||
| EXTRA_DIST = \ | ||||
| 	Doxyfile \ | ||||
| 	libupnp.pc.in \ | ||||
| 	LICENSE \ | ||||
| 	THANKS \ | ||||
| @@ -26,23 +25,9 @@ EXTRA_DIST = \ | ||||
| 	build/libupnp.dsp \ | ||||
| 	build/libupnp.dsw \ | ||||
| 	build/inc/autoconfig.h \ | ||||
| 	build/inc/config.h \ | ||||
| 	build/inc/upnpconfig.h \ | ||||
| 	build/msvc/inttypes.h \ | ||||
| 	build/msvc/stdint.h \ | ||||
| 	build/vc8/ixml.vcproj \ | ||||
| 	build/vc8/libupnp.sln \ | ||||
| 	build/vc8/libupnp.vcproj \ | ||||
| 	build/vc8/threadutil.vcproj \ | ||||
| 	build/vc8/tvcombo.vcproj \ | ||||
| 	build/vc8/tvctrlpt.vcproj \ | ||||
| 	build/vc8/tvdevice.vcproj \ | ||||
| 	build/vc9/ixml.vcproj \ | ||||
| 	build/vc9/libupnp.sln \ | ||||
| 	build/vc9/libupnp.vcproj \ | ||||
| 	build/vc9/threadutil.vcproj \ | ||||
| 	build/vc9/tvcombo.vcproj \ | ||||
| 	build/vc9/tvctrlpt.vcproj \ | ||||
| 	build/vc9/tvdevice.vcproj  | ||||
| 	build/msvc/inttypes.h | ||||
|  | ||||
|  | ||||
| # This variable must have 'exec' in its name, in order to be installed  | ||||
|   | ||||
							
								
								
									
										2
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								README
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | ||||
| Portable SDK for UPnP* Devices (libupnp) | ||||
|  | ||||
| Copyright (c) 2000-2003 Intel Corporation - All Rights Reserved. | ||||
| Copyright (c) 2005-2006 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
| Copyright (c) 2005-2006 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
| Copyright (c) 2006 Michel Pfeiffer and others <virtual_worlds@gmx.de> | ||||
|  | ||||
| See LICENSE for details. | ||||
|   | ||||
							
								
								
									
										14
									
								
								THANKS
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								THANKS
									
									
									
									
									
								
							| @@ -8,19 +8,13 @@ exempt of errors. | ||||
|  | ||||
| - Alex (afaucher) | ||||
| - Andre Sodermans (wienerschnitzel) | ||||
| - Anthony Viallard (homer242) | ||||
| - Apostolos Syropoulos | ||||
| - Arno Willig | ||||
| - Bob Ciora | ||||
| - Carlo Parata | ||||
| - Carl Benson | ||||
| - Chandra (inactiveneurons) | ||||
| - Chaos | ||||
| - Charles Nepveu (cnepveu) | ||||
| - Chris Pickel | ||||
| - Chuck Thomason (cyt4) | ||||
| - Craig Nelson | ||||
| - David Blanchet | ||||
| - David Maass | ||||
| - Emil Ljungdahl | ||||
| - Erik Johansson | ||||
| @@ -30,13 +24,12 @@ exempt of errors. | ||||
| - Fabrice Fontaine | ||||
| - Fredrik Svensson | ||||
| - Glen Masgai | ||||
| - Hartmut Holzgraefe (hholzgra) | ||||
| - Hartmut Holzgraefe - hholzgra | ||||
| - Ingo Hofmann | ||||
| - Jiri Zouhar | ||||
| - John Dennis | ||||
| - Jonathan Casiot (no_dice) | ||||
| - Josh Carroll | ||||
| - Juergen Lock | ||||
| - Keith Brindley | ||||
| - Leuk_He | ||||
| - Loigu | ||||
| @@ -44,18 +37,13 @@ exempt of errors. | ||||
| - Marcelo Roberto Jimenez (mroberto) | ||||
| - Markus Strobl | ||||
| - Nektarios K. Papadopoulos (npapadop) | ||||
| - Nicholas Kraft | ||||
| - Nick Leverton (leveret) | ||||
| - Obata Akio (obache) | ||||
| - Oskar Liljeblad | ||||
| - Michael (oxygenic) | ||||
| - Paul Vixie | ||||
| - Peter Hartley | ||||
| - Rene Hexel | ||||
| - Robert Gingher (robsbox) | ||||
| - Ronan Menard | ||||
| - Siva Chandran | ||||
| - Stefan Sommerfeld (zerocom) | ||||
| - Stéphane Corthésy | ||||
| - Steve Bresson | ||||
| - Timothy Redaelli | ||||
|   | ||||
							
								
								
									
										23
									
								
								TODO
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								TODO
									
									
									
									
									
								
							| @@ -2,5 +2,28 @@ | ||||
| To Be Done | ||||
| ========== | ||||
|  | ||||
| - add FreeBSD patches | ||||
|   ( http://sf.net/tracker/index.php?func=detail&aid=1332618&group_id=7189&atid=307189 ?) | ||||
|  | ||||
| - non-regression testing  | ||||
|  | ||||
| - replace doc++ by Doxygen for documentation generation | ||||
|  | ||||
| - incorporate public patches and fix reported bugs :  | ||||
| http://sourceforge.net/tracker/?group_id=7189&atid=107189 and  | ||||
| http://sourceforge.net/tracker/?group_id=7189&atid=307189 | ||||
|  | ||||
| - RPM packaging (a preliminary one here : | ||||
|     https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=176617 ) | ||||
|  | ||||
| - make API clean for large files and 64 bits | ||||
|  | ||||
|  | ||||
| To Be Decided | ||||
| ============= | ||||
|  | ||||
| - IPV6 support ? | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -19,9 +19,15 @@ | ||||
| /* Define to 1 if fseeko (and presumably ftello) exists and is declared. */ | ||||
| #define HAVE_FSEEKO 1 | ||||
|  | ||||
| /* Define to 1 if you have the `ftime' function. */ | ||||
| #define HAVE_FTIME 1 | ||||
|  | ||||
| /* Define to 1 if you have the <inttypes.h> header file. */ | ||||
| #define HAVE_INTTYPES_H 1 | ||||
|  | ||||
| /* Define to 1 if you have the `compat' library (-lcompat). */ | ||||
| /* #undef HAVE_LIBCOMPAT */ | ||||
|  | ||||
| /* Define to 1 if you have the <limits.h> header file. */ | ||||
| #define HAVE_LIMITS_H 1 | ||||
|  | ||||
| @@ -61,6 +67,9 @@ | ||||
| /* Define to 1 if you have the <sys/stat.h> header file. */ | ||||
| #define HAVE_SYS_STAT_H 1 | ||||
|  | ||||
| /* Define to 1 if you have the <sys/timeb.h> header file. */ | ||||
| #define HAVE_SYS_TIMEB_H 1 | ||||
|  | ||||
| /* Define to 1 if you have the <sys/time.h> header file. */ | ||||
| #define HAVE_SYS_TIME_H 1 | ||||
|  | ||||
| @@ -73,13 +82,6 @@ | ||||
| /* Define to 1 if you have the `vprintf' function. */ | ||||
| #define HAVE_VPRINTF 1 | ||||
|  | ||||
| /* Define to 1 if you have the <ws2tcpip.h> header file. */ | ||||
| /* #undef HAVE_WS2TCPIP_H */ | ||||
|  | ||||
| /* Define to the sub-directory in which libtool stores uninstalled libraries. | ||||
|    */ | ||||
| #define LT_OBJDIR ".libs/" | ||||
|  | ||||
| /* Define to 1 to prevent compilation of assert() */ | ||||
| #define NDEBUG 1 | ||||
|  | ||||
| @@ -99,13 +101,13 @@ | ||||
| #define PACKAGE_NAME "libupnp" | ||||
|  | ||||
| /* Define to the full name and version of this package. */ | ||||
| #define PACKAGE_STRING "libupnp 1.6.10" | ||||
| #define PACKAGE_STRING "libupnp 1.4.7" | ||||
|  | ||||
| /* Define to the one symbol short name of this package. */ | ||||
| #define PACKAGE_TARNAME "libupnp" | ||||
|  | ||||
| /* Define to the version of this package. */ | ||||
| #define PACKAGE_VERSION "1.6.10" | ||||
| #define PACKAGE_VERSION "1.4.7" | ||||
|  | ||||
| /* Define to necessary symbol if this constant uses a non-standard name on | ||||
|    your system. */ | ||||
| @@ -114,15 +116,6 @@ | ||||
| /* Define to 1 if you have the ANSI C header files. */ | ||||
| #define STDC_HEADERS 1 | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_ENABLE_BLOCKING_TCP_CONNECTIONS 1 | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| /* #undef UPNP_ENABLE_IPV6 */ | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_ENABLE_NOTIFICATION_REORDERING 1 | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_HAVE_CLIENT 1 | ||||
|  | ||||
| @@ -138,32 +131,29 @@ | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_HAVE_WEBSERVER 1 | ||||
|  | ||||
| /* Do not use pthread_rwlock_t */ | ||||
| #define UPNP_USE_RWLOCK 1 | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_VERSION_MAJOR 1 | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_VERSION_MINOR 6 | ||||
| #define UPNP_VERSION_MINOR 4 | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_VERSION_PATCH 10 | ||||
| #define UPNP_VERSION_PATCH 7 | ||||
|  | ||||
| /* see upnpconfig.h */ | ||||
| #define UPNP_VERSION_STRING "1.6.10" | ||||
| #define UPNP_VERSION_STRING "1.4.7" | ||||
|  | ||||
| /* Version number of package */ | ||||
| #define VERSION "1.6.10" | ||||
| #define VERSION "1.4.7" | ||||
|  | ||||
| /* File Offset size */ | ||||
| #define _FILE_OFFSET_BITS 64 | ||||
|  | ||||
| /* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */ | ||||
| #define _LARGEFILE_SOURCE 1 | ||||
| /* #undef _LARGEFILE_SOURCE */ | ||||
|  | ||||
| /* Large files support */ | ||||
| #define _LARGE_FILE_SOURCE /**/ | ||||
| #define _LARGE_FILE_SOURCE  | ||||
|  | ||||
| /* Define to empty if `const' does not conform to ANSI C. */ | ||||
| /* #undef const */ | ||||
| @@ -174,5 +164,5 @@ | ||||
| /* Define to `unsigned int' if <sys/types.h> does not define. */ | ||||
| /* #undef size_t */ | ||||
|  | ||||
| /* Type for storing the length of struct sockaddr */ | ||||
| /* Substitute for socklen_t */ | ||||
| /* #undef socklen_t */ | ||||
|   | ||||
							
								
								
									
										343
									
								
								build/inc/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										343
									
								
								build/inc/config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,343 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef INTERNAL_CONFIG_H | ||||
| #define INTERNAL_CONFIG_H  | ||||
|  | ||||
| #include "autoconfig.h" | ||||
|  | ||||
|  | ||||
| /** @name Compile time configuration options | ||||
|  *  The Linux SDK for UPnP Devices contains some compile-time parameters  | ||||
|  *  that effect the behavior of the SDK.  All configuration options are  | ||||
|  *  located in {\tt src/inc/config.h}. | ||||
|  */ | ||||
|   | ||||
| //@{ | ||||
|  | ||||
| /** @name THREAD_IDLE_TIME | ||||
|  *  The {\tt THREAD_IDLE_TIME} constant determines when a thread will be | ||||
|  *  removed from the thread pool and returned to the operating system. When  | ||||
|  *  a thread in the thread pool has been idle for this number of milliseconds | ||||
|  *  the thread will be released from the thread pool.  The default value is | ||||
|  *  5000 milliseconds (5 seconds). | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define THREAD_IDLE_TIME 5000 | ||||
| //@} | ||||
|  | ||||
| /** @name JOBS_PER_THREAD | ||||
|  *  The {\tt JOBS_PER_THREAD} constant determines when a new thread will be | ||||
|  *  allocated to the thread pool inside the  SDK. The thread pool will | ||||
|  *  try and maintain this jobs/thread ratio. When the jobs/thread ratio  | ||||
|  *  becomes greater than this, then a new thread (up to the max) will be  | ||||
|  *  allocated to the thread pool.  The default ratio is 10 jobs/thread. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define JOBS_PER_THREAD 10 | ||||
| //@} | ||||
|  | ||||
| /** @name MIN_THREADS | ||||
|  *  The {\tt MIN_THREADS} constant defines the minimum number of threads the | ||||
|  *  thread pool inside the SDK will create.  The thread pool will | ||||
|  *  always have this number of threads. These threads are used | ||||
|  *  for both callbacks into applications built on top of the SDK and also | ||||
|  *  for making connections to other control points and devices. This number | ||||
|  *  includes persistent threads.  The default value is two threads. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MIN_THREADS 2  | ||||
| //@} | ||||
|  | ||||
| /** @name MAX_THREADS | ||||
|  *  The {\tt MAX_THREADS} constant defines the maximum number of threads the | ||||
|  *  thread pool inside the SDK will create.  These threads are used | ||||
|  *  for both callbacks into applications built on top of the library and also  | ||||
|  *  for making connections to other control points and devices.  It is not  | ||||
|  *  recommended that this value be below 10, since the threads are  | ||||
|  *  necessary for correct operation.  This value can be increased for greater | ||||
|  *  performance in operation at the expense of greater memory overhead.  The  | ||||
|  *  default value is 12. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MAX_THREADS 12  | ||||
| //@} | ||||
|  | ||||
| /** @name MAX_JOBS_TOTAL | ||||
|  *  The {\tt MAX_JOBS_TOTAL} constant determines the maximum number of jobs | ||||
|  *  that can be queued. If this limit is reached further jobs will be thrown | ||||
|  *  to avoid memory exhaustion. The default value 100. | ||||
|  *  (Added by Axis.) | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MAX_JOBS_TOTAL 100 | ||||
| //@} | ||||
|  | ||||
| /** @name DEFAULT_SOAP_CONTENT_LENGTH | ||||
|  * SOAP messages will read at most {\tt DEFAULT_SOAP_CONTENT_LENGTH} bytes.   | ||||
|  * This prevents devices that have a misbehaving web server to send  | ||||
|  * a large amount of data to the control point causing it to crash.   | ||||
|  * This can be adjusted dynamically with {\tt UpnpSetMaxContentLength}. | ||||
|  */ | ||||
| //@{ | ||||
| #define DEFAULT_SOAP_CONTENT_LENGTH 16000 | ||||
| //@} | ||||
|  | ||||
| /** @name NUM_SSDP_COPY | ||||
|  * This configuration parameter determines how many copies of each SSDP  | ||||
|  * advertisement and search packets will be sent. By default it will send two  | ||||
|  * copies of every packet.   | ||||
|  */ | ||||
| //@{ | ||||
| #define NUM_SSDP_COPY  2 | ||||
| //@} | ||||
|  | ||||
| /** @name SSDP_PAUSE | ||||
|  * This configuration parameter determines the pause between identical SSDP  | ||||
|  * advertisement and search packets. The pause is measured in milliseconds | ||||
|  * and defaults to 100. | ||||
|  */ | ||||
| //@{ | ||||
| #define SSDP_PAUSE  100 | ||||
| //@} | ||||
|  | ||||
| /** @name WEB_SERVER_BUF_SIZE  | ||||
|  * This configuration parameter sets the maximum buffer size for the  | ||||
|  * webserver.  The default value is 1MB. | ||||
|  */ | ||||
| //@{ | ||||
| #define WEB_SERVER_BUF_SIZE  (1024*1024) | ||||
| //@} | ||||
|  | ||||
| /** @name AUTO_RENEW_TIME | ||||
|  * The {\tt AUTO_RENEW_TIME} is the time, in seconds, before a subscription | ||||
|  * expires that the SDK automatically resubscribes.  The default  | ||||
|  * value is 10 seconds.  Setting this value too low can result in the  | ||||
|  * subscription renewal not making it to the device in time, causing the  | ||||
|  * subscription to timeout. In order to avoid continually resubscribing | ||||
|  * the minimum subscription time is five seconds more than the auto renew | ||||
|  * time. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define AUTO_RENEW_TIME 10 | ||||
| //@} | ||||
|  | ||||
| /** @name CP_MINIMUM_SUBSCRIPTION_TIME  | ||||
|  * The {\tt CP_MINIMUM_SUBSCRIPTION_TIME} is the minimum subscription time | ||||
|  * allowed for a control point using the SDK. Subscribing for less than | ||||
|  * this time automatically results in a subscription for this amount.  The  | ||||
|  * default value is 5 seconds more than the {\tt AUTO_RENEW_TIME}, or 15 | ||||
|  * seconds. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define CP_MINIMUM_SUBSCRIPTION_TIME (AUTO_RENEW_TIME + 5) | ||||
| //@} | ||||
|  | ||||
| /** @name MAX_SEARCH_TIME  | ||||
|  * The {\tt MAX_SEARCH_TIME} is the maximum time | ||||
|  * allowed for an SSDP search by a control point. Searching for greater than | ||||
|  * this time automatically results in a search for this amount.  The default  | ||||
|  * value is 80 seconds. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MAX_SEARCH_TIME 80 | ||||
| //@} | ||||
|  | ||||
| /** @name MIN_SEARCH_TIME  | ||||
|  * The {\tt MIN_SEARCH_TIME} is the minimumm time | ||||
|  * allowed for an SSDP search by a control point. Searching for less than | ||||
|  * this time automatically results in a search for this amount.  The default  | ||||
|  * value is 2 seconds. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MIN_SEARCH_TIME 2 | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /** @name AUTO_ADVERTISEMENT_TIME | ||||
|  *  The {\tt AUTO_ADVERTISEMENT_TIME} is the time, in seconds, before an | ||||
|  *  device advertisements expires before a renewed advertisement is sent. | ||||
|  *  The default time is 30 seconds. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define AUTO_ADVERTISEMENT_TIME 30 | ||||
| //@} | ||||
|  | ||||
| /** @name SSDP_PACKET_DISTRIBUTE | ||||
|  *  The {\tt SSDP_PACKET_DISTRIBUTE} enables the SSDP packets to be sent | ||||
|  *  at an interval equal to half of the expiration time of SSDP packets | ||||
|  *  minus the AUTO_ADVERTISEMENT_TIME. This is used to increase | ||||
|  *  the probability of SSDP packets reaching to control points. | ||||
|  *  It is recommended that this flag be turned on for embedded wireless  | ||||
|  *  devices. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define SSDP_PACKET_DISTRIBUTE 1 | ||||
| //@} | ||||
|  | ||||
| /** @name Module Exclusion | ||||
|  *  Depending on the requirements, the user can selectively discard any of  | ||||
|  *  the major modules like SOAP, GENA, SSDP or the Internal web server. By  | ||||
|  *  default everything is included inside the SDK.  By setting any of | ||||
|  *  the values below to 0, that component will not be included in the final | ||||
|  *  SDK. | ||||
|  *  \begin{itemize} | ||||
|  *    \item {\tt EXCLUDE_SOAP[0,1]} | ||||
|  *    \item {\tt EXCLUDE_GENA[0,1]} | ||||
|  *    \item {\tt EXCLUDE_SSDP[0,1]} | ||||
|  *    \item {\tt EXCLUDE_DOM [0,1]} | ||||
|  *    \item {\tt EXCLUDE_MINISERVER[0,1]} | ||||
|  *    \item {\tt EXCLUDE_WEB_SERVER[0,1]} | ||||
|  *    \item {\tt EXCLUDE_JNI[0,1]} | ||||
|  *  \end{itemize} | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define EXCLUDE_SSDP 0 | ||||
| #define EXCLUDE_SOAP 0 | ||||
| #define EXCLUDE_GENA 0 | ||||
| #define EXCLUDE_DOM  0 | ||||
| #define EXCLUDE_MINISERVER 0 | ||||
| #define EXCLUDE_WEB_SERVER 0 | ||||
| #ifdef USE_JNI | ||||
| #	define EXCLUDE_JNI 0 | ||||
| #else | ||||
| #	define EXCLUDE_JNI 1 | ||||
| #endif | ||||
| //@} | ||||
|  | ||||
|      | ||||
| /** @name DEBUG_TARGET | ||||
|  *  The user has the option to redirect the library output debug messages  | ||||
|  *  to either the screen or to a log file.  All the output messages with  | ||||
|  *  debug level 0 will go to {\tt upnp.err} and messages with debug level  | ||||
|  *  greater than zero will be redirected to {\tt upnp.out}. | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define DEBUG_TARGET		1    | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /** @name Other debugging features | ||||
|           The UPnP SDK contains other features to aid in debugging: | ||||
| 	  see <upnp/inc/upnpdebug.h> | ||||
|  */ | ||||
|  | ||||
| #define DEBUG_ALL		1 | ||||
| #define DEBUG_SSDP		0 | ||||
| #define DEBUG_SOAP		0 | ||||
| #define DEBUG_GENA		0 | ||||
| #define DEBUG_TPOOL		0 | ||||
| #define DEBUG_MSERV		0 | ||||
| #define DEBUG_DOM		0 | ||||
| #define DEBUG_HTTP		0 | ||||
| #define DEBUG_API		0 | ||||
|  | ||||
| //@} // Compile time configuration options | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Do not change, Internal purpose only!!!  | ||||
|  ***************************************************************************/  | ||||
|  | ||||
| //@{ | ||||
|  | ||||
| /* | ||||
|  * Set additional defines based on requested configuration  | ||||
|  */ | ||||
|  | ||||
| // configure --enable-client | ||||
| #if UPNP_HAVE_CLIENT | ||||
| #	define INCLUDE_CLIENT_APIS	1 | ||||
| #endif | ||||
|  | ||||
| // configure --enable-device | ||||
| #if UPNP_HAVE_DEVICE | ||||
| #	define INCLUDE_DEVICE_APIS	1 | ||||
| #endif | ||||
|  | ||||
| // configure --enable-webserver --enable-device | ||||
| #if UPNP_HAVE_WEBSERVER | ||||
| #	define INTERNAL_WEB_SERVER	1 | ||||
| #endif | ||||
|  | ||||
|  | ||||
|  | ||||
| #undef  EXCLUDE_WEB_SERVER  | ||||
| #undef  EXCLUDE_MINISERVER  | ||||
| #ifdef  INTERNAL_WEB_SERVER | ||||
| #	define EXCLUDE_WEB_SERVER 0 | ||||
| #	define EXCLUDE_MINISERVER 0 | ||||
| #else | ||||
| #	define EXCLUDE_WEB_SERVER 1 | ||||
| #	define EXCLUDE_MINISERVER 1 | ||||
| #endif | ||||
|  | ||||
| #if EXCLUDE_GENA == 1 && EXCLUDE_SOAP == 1 && EXCLUDE_WEB_SERVER == 1 | ||||
| #	undef  EXCLUDE_MINISERVER  | ||||
| #	define EXCLUDE_MINISERVER 1 | ||||
| #	if INTERNAL_WEB_SERVER | ||||
| #		error "conflicting settings: use configure --disable-webserver" | ||||
| #	endif | ||||
| #endif | ||||
|  | ||||
| #if EXCLUDE_GENA == 0 || EXCLUDE_SOAP == 0 || EXCLUDE_WEB_SERVER == 0 | ||||
| #	undef  EXCLUDE_MINISERVER  | ||||
| #	define EXCLUDE_MINISERVER 0 | ||||
| #	if EXCLUDE_WEB_SERVER == 0 && !defined INTERNAL_WEB_SERVER | ||||
| #		error "conflicting settings : use configure --enable-webserver" | ||||
| #	endif | ||||
| #endif | ||||
|  | ||||
|  | ||||
|  | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
| #	define CLIENTONLY(x) x | ||||
| #else  | ||||
| #	define CLIENTONLY(x) | ||||
| #endif | ||||
|  | ||||
| //@} | ||||
| #endif | ||||
|  | ||||
| @@ -1,35 +1,35 @@ | ||||
| /* upnp/inc/upnpconfig.h.  Generated from upnpconfig.h.in by configure.  */ | ||||
| /* -*- C -*- */ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2006 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * * Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * * Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| // -*- C -*- | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2006 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef UPNP_CONFIG_H | ||||
| #define UPNP_CONFIG_H  | ||||
| @@ -40,16 +40,16 @@ | ||||
|  ***************************************************************************/  | ||||
|  | ||||
| /** The library version (string) e.g. "1.3.0" */ | ||||
| #define UPNP_VERSION_STRING "1.6.10" | ||||
| #define UPNP_VERSION_STRING "1.4.7" | ||||
|  | ||||
| /** Major version of the library */ | ||||
| #define UPNP_VERSION_MAJOR 1 | ||||
|  | ||||
| /** Minor version of the library */ | ||||
| #define UPNP_VERSION_MINOR 6 | ||||
| #define UPNP_VERSION_MINOR 4 | ||||
|  | ||||
| /** Patch version of the library */ | ||||
| #define UPNP_VERSION_PATCH 10 | ||||
| #define UPNP_VERSION_PATCH 7 | ||||
|  | ||||
| /** The library version (numeric) e.g. 10300 means version 1.3.0 */ | ||||
| #define UPNP_VERSION	\ | ||||
| @@ -91,9 +91,7 @@ | ||||
|  *  (i.e. configure --enable-tools) : <upnp/upnptools.h> file is available */ | ||||
| #define UPNP_HAVE_TOOLS 1 | ||||
|  | ||||
| /** Defined to 1 if the library has been compiled with ipv6 support | ||||
|  *  (i.e. configure --enable-ipv6) */ | ||||
| /* #undef UPNP_ENABLE_IPV6 */ | ||||
|  | ||||
| #endif /* UPNP_CONFIG_H */ | ||||
| #endif // UPNP_CONFIG_H | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -5,17 +5,17 @@ | ||||
| # TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102 | ||||
|  | ||||
| CFG=libupnp - Win32 Debug | ||||
| !MESSAGE Dies ist kein gültiges Makefile. Zum Erstellen dieses Projekts mit NMAKE | ||||
| !MESSAGE verwenden Sie den Befehl "Makefile exportieren" und führen Sie den Befehl | ||||
| !MESSAGE Dies ist kein g<EFBFBD>ltiges Makefile. Zum Erstellen dieses Projekts mit NMAKE | ||||
| !MESSAGE verwenden Sie den Befehl "Makefile exportieren" und f<EFBFBD>hren Sie den Befehl | ||||
| !MESSAGE  | ||||
| !MESSAGE NMAKE /f "libupnp.mak". | ||||
| !MESSAGE  | ||||
| !MESSAGE Sie können beim Ausf?hren von NMAKE eine Konfiguration angeben | ||||
| !MESSAGE Sie k<EFBFBD>nnen beim Ausf<EFBFBD>hren von NMAKE eine Konfiguration angeben | ||||
| !MESSAGE durch Definieren des Makros CFG in der Befehlszeile. Zum Beispiel: | ||||
| !MESSAGE  | ||||
| !MESSAGE NMAKE /f "libupnp.mak" CFG="libupnp - Win32 Debug" | ||||
| !MESSAGE  | ||||
| !MESSAGE Für die Konfiguration stehen zur Auswahl: | ||||
| !MESSAGE F<EFBFBD>r die Konfiguration stehen zur Auswahl: | ||||
| !MESSAGE  | ||||
| !MESSAGE "libupnp - Win32 Release" (basierend auf  "Win32 (x86) Dynamic-Link Library") | ||||
| !MESSAGE "libupnp - Win32 Debug" (basierend auf  "Win32 (x86) Dynamic-Link Library") | ||||
| @@ -389,6 +389,10 @@ SOURCE=..\upnp\src\inc\upnpapi.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\upnp\src\inc\upnpclosesocket.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\upnp\src\inc\uri.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|   | ||||
| @@ -39,15 +39,14 @@ | ||||
| 			<Tool | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="0" | ||||
| 				AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc" | ||||
| 				AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc" | ||||
| 				PreprocessorDefinitions="WIN32;DEBUG" | ||||
| 				MinimalRebuild="true" | ||||
| 				BasicRuntimeChecks="3" | ||||
| 				RuntimeLibrary="1" | ||||
| 				RuntimeLibrary="3" | ||||
| 				WarningLevel="3" | ||||
| 				Detect64BitPortabilityProblems="true" | ||||
| 				DebugInformationFormat="4" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
| @@ -79,10 +78,9 @@ | ||||
| 		</Configuration> | ||||
| 		<Configuration | ||||
| 			Name="Release|Win32" | ||||
| 			OutputDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)" | ||||
| 			ConfigurationType="4" | ||||
| 			UseOfMFC="0" | ||||
| 			OutputDirectory="$(SolutionDir)$(ConfigurationName)" | ||||
| 			IntermediateDirectory="$(ConfigurationName)" | ||||
| 			ConfigurationType="1" | ||||
| 			CharacterSet="2" | ||||
| 			WholeProgramOptimization="1" | ||||
| 			> | ||||
| @@ -103,13 +101,10 @@ | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc" | ||||
| 				PreprocessorDefinitions="WIN32;IXML_INLINE=" | ||||
| 				RuntimeLibrary="0" | ||||
| 				RuntimeLibrary="2" | ||||
| 				WarningLevel="3" | ||||
| 				Detect64BitPortabilityProblems="true" | ||||
| 				DebugInformationFormat="3" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
| @@ -121,11 +116,18 @@ | ||||
| 				Name="VCPreLinkEventTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCLibrarianTool" | ||||
| 				Name="VCLinkerTool" | ||||
| 				GenerateDebugInformation="true" | ||||
| 				OptimizeReferences="2" | ||||
| 				EnableCOMDATFolding="2" | ||||
| 				TargetMachine="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCALinkTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManifestTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCXDCMakeTool" | ||||
| 			/> | ||||
| @@ -135,6 +137,12 @@ | ||||
| 			<Tool | ||||
| 				Name="VCFxCopTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCAppVerifierTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCWebDeploymentTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCPostBuildEventTool" | ||||
| 			/> | ||||
| @@ -164,10 +172,6 @@ | ||||
| 				RelativePath="..\..\ixml\src\ixml.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\ixmldebug.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\ixmlmembuf.c" | ||||
| 				> | ||||
| @@ -198,10 +202,6 @@ | ||||
| 				RelativePath="..\..\ixml\inc\ixml.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\inc\ixmldebug.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\inc\ixmlmembuf.h" | ||||
| 				> | ||||
| @@ -211,6 +211,12 @@ | ||||
| 				> | ||||
| 			</File> | ||||
| 		</Filter> | ||||
| 		<Filter | ||||
| 			Name="Resource Files" | ||||
| 			Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav" | ||||
| 			UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||||
| 			> | ||||
| 		</Filter> | ||||
| 	</Files> | ||||
| 	<Globals> | ||||
| 	</Globals> | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| 	Version="8.00" | ||||
| 	Name="libupnp" | ||||
| 	ProjectGUID="{6227F51A-1498-4C4A-B213-F6FDED605125}" | ||||
| 	RootNamespace="libupnp" | ||||
| 	> | ||||
| 	<Platforms> | ||||
| 		<Platform | ||||
| @@ -16,8 +15,8 @@ | ||||
| 	<Configurations> | ||||
| 		<Configuration | ||||
| 			Name="Release|Win32" | ||||
| 			OutputDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)" | ||||
| 			OutputDirectory=".\Release" | ||||
| 			IntermediateDirectory=".\Release" | ||||
| 			ConfigurationType="2" | ||||
| 			InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops" | ||||
| 			UseOfMFC="0" | ||||
| @@ -49,19 +48,18 @@ | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="2" | ||||
| 				InlineFunctionExpansion="1" | ||||
| 				AdditionalIncludeDirectories="..\..\pthreads\include;..\..\ixml\src\inc;..\..\ixml\inc;..\..\threadutil\inc;..\..\upnp\inc;..\..\upnp\src\inc;..\inc;..\msvc" | ||||
| 				PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				AdditionalIncludeDirectories="..\..\pthreads\include,..\ixml\src\inc,..\ixml\inc,..\threadutil\inc,..\upnp\inc,..\upnp\src\inc,.\inc" | ||||
| 				PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP" | ||||
| 				StringPooling="true" | ||||
| 				RuntimeLibrary="0" | ||||
| 				EnableFunctionLevelLinking="true" | ||||
| 				PrecompiledHeaderFile=".\Release/libupnp.pch" | ||||
| 				AssemblerListingLocation="$(OutDir)\" | ||||
| 				ObjectFile="$(OutDir)\" | ||||
| 				ProgramDataBaseFileName="$(OutDir)\" | ||||
| 				AssemblerListingLocation=".\Release/" | ||||
| 				ObjectFile=".\Release/" | ||||
| 				ProgramDataBaseFileName=".\Release/" | ||||
| 				BrowseInformation="1" | ||||
| 				WarningLevel="3" | ||||
| 				SuppressStartupBanner="true" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
| @@ -76,8 +74,8 @@ | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCLinkerTool" | ||||
| 				AdditionalDependencies="odbc32.lib odbccp32.lib ..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib  iphlpapi.lib" | ||||
| 				OutputFile="$(OutDir)\libupnp.dll" | ||||
| 				AdditionalDependencies="odbc32.lib odbccp32.lib ..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib" | ||||
| 				OutputFile=".\Release/libupnp.dll" | ||||
| 				LinkIncremental="1" | ||||
| 				SuppressStartupBanner="true" | ||||
| 				ProgramDatabaseFile=".\Release/libupnp.pdb" | ||||
| @@ -146,7 +144,7 @@ | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="0" | ||||
| 				AdditionalIncludeDirectories="..\..\pthreads\include;..\..\ixml\src\inc;..\..\ixml\inc;..\..\threadutil\inc;..\..\upnp\inc;..\..\upnp\src\inc;..\inc;..\msvc" | ||||
| 				PreprocessorDefinitions="DEBUG;WIN32;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				PreprocessorDefinitions="DEBUG;WIN32;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP" | ||||
| 				MinimalRebuild="true" | ||||
| 				BasicRuntimeChecks="3" | ||||
| 				RuntimeLibrary="1" | ||||
| @@ -158,7 +156,6 @@ | ||||
| 				WarningLevel="3" | ||||
| 				SuppressStartupBanner="true" | ||||
| 				DebugInformationFormat="4" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
| @@ -173,11 +170,10 @@ | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCLinkerTool" | ||||
| 				AdditionalDependencies="..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib iphlpapi.lib ixml.lib" | ||||
| 				AdditionalDependencies="odbc32.lib odbccp32.lib ..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib" | ||||
| 				OutputFile="$(OutDir)\libupnp.dll" | ||||
| 				LinkIncremental="2" | ||||
| 				SuppressStartupBanner="true" | ||||
| 				AdditionalLibraryDirectories="$(OutDir)\..\ixml" | ||||
| 				GenerateDebugInformation="true" | ||||
| 				ProgramDatabaseFile="$(OutDir)\libupnp.pdb" | ||||
| 				ImportLibrary="$(OutDir)\libupnp.lib" | ||||
| @@ -218,14 +214,6 @@ | ||||
| 			Name="sources" | ||||
| 			Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat" | ||||
| 			> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\ActionComplete.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\ActionRequest.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\attr.c" | ||||
| 				> | ||||
| @@ -234,10 +222,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\genlib\client_table\client_table.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\Discovery.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\document.c" | ||||
| 				> | ||||
| @@ -246,18 +230,6 @@ | ||||
| 				RelativePath="..\..\ixml\src\element.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\Event.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\EventSubscribe.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\FileInfo.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\threadutil\src\FreeList.c" | ||||
| 				> | ||||
| @@ -358,10 +330,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_device.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_ResultData.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_server.c" | ||||
| 				> | ||||
| @@ -370,22 +338,10 @@ | ||||
| 				RelativePath="..\..\upnp\src\genlib\net\http\statcodes.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\StateVarComplete.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\StateVarRequest.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\genlib\util\strintmap.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\SubscriptionRequest.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\uuid\sysdep.c" | ||||
| 				> | ||||
| @@ -410,10 +366,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\api\upnpdebug.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\UpnpString.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\upnptools.c" | ||||
| 				> | ||||
| @@ -447,14 +399,6 @@ | ||||
| 			Name="headers" | ||||
| 			Filter="h;hpp;hxx;hm;inl" | ||||
| 			> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\ActionComplete.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\actionrequest.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\client_table.h" | ||||
| 				> | ||||
| @@ -463,22 +407,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\config.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\discovery.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\Event.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\EventSubscribe.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\FileInfo.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\gena.h" | ||||
| 				> | ||||
| @@ -551,10 +479,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\sock.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_ResultData.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\ssdplib.h" | ||||
| 				> | ||||
| @@ -563,14 +487,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\statcodes.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\StateVarComplete.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\statevarrequest.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\statuscodes.h" | ||||
| 				> | ||||
| @@ -579,10 +495,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\strintmap.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\SubscriptionRequest.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\sysdep.h" | ||||
| 				> | ||||
| @@ -591,10 +503,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\unixutil.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\upnp.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\upnp_timeout.h" | ||||
| 				> | ||||
| @@ -603,18 +511,14 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\upnpapi.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\upnpclosesocket.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\upnpdebug.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\UpnpString.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\upnptools.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\uri.h" | ||||
| 				> | ||||
| @@ -640,6 +544,11 @@ | ||||
| 				> | ||||
| 			</File> | ||||
| 		</Filter> | ||||
| 		<Filter | ||||
| 			Name="resources" | ||||
| 			Filter="ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe" | ||||
| 			> | ||||
| 		</Filter> | ||||
| 		<File | ||||
| 			RelativePath="..\..\..\..\libupnp_win32.patch" | ||||
| 			> | ||||
|   | ||||
| @@ -20,7 +20,7 @@ | ||||
| 			OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			ConfigurationType="4" | ||||
| 			CharacterSet="0" | ||||
| 			CharacterSet="2" | ||||
| 			> | ||||
| 			<Tool | ||||
| 				Name="VCPreBuildEventTool" | ||||
| @@ -40,8 +40,8 @@ | ||||
| 			<Tool | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="0" | ||||
| 				AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc" | ||||
| 				PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc" | ||||
| 				PreprocessorDefinitions="DEBUG;WIN32" | ||||
| 				MinimalRebuild="true" | ||||
| 				BasicRuntimeChecks="3" | ||||
| 				RuntimeLibrary="3" | ||||
| @@ -78,10 +78,10 @@ | ||||
| 		</Configuration> | ||||
| 		<Configuration | ||||
| 			Name="Release|Win32" | ||||
| 			OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			ConfigurationType="4" | ||||
| 			CharacterSet="0" | ||||
| 			OutputDirectory="$(SolutionDir)$(ConfigurationName)" | ||||
| 			IntermediateDirectory="$(ConfigurationName)" | ||||
| 			ConfigurationType="1" | ||||
| 			CharacterSet="2" | ||||
| 			WholeProgramOptimization="1" | ||||
| 			> | ||||
| 			<Tool | ||||
| @@ -103,8 +103,6 @@ | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="2" | ||||
| 				EnableIntrinsicFunctions="true" | ||||
| 				AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc" | ||||
| 				PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				RuntimeLibrary="2" | ||||
| 				EnableFunctionLevelLinking="true" | ||||
| 				WarningLevel="3" | ||||
| @@ -120,11 +118,18 @@ | ||||
| 				Name="VCPreLinkEventTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCLibrarianTool" | ||||
| 				Name="VCLinkerTool" | ||||
| 				GenerateDebugInformation="true" | ||||
| 				OptimizeReferences="2" | ||||
| 				EnableCOMDATFolding="2" | ||||
| 				TargetMachine="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCALinkTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManifestTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCXDCMakeTool" | ||||
| 			/> | ||||
| @@ -134,6 +139,9 @@ | ||||
| 			<Tool | ||||
| 				Name="VCFxCopTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCAppVerifierTool" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCPostBuildEventTool" | ||||
| 			/> | ||||
| @@ -163,10 +171,6 @@ | ||||
| 				RelativePath="..\..\ixml\src\ixml.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\ixmldebug.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\ixmlmembuf.c" | ||||
| 				> | ||||
| @@ -197,10 +201,6 @@ | ||||
| 				RelativePath="..\..\ixml\inc\ixml.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\inc\ixmldebug.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\inc\ixmlmembuf.h" | ||||
| 				> | ||||
| @@ -210,6 +210,12 @@ | ||||
| 				> | ||||
| 			</File> | ||||
| 		</Filter> | ||||
| 		<Filter | ||||
| 			Name="Resource Files" | ||||
| 			Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav" | ||||
| 			UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||||
| 			> | ||||
| 		</Filter> | ||||
| 	</Files> | ||||
| 	<Globals> | ||||
| 	</Globals> | ||||
|   | ||||
| @@ -1,29 +1,35 @@ | ||||
|  | ||||
| Microsoft Visual Studio Solution File, Format Version 10.00 | ||||
| # Visual Studio 2008 | ||||
| # Visual C++ Express 2008 | ||||
| Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libupnp", "libupnp.vcproj", "{6227F51A-1498-4C4A-B213-F6FDED605125}" | ||||
| 	ProjectSection(ProjectDependencies) = postProject | ||||
| 		{9C2C266D-35A3-465F-A297-0E21D54E5C89} = {9C2C266D-35A3-465F-A297-0E21D54E5C89} | ||||
| 		{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} = {1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} | ||||
| 	EndProjectSection | ||||
| EndProject | ||||
| Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ixml", "ixml.vcproj", "{9C2C266D-35A3-465F-A297-0E21D54E5C89}" | ||||
| EndProject | ||||
| Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "threadutil", "threadutil.vcproj", "{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}" | ||||
| 	ProjectSection(ProjectDependencies) = postProject | ||||
| 		{6227F51A-1498-4C4A-B213-F6FDED605125} = {6227F51A-1498-4C4A-B213-F6FDED605125} | ||||
| 		{9C2C266D-35A3-465F-A297-0E21D54E5C89} = {9C2C266D-35A3-465F-A297-0E21D54E5C89} | ||||
| 	EndProjectSection | ||||
| EndProject | ||||
| Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "tvctrlpt", "tvctrlpt.vcproj", "{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}" | ||||
| 	ProjectSection(ProjectDependencies) = postProject | ||||
| 		{6227F51A-1498-4C4A-B213-F6FDED605125} = {6227F51A-1498-4C4A-B213-F6FDED605125} | ||||
| 		{9C2C266D-35A3-465F-A297-0E21D54E5C89} = {9C2C266D-35A3-465F-A297-0E21D54E5C89} | ||||
| 		{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} = {1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} | ||||
| 	EndProjectSection | ||||
| EndProject | ||||
| Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "tvdevice", "tvdevice.vcproj", "{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}" | ||||
| 	ProjectSection(ProjectDependencies) = postProject | ||||
| 		{6227F51A-1498-4C4A-B213-F6FDED605125} = {6227F51A-1498-4C4A-B213-F6FDED605125} | ||||
| 		{9C2C266D-35A3-465F-A297-0E21D54E5C89} = {9C2C266D-35A3-465F-A297-0E21D54E5C89} | ||||
| 		{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} = {1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} | ||||
| 	EndProjectSection | ||||
| EndProject | ||||
| Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "tvcombo", "tvcombo.vcproj", "{6365804B-22C6-4D5E-91F3-0C052EB55B4F}" | ||||
| 	ProjectSection(ProjectDependencies) = postProject | ||||
| 		{6227F51A-1498-4C4A-B213-F6FDED605125} = {6227F51A-1498-4C4A-B213-F6FDED605125} | ||||
| 		{9C2C266D-35A3-465F-A297-0E21D54E5C89} = {9C2C266D-35A3-465F-A297-0E21D54E5C89} | ||||
| 		{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} = {1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D} | ||||
| 	EndProjectSection | ||||
| EndProject | ||||
| Global | ||||
|   | ||||
| @@ -1,10 +1,9 @@ | ||||
| <?xml version="1.0" encoding="Windows-1252"?> | ||||
| <VisualStudioProject | ||||
| 	ProjectType="Visual C++" | ||||
| 	Version="9,00" | ||||
| 	Version="9.00" | ||||
| 	Name="libupnp" | ||||
| 	ProjectGUID="{6227F51A-1498-4C4A-B213-F6FDED605125}" | ||||
| 	RootNamespace="libupnp" | ||||
| 	TargetFrameworkVersion="131072" | ||||
| 	> | ||||
| 	<Platforms> | ||||
| @@ -17,13 +16,13 @@ | ||||
| 	<Configurations> | ||||
| 		<Configuration | ||||
| 			Name="Release|Win32" | ||||
| 			OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			OutputDirectory=".\Release" | ||||
| 			IntermediateDirectory=".\Release" | ||||
| 			ConfigurationType="2" | ||||
| 			InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops" | ||||
| 			UseOfMFC="0" | ||||
| 			ATLMinimizesCRunTimeLibraryUsage="false" | ||||
| 			CharacterSet="0" | ||||
| 			CharacterSet="2" | ||||
| 			> | ||||
| 			<Tool | ||||
| 				Name="VCPreBuildEventTool" | ||||
| @@ -51,9 +50,9 @@ | ||||
| 				Optimization="2" | ||||
| 				InlineFunctionExpansion="1" | ||||
| 				AdditionalIncludeDirectories="..\..\pthreads\include,..\ixml\src\inc,..\ixml\inc,..\threadutil\inc,..\upnp\inc,..\upnp\src\inc,.\inc" | ||||
| 				PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP" | ||||
| 				StringPooling="true" | ||||
| 				RuntimeLibrary="2" | ||||
| 				RuntimeLibrary="0" | ||||
| 				EnableFunctionLevelLinking="true" | ||||
| 				PrecompiledHeaderFile=".\Release/libupnp.pch" | ||||
| 				AssemblerListingLocation=".\Release/" | ||||
| @@ -76,7 +75,7 @@ | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCLinkerTool" | ||||
| 				AdditionalDependencies="..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib iphlpapi.lib" | ||||
| 				AdditionalDependencies="odbc32.lib odbccp32.lib ..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib" | ||||
| 				OutputFile=".\Release/libupnp.dll" | ||||
| 				LinkIncremental="1" | ||||
| 				SuppressStartupBanner="true" | ||||
| @@ -118,7 +117,7 @@ | ||||
| 			InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops" | ||||
| 			UseOfMFC="0" | ||||
| 			ATLMinimizesCRunTimeLibraryUsage="false" | ||||
| 			CharacterSet="0" | ||||
| 			CharacterSet="2" | ||||
| 			> | ||||
| 			<Tool | ||||
| 				Name="VCPreBuildEventTool" | ||||
| @@ -145,10 +144,10 @@ | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="0" | ||||
| 				AdditionalIncludeDirectories="..\..\pthreads\include;..\..\ixml\src\inc;..\..\ixml\inc;..\..\threadutil\inc;..\..\upnp\inc;..\..\upnp\src\inc;..\inc;..\msvc" | ||||
| 				PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP" | ||||
| 				MinimalRebuild="true" | ||||
| 				BasicRuntimeChecks="3" | ||||
| 				RuntimeLibrary="3" | ||||
| 				RuntimeLibrary="1" | ||||
| 				PrecompiledHeaderFile="$(OutDir)\libupnp.pch" | ||||
| 				AssemblerListingLocation="$(OutDir)\" | ||||
| 				ObjectFile="$(OutDir)\" | ||||
| @@ -171,7 +170,7 @@ | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCLinkerTool" | ||||
| 				AdditionalDependencies="..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib iphlpapi.lib $(TargetDir)..\ixml\ixml.lib" | ||||
| 				AdditionalDependencies="odbc32.lib odbccp32.lib ..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib" | ||||
| 				OutputFile="$(OutDir)\libupnp.dll" | ||||
| 				LinkIncremental="2" | ||||
| 				SuppressStartupBanner="true" | ||||
| @@ -214,14 +213,6 @@ | ||||
| 			Name="sources" | ||||
| 			Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat" | ||||
| 			> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\ActionComplete.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\ActionRequest.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\attr.c" | ||||
| 				> | ||||
| @@ -230,10 +221,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\genlib\client_table\client_table.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\Discovery.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\ixml\src\document.c" | ||||
| 				> | ||||
| @@ -242,18 +229,6 @@ | ||||
| 				RelativePath="..\..\ixml\src\element.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\Event.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\EventSubscribe.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\FileInfo.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\threadutil\src\FreeList.c" | ||||
| 				> | ||||
| @@ -354,10 +329,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_device.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_ResultData.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_server.c" | ||||
| 				> | ||||
| @@ -366,22 +337,10 @@ | ||||
| 				RelativePath="..\..\upnp\src\genlib\net\http\statcodes.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\StateVarComplete.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\StateVarRequest.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\genlib\util\strintmap.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\SubscriptionRequest.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\uuid\sysdep.c" | ||||
| 				> | ||||
| @@ -406,10 +365,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\api\upnpdebug.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\UpnpString.c" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\api\upnptools.c" | ||||
| 				> | ||||
| @@ -443,14 +398,6 @@ | ||||
| 			Name="headers" | ||||
| 			Filter="h;hpp;hxx;hm;inl" | ||||
| 			> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\ActionComplete.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\ActionRequest.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\client_table.h" | ||||
| 				> | ||||
| @@ -459,22 +406,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\config.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\Discovery.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\Event.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\EventSubscribe.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\FileInfo.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\gena.h" | ||||
| 				> | ||||
| @@ -547,10 +478,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\sock.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\ssdp\ssdp_ResultData.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\ssdplib.h" | ||||
| 				> | ||||
| @@ -559,14 +486,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\statcodes.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\StateVarComplete.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\StateVarRequest.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\statuscodes.h" | ||||
| 				> | ||||
| @@ -575,10 +494,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\strintmap.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\SubscriptionRequest.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\sysdep.h" | ||||
| 				> | ||||
| @@ -587,10 +502,6 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\unixutil.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\upnp.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\upnp_timeout.h" | ||||
| 				> | ||||
| @@ -599,18 +510,14 @@ | ||||
| 				RelativePath="..\..\upnp\src\inc\upnpapi.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\upnpclosesocket.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\upnpdebug.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\UpnpString.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\inc\upnptools.h" | ||||
| 				> | ||||
| 			</File> | ||||
| 			<File | ||||
| 				RelativePath="..\..\upnp\src\inc\uri.h" | ||||
| 				> | ||||
| @@ -636,6 +543,11 @@ | ||||
| 				> | ||||
| 			</File> | ||||
| 		</Filter> | ||||
| 		<Filter | ||||
| 			Name="resources" | ||||
| 			Filter="ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe" | ||||
| 			> | ||||
| 		</Filter> | ||||
| 		<File | ||||
| 			RelativePath="..\..\..\..\libupnp_win32.patch" | ||||
| 			> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <?xml version="1.0" encoding="Windows-1252"?> | ||||
| <VisualStudioProject | ||||
| 	ProjectType="Visual C++" | ||||
| 	Version="9,00" | ||||
| 	Version="9.00" | ||||
| 	Name="threadutil" | ||||
| 	ProjectGUID="{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}" | ||||
| 	RootNamespace="threadutil" | ||||
| @@ -20,7 +20,7 @@ | ||||
| 			OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			ConfigurationType="4" | ||||
| 			CharacterSet="0" | ||||
| 			CharacterSet="2" | ||||
| 			> | ||||
| 			<Tool | ||||
| 				Name="VCPreBuildEventTool" | ||||
| @@ -41,13 +41,12 @@ | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="0" | ||||
| 				AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\ixml\inc;..\..\pthreads\include" | ||||
| 				PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				PreprocessorDefinitions="WIN32;DEBUG" | ||||
| 				MinimalRebuild="true" | ||||
| 				BasicRuntimeChecks="3" | ||||
| 				RuntimeLibrary="3" | ||||
| 				WarningLevel="3" | ||||
| 				DebugInformationFormat="4" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
| @@ -81,10 +80,10 @@ | ||||
| 		</Configuration> | ||||
| 		<Configuration | ||||
| 			Name="Release|Win32" | ||||
| 			OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			OutputDirectory="$(SolutionDir)$(ConfigurationName)" | ||||
| 			IntermediateDirectory="$(ConfigurationName)" | ||||
| 			ConfigurationType="1" | ||||
| 			CharacterSet="0" | ||||
| 			CharacterSet="2" | ||||
| 			WholeProgramOptimization="1" | ||||
| 			> | ||||
| 			<Tool | ||||
| @@ -106,13 +105,10 @@ | ||||
| 				Name="VCCLCompilerTool" | ||||
| 				Optimization="2" | ||||
| 				EnableIntrinsicFunctions="true" | ||||
| 				AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\ixml\inc;..\..\pthreads\include" | ||||
| 				PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS" | ||||
| 				RuntimeLibrary="2" | ||||
| 				EnableFunctionLevelLinking="true" | ||||
| 				WarningLevel="3" | ||||
| 				DebugInformationFormat="3" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <?xml version="1.0" encoding="Windows-1252"?> | ||||
| <VisualStudioProject | ||||
| 	ProjectType="Visual C++" | ||||
| 	Version="9,00" | ||||
| 	Version="9.00" | ||||
| 	Name="tvcombo" | ||||
| 	ProjectGUID="{6365804B-22C6-4D5E-91F3-0C052EB55B4F}" | ||||
| 	RootNamespace="tvcombo" | ||||
| @@ -47,7 +47,6 @@ | ||||
| 				RuntimeLibrary="3" | ||||
| 				WarningLevel="3" | ||||
| 				DebugInformationFormat="4" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
| @@ -60,8 +59,8 @@ | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCLinkerTool" | ||||
| 				AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib $(TargetDir)..\libupnp\libupnp.lib" | ||||
| 				AdditionalLibraryDirectories=""$(TargetDir)..\ixml";"$(TargetDir)..\threadutil";"$(TargetDir)..\libupnp"" | ||||
| 				AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib" | ||||
| 				AdditionalLibraryDirectories=""$(OutDir)";".\out.vc9.$(ConfigurationName)\ixml";".\out.vc9.$(ConfigurationName)\threadutil";".\out.vc9.$(ConfigurationName)\libupnp"" | ||||
| 				GenerateDebugInformation="true" | ||||
| 				TargetMachine="1" | ||||
| 			/> | ||||
| @@ -89,8 +88,8 @@ | ||||
| 		</Configuration> | ||||
| 		<Configuration | ||||
| 			Name="Release|Win32" | ||||
| 			OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)" | ||||
| 			OutputDirectory="$(SolutionDir)$(ConfigurationName)" | ||||
| 			IntermediateDirectory="$(ConfigurationName)" | ||||
| 			ConfigurationType="1" | ||||
| 			CharacterSet="2" | ||||
| 			WholeProgramOptimization="1" | ||||
| @@ -118,7 +117,6 @@ | ||||
| 				EnableFunctionLevelLinking="true" | ||||
| 				WarningLevel="3" | ||||
| 				DebugInformationFormat="3" | ||||
| 				CompileAs="1" | ||||
| 			/> | ||||
| 			<Tool | ||||
| 				Name="VCManagedResourceCompilerTool" | ||||
|   | ||||
							
								
								
									
										154
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										154
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -4,12 +4,12 @@ | ||||
| # | ||||
| # Process this file with autoconf to produce a configure script. | ||||
| # | ||||
| # (C) Copyright 2005-2007 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
| # (C) Copyright 2005-2007 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
| # | ||||
|  | ||||
| AC_PREREQ(2.60) | ||||
|  | ||||
| AC_INIT([libupnp], [1.6.10], [mroberto@users.sourceforge.net]) | ||||
| AC_INIT([libupnp], [1.6.6], [mroberto@users.sourceforge.net]) | ||||
| dnl ############################################################################ | ||||
| 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: | ||||
| @@ -144,77 +144,9 @@ dnl #AC_SUBST([LT_VERSION_THREADUTIL], [4:3:2]) | ||||
| dnl #AC_SUBST([LT_VERSION_UPNP],       [3:5:0]) | ||||
| dnl # | ||||
| dnl ############################################################################ | ||||
| dnl # Release 1.6.7: | ||||
| dnl # "current:revision:age" | ||||
| dnl # | ||||
| dnl # - Code has changed in threadutil | ||||
| dnl #	revision: 3 -> 4 | ||||
| dnl # - Code has changed in upnp | ||||
| dnl #	revision: 5 -> 6 | ||||
| dnl # - Interfaces have been changed, added and removed in upnp | ||||
| dnl #	current: 3 -> 4 | ||||
| dnl #   revision: 6 -> 0 | ||||
| dnl # - Interfaces removed in upnp: | ||||
| dnl #   age: -> 0 | ||||
| dnl # | ||||
| dnl #AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | ||||
| dnl #AC_SUBST([LT_VERSION_THREADUTIL], [5:0:2]) | ||||
| dnl #AC_SUBST([LT_VERSION_UPNP],       [3:5:0]) | ||||
| dnl # | ||||
| dnl # Obs.: 1.6.7 was released with a version error, the correct nubers should | ||||
| dnl # have been: | ||||
| dnl #AC_SUBST([LT_VERSION_UPNP],       [4:0:0]) | ||||
| dnl # | ||||
| dnl ############################################################################ | ||||
| dnl # Release 1.6.8: | ||||
| dnl # "current:revision:age" | ||||
| dnl # | ||||
| dnl # - Code has changed in ixml | ||||
| dnl #	revision: 4 -> 5 | ||||
| dnl # - Code has changed in threadutil | ||||
| dnl #	revision: 0 -> 1 | ||||
| dnl # - Code has changed in upnp | ||||
| dnl #	revision: 0 -> 1 | ||||
| dnl # | ||||
| dnl #AC_SUBST([LT_VERSION_IXML],       [2:5:0]) | ||||
| dnl #AC_SUBST([LT_VERSION_THREADUTIL], [5:1:2]) | ||||
| dnl #AC_SUBST([LT_VERSION_UPNP],       [4:1:0]) | ||||
| dnl # | ||||
| dnl ############################################################################ | ||||
| dnl # Release 1.6.9: | ||||
| dnl # "current:revision:age" | ||||
| dnl # | ||||
| dnl # - Code has changed in threadutil | ||||
| dnl #	revision: 1 -> 2 | ||||
| dnl # - Code has changed in upnp | ||||
| dnl #	revision: 1 -> 2 | ||||
| dnl # | ||||
| dnl #AC_SUBST([LT_VERSION_IXML],       [2:5:0]) | ||||
| dnl #AC_SUBST([LT_VERSION_THREADUTIL], [5:2:2]) | ||||
| dnl #AC_SUBST([LT_VERSION_UPNP],       [4:2:0]) | ||||
| dnl # | ||||
| dnl ############################################################################ | ||||
| dnl # Release 1.6.10: | ||||
| dnl # "current:revision:age" | ||||
| dnl # | ||||
| dnl # - Code has changed inxml  | ||||
| dnl #	revision: 5 -> 6 | ||||
| dnl # - Code has changed in threadutil | ||||
| dnl #	revision: 2 -> 3 | ||||
| dnl # - Code has changed in upnp | ||||
| dnl #	revision: 2 -> 3 | ||||
| dnl # - interface has changed in upnp | ||||
| dnl #   current: 4 -> 5 | ||||
| dnl #   revision: 3 -> 0 | ||||
| dnl # | ||||
| dnl #AC_SUBST([LT_VERSION_IXML],       [2:6:0]) | ||||
| dnl #AC_SUBST([LT_VERSION_THREADUTIL], [5:3:2]) | ||||
| dnl #AC_SUBST([LT_VERSION_UPNP],       [5:0:0]) | ||||
| dnl # | ||||
|  ############################################################################ | ||||
| AC_SUBST([LT_VERSION_IXML],       [2:6:0]) | ||||
| AC_SUBST([LT_VERSION_THREADUTIL], [5:3:2]) | ||||
| AC_SUBST([LT_VERSION_UPNP],       [5:0:0]) | ||||
| AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | ||||
| AC_SUBST([LT_VERSION_THREADUTIL], [4:3:2]) | ||||
| AC_SUBST([LT_VERSION_UPNP],       [3:5:0]) | ||||
| dnl ############################################################################ | ||||
| dnl # Repeating the algorithm to place it closer to the modificatin place: | ||||
| dnl # 	- library code modified:		revision++ | ||||
| @@ -308,21 +240,6 @@ if test "x$enable_tools" = xyes ; then | ||||
| 	AC_DEFINE(UPNP_HAVE_TOOLS, 1, [see upnpconfig.h]) | ||||
| fi | ||||
|  | ||||
| RT_BOOL_ARG_ENABLE([ipv6], [no], [ipv6 support]) | ||||
| if test "x$enable_ipv6" = xyes ; then | ||||
|         AC_DEFINE(UPNP_ENABLE_IPV6, 1, [see upnpconfig.h]) | ||||
| fi | ||||
|  | ||||
| RT_BOOL_ARG_ENABLE([notification_reordering], [yes], [GENA notification reordering in gena_device.c]) | ||||
| if test "x$enable_notification_reordering" = xyes ; then | ||||
|         AC_DEFINE(UPNP_ENABLE_NOTIFICATION_REORDERING, 1, [see upnpconfig.h]) | ||||
| fi | ||||
|  | ||||
| RT_BOOL_ARG_ENABLE([blocking_tcp_connections], [yes], [blocking TCP connections]) | ||||
| if test "x$enable_blocking_tcp_connections" = xyes ; then | ||||
|         AC_DEFINE(UPNP_ENABLE_BLOCKING_TCP_CONNECTIONS, 1, [see upnpconfig.h]) | ||||
| fi | ||||
|  | ||||
|  | ||||
| RT_BOOL_ARG_ENABLE([samples], [yes], [compilation of upnp/sample/ code]) | ||||
|  | ||||
| @@ -408,26 +325,9 @@ AC_DEFINE([_FILE_OFFSET_BITS], [64], [File Offset size]) | ||||
|  | ||||
|  | ||||
| # | ||||
| # 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) | ||||
| # Checks for header files | ||||
| # | ||||
| AC_HEADER_STDC | ||||
| if test "$ac_cv_win32" = "no"; then | ||||
| # libupnp code doesn't use autoconf variables yet, | ||||
| # so just abort if a header file is not found. | ||||
| AC_CHECK_HEADERS( | ||||
| @@ -443,43 +343,19 @@ AC_CHECK_HEADERS( | ||||
| 	sys/ioctl.h \ | ||||
| 	sys/socket.h \ | ||||
| 	sys/time.h \ | ||||
| 	sys/timeb.h \ | ||||
| 	syslog.h \ | ||||
| 	unistd.h \ | ||||
| 	], | ||||
| 	[], | ||||
| 	[AC_MSG_ERROR([required header file missing])]) | ||||
| fi | ||||
|  | ||||
|  | ||||
| # | ||||
| # Checks for typedefs, structures, and compiler characteristics | ||||
| #	 | ||||
| AC_C_CONST | ||||
|  | ||||
| # 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 | ||||
| TYPE_SOCKLEN_T | ||||
|  | ||||
|  | ||||
| # | ||||
| @@ -487,11 +363,7 @@ fi | ||||
| # | ||||
| AC_FUNC_VPRINTF | ||||
| AC_FUNC_FSEEKO | ||||
| # | ||||
| # Solaris needs -lsocket -lnsl -lrt | ||||
| AC_SEARCH_LIBS([bind],           [socket]) | ||||
| AC_SEARCH_LIBS([gethostbyname],  [nsl]) | ||||
| AC_SEARCH_LIBS([sched_getparam], [rt]) | ||||
| AC_CHECK_FUNCS(ftime,, [AC_CHECK_LIB(compat, ftime)]) | ||||
|  | ||||
|  | ||||
| # | ||||
| @@ -548,11 +420,3 @@ AC_CONFIG_FILES([ | ||||
|  | ||||
| AC_OUTPUT | ||||
|  | ||||
| # | ||||
| # Files copied for windows compilation. | ||||
| # | ||||
| echo "configure: copying \"autoconfig.h\"          to \"build/inc/autoconfig.h\"" | ||||
| cp autoconfig.h build/inc/autoconfig.h | ||||
| echo "configure: copying \"upnp/inc/upnpconfig.h\" to \"build/inc/upnpconfig.h\"" | ||||
| cp upnp/inc/upnpconfig.h build/inc/upnpconfig.h | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| # | ||||
| # "Makefile.am" for "libupnp/ixml" | ||||
| # | ||||
| # (C) Copyright 2005 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
| # (C) Copyright 2005 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
| # | ||||
|  | ||||
| SUBDIRS 		= doc | ||||
| @@ -24,23 +24,15 @@ libixml_la_LDFLAGS	= -version-info $(LT_VERSION_IXML) \ | ||||
| 			  -export-symbols-regex '^ixml.*' | ||||
|  | ||||
| libixml_la_SOURCES	= \ | ||||
| 			src/attr.c \ | ||||
| 			src/document.c \ | ||||
| 			src/element.c \ | ||||
| 			src/inc/ixmlmembuf.h \ | ||||
| 			src/inc/ixmlparser.h \ | ||||
| 			src/ixml.c \ | ||||
| 			src/ixmldebug.c \ | ||||
| 			src/ixmlparser.c \ | ||||
| 			src/ixmlmembuf.c \ | ||||
| 			src/ixml.c src/node.c src/ixmlparser.c \ | ||||
| 			src/ixmlmembuf.c src/nodeList.c \ | ||||
| 			src/element.c src/attr.c src/document.c \ | ||||
| 			src/namedNodeMap.c \ | ||||
| 			src/node.c \ | ||||
| 			src/nodeList.c | ||||
| 			src/inc/ixmlmembuf.h src/inc/ixmlparser.h | ||||
|  | ||||
| upnpincludedir		= $(includedir)/upnp | ||||
| upnpinclude_HEADERS	= \ | ||||
| 			inc/ixml.h \ | ||||
| 			inc/ixmldebug.h | ||||
| upnpinclude_HEADERS	= inc/ixml.h  | ||||
|  | ||||
|  | ||||
| check_PROGRAMS          = test_document | ||||
| TESTS                   = test/test_document.sh | ||||
| @@ -55,3 +47,4 @@ dist-hook: | ||||
| clean-local: | ||||
| 	@if [ -d bin ] ; then  rm -rf bin ; fi | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										2718
									
								
								ixml/inc/ixml.h
									
									
									
									
									
								
							
							
						
						
									
										2718
									
								
								ixml/inc/ixml.h
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,72 +0,0 @@ | ||||
|  | ||||
|  | ||||
| #ifndef IXMLDEBUG_H | ||||
| #define IXMLDEBUG_H | ||||
|  | ||||
|  | ||||
| #include "UpnpGlobal.h" | ||||
| #include "ixml.h" | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
|  * \brief Auxiliar routines to aid debugging. | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Prints the debug statement either on the standard output or log file | ||||
|  * along with the information from where this debug statement is coming. | ||||
|  */  | ||||
| #ifdef DEBUG | ||||
| void IxmlPrintf( | ||||
| 	/*! [in] The file name, usually __FILE__. */ | ||||
| 	const char *DbgFileName, | ||||
| 	/*! [in] The line number, usually __LINE__ or a variable that got the | ||||
| 	 * __LINE__ at the appropriate place. */ | ||||
| 	int DbgLineNo, | ||||
| 	/*! [in] The function name. */ | ||||
| 	const char *FunctionName, | ||||
| 	/*! [in] Printf like format specification. */ | ||||
| 	const char* FmtStr, | ||||
| 	/*! [in] Printf like Variable number of arguments that will go in the debug | ||||
| 	 * statement. */ | ||||
| 	...) | ||||
| #if (__GNUC__ >= 3) | ||||
| 	/* This enables printf like format checking by the compiler */ | ||||
| 	__attribute__((format (__printf__, 4, 5))) | ||||
| #endif | ||||
| ; | ||||
| #else /* DEBUG */ | ||||
| static UPNP_INLINE void IxmlPrintf( | ||||
| 	const char *FmtStr, | ||||
| 	...) | ||||
| { | ||||
| 	FmtStr = FmtStr; | ||||
| } | ||||
| #endif /* DEBUG */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Print the node names and values of a XML tree. | ||||
|  */ | ||||
| #ifdef DEBUG | ||||
| void printNodes( | ||||
| 	/*! [in] The root of the tree to print. */ | ||||
| 	IXML_Node *tmpRoot, | ||||
| 	/*! [in] The depth to print. */ | ||||
| 	int depth); | ||||
| #else | ||||
| static UPNP_INLINE void printNodes( | ||||
| 	IXML_Node *tmpRoot, | ||||
| 	int depth) | ||||
| { | ||||
| 	tmpRoot = tmpRoot; | ||||
| 	depth = depth; | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #endif /* IXMLDEBUG_H */ | ||||
|  | ||||
| @@ -1,53 +1,60 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "ixmlparser.h" | ||||
|  | ||||
|  | ||||
| #include <string.h> | ||||
|  | ||||
|  | ||||
| void ixmlAttr_init(IN IXML_Attr *attr) | ||||
| /*================================================================ | ||||
| *   Function: Attr_init | ||||
| *       Initializes an attribute node | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlAttr_init( IN IXML_Attr * attr ) | ||||
| { | ||||
|     if( attr != NULL ) { | ||||
|         memset( attr, 0, sizeof( IXML_Attr ) ); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixmlAttr_free(IN IXML_Attr *attr) | ||||
| /*================================================================ | ||||
| *   Function: Attr_free | ||||
| *       Frees an attribute node. | ||||
| *       external function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlAttr_free( IN IXML_Attr * attr ) | ||||
| { | ||||
|     if( attr != NULL ) { | ||||
|         ixmlNode_free( ( IXML_Node * ) attr ); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,97 +1,119 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #include "ixmldebug.h" | ||||
| #include "ixmlparser.h" | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #include "ixmlparser.h" | ||||
|  | ||||
| void ixmlDocument_init(IXML_Document *doc) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_init | ||||
| *       It initialize the document structure. | ||||
| *       External function. | ||||
| *    | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlDocument_init( IN IXML_Document * doc ) | ||||
| { | ||||
|     memset( doc, 0, sizeof( IXML_Document ) ); | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixmlDocument_free(IXML_Document *doc) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_free | ||||
| *       It frees the whole document tree. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlDocument_free( IN IXML_Document * doc ) | ||||
| { | ||||
|     if( doc != NULL ) { | ||||
|         ixmlNode_free( ( IXML_Node * ) doc ); | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * When this function is called first time, nodeptr is the root of the subtree, | ||||
|  * so it is not necessay to do two steps recursion. | ||||
| /*================================================================ | ||||
| *   ixmlDocument_setOwnerDocument | ||||
| *        | ||||
| *       When this function is called first time, nodeptr is the root | ||||
| *       of the subtree, so it is not necessay to do two steps | ||||
| *       recursion. | ||||
| *         | ||||
| *       Internal function called by ixmlDocument_importNode | ||||
|  */ | ||||
| static void ixmlDocument_setOwnerDocument( | ||||
| 	/*! [in] The document node. */ | ||||
| 	IXML_Document *doc, | ||||
| 	/*! [in] \todo documentation. */ | ||||
| 	IXML_Node *nodeptr) | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlDocument_setOwnerDocument( IN IXML_Document * doc, | ||||
|                                IN IXML_Node * nodeptr ) | ||||
| { | ||||
|     if( nodeptr != NULL ) { | ||||
|         nodeptr->ownerDocument = doc; | ||||
| 		ixmlDocument_setOwnerDocument( | ||||
| 			doc, ixmlNode_getFirstChild(nodeptr)); | ||||
| 		ixmlDocument_setOwnerDocument( | ||||
| 			doc, ixmlNode_getNextSibling(nodeptr)); | ||||
|         ixmlDocument_setOwnerDocument( doc, | ||||
|                                        ixmlNode_getFirstChild( nodeptr ) ); | ||||
|         ixmlDocument_setOwnerDocument( doc, | ||||
|                                        ixmlNode_getNextSibling | ||||
|                                        ( nodeptr ) ); | ||||
|     } | ||||
| } | ||||
|  | ||||
| /*================================================================ | ||||
| *   ixmlDocument_importNode | ||||
| *       Imports a node from another document to this document. The | ||||
| *       returned node has no parent; (parentNode is null). The source | ||||
| *       node is not altered or removed from the original document; | ||||
| *       this method creates a new copy of the source node. | ||||
|   | ||||
| int ixmlDocument_importNode( | ||||
| 	IXML_Document *doc, | ||||
| 	IXML_Node *importNode, | ||||
| 	BOOL deep, | ||||
| 	IXML_Node **rtNode) | ||||
| *       For all nodes, importing a node creates a node object owned | ||||
| *       by the importing document, with attribute values identical to | ||||
| *       the source node's nodeName and nodeType, plus the attributes | ||||
| *       related to namespaces (prefix, localName, and namespaceURI). | ||||
| *       As in the cloneNode operation on a node, the source node is | ||||
| *       not altered. | ||||
| *        | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlDocument_importNode( IN IXML_Document * doc, | ||||
|                          IN IXML_Node * importNode, | ||||
|                          IN BOOL deep, | ||||
|                          OUT IXML_Node ** rtNode ) | ||||
| { | ||||
|     unsigned short nodeType; | ||||
|     IXML_Node *newNode; | ||||
|  | ||||
|     *rtNode = NULL; | ||||
|  | ||||
| 	if (doc == NULL || importNode == NULL) { | ||||
|     if( ( doc == NULL ) || ( importNode == NULL ) ) { | ||||
|         return IXML_INVALID_PARAMETER; | ||||
|     } | ||||
|  | ||||
| @@ -111,16 +133,29 @@ int ixmlDocument_importNode( | ||||
|     return IXML_SUCCESS; | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlDocument_createElementEx( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString tagName, | ||||
| 	IXML_Element **rtElement) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createElementEx | ||||
| *       Creates an element of the type specified.  | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       doc:        pointer to document | ||||
| *       tagName:    The name of the element, it is case-sensitive. | ||||
| *   Return Value: | ||||
| *       IXML_SUCCESS | ||||
| *       IXML_INVALID_PARAMETER:     if either doc or tagName is NULL | ||||
| *       IXML_INSUFFICIENT_MEMORY:   if not enough memory to finish this operations. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlDocument_createElementEx( IN IXML_Document * doc, | ||||
|                               IN const DOMString tagName, | ||||
|                               OUT IXML_Element ** rtElement ) | ||||
| { | ||||
|  | ||||
|     int errCode = IXML_SUCCESS; | ||||
|     IXML_Element *newElement = NULL; | ||||
|  | ||||
| 	if (doc == NULL || tagName == NULL) { | ||||
|     if( ( doc == NULL ) || ( tagName == NULL ) ) { | ||||
|         errCode = IXML_INVALID_PARAMETER; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| @@ -139,7 +174,7 @@ int ixmlDocument_createElementEx( | ||||
|         errCode = IXML_INSUFFICIENT_MEMORY; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| 	/* set the node fields */ | ||||
|     // set the node fields  | ||||
|     newElement->n.nodeType = eELEMENT_NODE; | ||||
|     newElement->n.nodeName = strdup( tagName ); | ||||
|     if( newElement->n.nodeName == NULL ) { | ||||
| @@ -153,23 +188,46 @@ int ixmlDocument_createElementEx( | ||||
|  | ||||
|   ErrorHandler: | ||||
|     *rtElement = newElement; | ||||
|  | ||||
|     return errCode; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Element *ixmlDocument_createElement( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString tagName) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createElement | ||||
| *       Creates an element of the type specified.  | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       doc:        pointer to document | ||||
| *       tagName:    The name of the element, it is case-sensitive. | ||||
| *   Return Value:  | ||||
| *       A new element object with the nodeName set to tagName, and | ||||
| *       localName, prefix and namespaceURI set to null. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Element * | ||||
| ixmlDocument_createElement( IN IXML_Document * doc, | ||||
|                             IN const DOMString tagName ) | ||||
| { | ||||
|     IXML_Element *newElement = NULL; | ||||
|  | ||||
|     ixmlDocument_createElementEx( doc, tagName, &newElement ); | ||||
|     return newElement; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlDocument_createDocumentEx(IXML_Document **rtDoc) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createDocumentEx | ||||
| *       Creates an document object | ||||
| *       Internal function. | ||||
| *   Parameters: | ||||
| *       rtDoc:  the document created or NULL on failure | ||||
| *   Return Value: | ||||
| *       IXML_SUCCESS | ||||
| *       IXML_INSUFFICIENT_MEMORY:   if not enough memory to finish this operations. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlDocument_createDocumentEx( OUT IXML_Document ** rtDoc ) | ||||
| { | ||||
|     IXML_Document *doc; | ||||
|     int errCode = IXML_SUCCESS; | ||||
| @@ -199,27 +257,49 @@ ErrorHandler: | ||||
|     return errCode; | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Document *ixmlDocument_createDocument() | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createDocument | ||||
| *       Creates an document object | ||||
| *       Internal function. | ||||
| *   Parameters: | ||||
| *       none | ||||
| *   Return Value: | ||||
| *       A new document object with the nodeName set to "#document". | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Document * | ||||
| ixmlDocument_createDocument() | ||||
| { | ||||
|     IXML_Document *doc = NULL; | ||||
|  | ||||
|     ixmlDocument_createDocumentEx( &doc ); | ||||
|  | ||||
|     return doc; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlDocument_createTextNodeEx( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString data, | ||||
| 	IXML_Node **textNode) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createTextNodeEx | ||||
| *       Creates an text node.  | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       data: text data for the text node. It is stored in nodeValue field. | ||||
| *   Return Value: | ||||
| *       IXML_SUCCESS | ||||
| *       IXML_INVALID_PARAMETER:     if either doc or data is NULL | ||||
| *       IXML_INSUFFICIENT_MEMORY:   if not enough memory to finish this operations. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlDocument_createTextNodeEx( IN IXML_Document * doc, | ||||
|                                IN const char *data, | ||||
|                                OUT IXML_Node ** textNode ) | ||||
| { | ||||
|     IXML_Node *returnNode; | ||||
|     int rc = IXML_SUCCESS; | ||||
|  | ||||
|     returnNode = NULL; | ||||
| 	if (doc == NULL || data == NULL) { | ||||
|     if( ( doc == NULL ) || ( data == NULL ) ) { | ||||
|         rc = IXML_INVALID_PARAMETER; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| @@ -229,7 +309,7 @@ int ixmlDocument_createTextNodeEx( | ||||
|         rc = IXML_INSUFFICIENT_MEMORY; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| 	/* initialize the node */ | ||||
|     // initialize the node | ||||
|     ixmlNode_init( returnNode ); | ||||
|  | ||||
|     returnNode->nodeName = strdup( TEXTNODENAME ); | ||||
| @@ -239,7 +319,7 @@ int ixmlDocument_createTextNodeEx( | ||||
|         rc = IXML_INSUFFICIENT_MEMORY; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| 	/* add in node value */ | ||||
|     // add in node value | ||||
|     if( data != NULL ) { | ||||
|         returnNode->nodeValue = strdup( data ); | ||||
|         if( returnNode->nodeValue == NULL ) { | ||||
| @@ -256,12 +336,22 @@ int ixmlDocument_createTextNodeEx( | ||||
|   ErrorHandler: | ||||
|     *textNode = returnNode; | ||||
|     return rc; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Node *ixmlDocument_createTextNode( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString data) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createTextNode | ||||
| *       Creates an text node.  | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       data: text data for the text node. It is stored in nodeValue field. | ||||
| *   Return Value: | ||||
| *       The new text node. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Node * | ||||
| ixmlDocument_createTextNode( IN IXML_Document * doc, | ||||
|                              IN const char *data ) | ||||
| { | ||||
|     IXML_Node *returnNode = NULL; | ||||
|  | ||||
| @@ -270,11 +360,21 @@ IXML_Node *ixmlDocument_createTextNode( | ||||
|     return returnNode; | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlDocument_createAttributeEx( | ||||
| 	IXML_Document *doc, | ||||
| 	const char *name, | ||||
| 	IXML_Attr **rtAttr) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createAttributeEx | ||||
| *       Creates an attribute of the given name.              | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       name: The name of the Attribute node. | ||||
| *   Return Value: | ||||
| *       IXML_SUCCESS | ||||
| *       IXML_INSUFFICIENT_MEMORY:   if not enough memory to finish this operations. | ||||
| * | ||||
| ================================================================*/ | ||||
| int | ||||
| ixmlDocument_createAttributeEx( IN IXML_Document * doc, | ||||
|                                 IN const char *name, | ||||
|                                 OUT IXML_Attr ** rtAttr ) | ||||
| { | ||||
|     IXML_Attr *attrNode = NULL; | ||||
|     int errCode = IXML_SUCCESS; | ||||
| @@ -285,7 +385,7 @@ int ixmlDocument_createAttributeEx( | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
|  | ||||
| 	if (doc == NULL || name == NULL) { | ||||
|     if( ( doc == NULL ) || ( name == NULL ) ) { | ||||
|         ixmlAttr_free( attrNode ); | ||||
|         attrNode = NULL; | ||||
|         errCode = IXML_INVALID_PARAMETER; | ||||
| @@ -293,9 +393,10 @@ int ixmlDocument_createAttributeEx( | ||||
|     } | ||||
|  | ||||
|     ixmlAttr_init( attrNode ); | ||||
|  | ||||
|     attrNode->n.nodeType = eATTRIBUTE_NODE; | ||||
|  | ||||
| 	/* set the node fields */ | ||||
|     // set the node fields | ||||
|     attrNode->n.nodeName = strdup( name ); | ||||
|     if( attrNode->n.nodeName == NULL ) { | ||||
|         ixmlAttr_free( attrNode ); | ||||
| @@ -309,31 +410,56 @@ int ixmlDocument_createAttributeEx( | ||||
|   ErrorHandler: | ||||
|     *rtAttr = attrNode; | ||||
|     return errCode; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Attr *ixmlDocument_createAttribute( | ||||
| 	IXML_Document *doc, | ||||
| 	const char *name) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createAttribute | ||||
| *       Creates an attribute of the given name.              | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       name: The name of the Attribute node. | ||||
| *   Return Value:    | ||||
| *       A new attr object with the nodeName attribute set to the | ||||
| *       given name, and the localName, prefix and namespaceURI set to NULL. | ||||
| *       The value of the attribute is the empty string. | ||||
| * | ||||
| ================================================================*/ | ||||
| IXML_Attr * | ||||
| ixmlDocument_createAttribute( IN IXML_Document * doc, | ||||
|                               IN const char *name ) | ||||
| { | ||||
|     IXML_Attr *attrNode = NULL; | ||||
|  | ||||
|     ixmlDocument_createAttributeEx( doc, name, &attrNode ); | ||||
|  | ||||
|     return attrNode; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlDocument_createAttributeNSEx( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString namespaceURI, | ||||
| 	const DOMString qualifiedName, | ||||
| 	IXML_Attr **rtAttr ) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createAttributeNSEx | ||||
| *       Creates an attrbute of the given name and namespace URI | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       namespaceURI: the namespace fo the attribute to create | ||||
| *       qualifiedName: qualifiedName of the attribute to instantiate | ||||
| *   Return Value: | ||||
| *       IXML_SUCCESS | ||||
| *       IXML_INVALID_PARAMETER:     if either doc,namespaceURI or qualifiedName is NULL | ||||
| *       IXML_INSUFFICIENT_MEMORY:   if not enough memory to finish this operations. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlDocument_createAttributeNSEx( IN IXML_Document * doc, | ||||
|                                   IN const DOMString namespaceURI, | ||||
|                                   IN const DOMString qualifiedName, | ||||
|                                   OUT IXML_Attr ** rtAttr ) | ||||
| { | ||||
|     IXML_Attr *attrNode = NULL; | ||||
|     int errCode = IXML_SUCCESS; | ||||
|  | ||||
| 	if (doc == NULL || namespaceURI == NULL || qualifiedName == NULL) { | ||||
|     if( ( doc == NULL ) || ( namespaceURI == NULL ) | ||||
|         || ( qualifiedName == NULL ) ) { | ||||
|         errCode = IXML_INVALID_PARAMETER; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| @@ -343,7 +469,7 @@ int ixmlDocument_createAttributeNSEx( | ||||
|     if( errCode != IXML_SUCCESS ) { | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| 	/* set the namespaceURI field */ | ||||
|     // set the namespaceURI field  | ||||
|     attrNode->n.namespaceURI = strdup( namespaceURI ); | ||||
|     if( attrNode->n.namespaceURI == NULL ) { | ||||
|         ixmlAttr_free( attrNode ); | ||||
| @@ -351,7 +477,7 @@ int ixmlDocument_createAttributeNSEx( | ||||
|         errCode = IXML_INSUFFICIENT_MEMORY; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| 	/* set the localName and prefix */ | ||||
|     // set the localName and prefix  | ||||
|     errCode = | ||||
|         ixmlNode_setNodeName( ( IXML_Node * ) attrNode, qualifiedName ); | ||||
|     if( errCode != IXML_SUCCESS ) { | ||||
| @@ -363,43 +489,68 @@ int ixmlDocument_createAttributeNSEx( | ||||
|   ErrorHandler: | ||||
|     *rtAttr = attrNode; | ||||
|     return errCode; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Attr *ixmlDocument_createAttributeNS( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString namespaceURI, | ||||
| 	const DOMString qualifiedName) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createAttributeNS | ||||
| *       Creates an attrbute of the given name and namespace URI | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       namespaceURI: the namespace fo the attribute to create | ||||
| *       qualifiedName: qualifiedName of the attribute to instantiate | ||||
| *   Return Value:    | ||||
| *       Creates an attribute node with the given namespaceURI and | ||||
| *       qualifiedName. The prefix and localname are extracted from  | ||||
| *       the qualifiedName. The node value is empty. | ||||
| *	 | ||||
| *=================================================================*/ | ||||
| IXML_Attr * | ||||
| ixmlDocument_createAttributeNS( IN IXML_Document * doc, | ||||
|                                 IN const DOMString namespaceURI, | ||||
|                                 IN const DOMString qualifiedName ) | ||||
| { | ||||
|     IXML_Attr *attrNode = NULL; | ||||
|  | ||||
| 	ixmlDocument_createAttributeNSEx( | ||||
| 		doc, namespaceURI, qualifiedName, &attrNode); | ||||
|  | ||||
|     ixmlDocument_createAttributeNSEx( doc, namespaceURI, qualifiedName, | ||||
|                                       &attrNode ); | ||||
|     return attrNode; | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlDocument_createCDATASectionEx( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString data, | ||||
| 	IXML_CDATASection **rtCD) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createCDATASectionEx | ||||
| *       Creates an CDATASection node whose value is the specified string | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       data: the data for the CDATASection contents. | ||||
| *   Return Value: | ||||
| *       IXML_SUCCESS | ||||
| *       IXML_INVALID_PARAMETER:     if either doc or data is NULL | ||||
| *       IXML_INSUFFICIENT_MEMORY:   if not enough memory to finish this operations. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlDocument_createCDATASectionEx( IN IXML_Document * doc, | ||||
|                                    IN const DOMString data, | ||||
|                                    OUT IXML_CDATASection ** rtCD ) | ||||
| { | ||||
|     int errCode = IXML_SUCCESS; | ||||
|     IXML_CDATASection *cDSectionNode = NULL; | ||||
|  | ||||
| 	if(doc == NULL || data == NULL) { | ||||
|     if( ( doc == NULL ) || ( data == NULL ) ) { | ||||
|         errCode = IXML_INVALID_PARAMETER; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
|  | ||||
| 	cDSectionNode = (IXML_CDATASection *)malloc(sizeof (IXML_CDATASection)); | ||||
|     cDSectionNode = | ||||
|         ( IXML_CDATASection * ) malloc( sizeof( IXML_CDATASection ) ); | ||||
|     if( cDSectionNode == NULL ) { | ||||
|         errCode = IXML_INSUFFICIENT_MEMORY; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
|  | ||||
|     ixmlCDATASection_init( cDSectionNode ); | ||||
|  | ||||
|     cDSectionNode->n.nodeType = eCDATA_SECTION_NODE; | ||||
|     cDSectionNode->n.nodeName = strdup( CDATANODENAME ); | ||||
|     if( cDSectionNode->n.nodeName == NULL ) { | ||||
| @@ -422,58 +573,80 @@ int ixmlDocument_createCDATASectionEx( | ||||
|   ErrorHandler: | ||||
|     *rtCD = cDSectionNode; | ||||
|     return errCode; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_CDATASection *ixmlDocument_createCDATASection( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString data) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createCDATASection | ||||
| *       Creates an CDATASection node whose value is the specified string | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       data: the data for the CDATASection contents. | ||||
| *   Return Value:    | ||||
| *       The new CDATASection object. | ||||
| *	 | ||||
| *=================================================================*/ | ||||
| IXML_CDATASection * | ||||
| ixmlDocument_createCDATASection( IN IXML_Document * doc, | ||||
|                                  IN const DOMString data ) | ||||
| { | ||||
|  | ||||
|     IXML_CDATASection *cDSectionNode = NULL; | ||||
|  | ||||
|     ixmlDocument_createCDATASectionEx( doc, data, &cDSectionNode ); | ||||
|  | ||||
|     return cDSectionNode; | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlDocument_createElementNSEx( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString namespaceURI, | ||||
| 	const DOMString qualifiedName, | ||||
| 	IXML_Element **rtElement) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createElementNSEx | ||||
| *       Creates an element of the given qualified name and namespace URI. | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       namespaceURI: the namespace URI of the element to create. | ||||
| *       qualifiedName: the qualified name of the element to instantiate. | ||||
| *   Return Value:    | ||||
| *   Return Value: | ||||
| *       IXML_SUCCESS | ||||
| *       IXML_INVALID_PARAMETER:     if either doc,namespaceURI or qualifiedName is NULL | ||||
| *       IXML_INSUFFICIENT_MEMORY:   if not enough memory to finish this operations. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlDocument_createElementNSEx( IN IXML_Document * doc, | ||||
|                                 IN const DOMString namespaceURI, | ||||
|                                 IN const DOMString qualifiedName, | ||||
|                                 OUT IXML_Element ** rtElement ) | ||||
| { | ||||
|  | ||||
|     IXML_Element *newElement = NULL; | ||||
| 	int ret = IXML_SUCCESS; | ||||
| 	int line = 0; | ||||
|     int errCode = IXML_SUCCESS; | ||||
|  | ||||
| 	if (doc == NULL || namespaceURI == NULL || qualifiedName == NULL) { | ||||
| 		line = __LINE__; | ||||
| 		ret = IXML_INVALID_PARAMETER; | ||||
|     if( ( doc == NULL ) || ( namespaceURI == NULL ) | ||||
|         || ( qualifiedName == NULL ) ) { | ||||
|         errCode = IXML_INVALID_PARAMETER; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
|  | ||||
| 	ret = ixmlDocument_createElementEx(doc, qualifiedName, &newElement); | ||||
| 	if (ret != IXML_SUCCESS) { | ||||
| 		line = __LINE__; | ||||
|     errCode = | ||||
|         ixmlDocument_createElementEx( doc, qualifiedName, &newElement ); | ||||
|     if( errCode != IXML_SUCCESS ) { | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| 	/* set the namespaceURI field */ | ||||
|     // set the namespaceURI field  | ||||
|     newElement->n.namespaceURI = strdup( namespaceURI ); | ||||
|     if( newElement->n.namespaceURI == NULL ) { | ||||
| 		line = __LINE__; | ||||
|         ixmlElement_free( newElement ); | ||||
|         newElement = NULL; | ||||
| 		ret = IXML_INSUFFICIENT_MEMORY; | ||||
|         errCode = IXML_INSUFFICIENT_MEMORY; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
| 	/* set the localName and prefix */ | ||||
| 	ret = ixmlNode_setNodeName((IXML_Node *)newElement, qualifiedName); | ||||
| 	if (ret != IXML_SUCCESS) { | ||||
| 		line = __LINE__; | ||||
|     // set the localName and prefix  | ||||
|     errCode = | ||||
|         ixmlNode_setNodeName( ( IXML_Node * ) newElement, qualifiedName ); | ||||
|     if( errCode != IXML_SUCCESS ) { | ||||
|         ixmlElement_free( newElement ); | ||||
|         newElement = NULL; | ||||
| 		ret = IXML_INSUFFICIENT_MEMORY; | ||||
|         errCode = IXML_INSUFFICIENT_MEMORY; | ||||
|         goto ErrorHandler; | ||||
|     } | ||||
|  | ||||
| @@ -481,70 +654,115 @@ int ixmlDocument_createElementNSEx( | ||||
|  | ||||
|   ErrorHandler: | ||||
|     *rtElement = newElement; | ||||
| 	if (ret != IXML_SUCCESS) { | ||||
| 		IxmlPrintf(__FILE__, line, "ixmlDocument_createElementNSEx", "Error %d\n", ret); | ||||
|     return errCode; | ||||
|  | ||||
| } | ||||
|  | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Element *ixmlDocument_createElementNS( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString namespaceURI, | ||||
| 	const DOMString qualifiedName) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_createElementNS | ||||
| *       Creates an element of the given qualified name and namespace URI. | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       namespaceURI: the namespace URI of the element to create. | ||||
| *       qualifiedName: the qualified name of the element to instantiate. | ||||
| *   Return Value:    | ||||
| *       The new element object with tagName qualifiedName, prefix and | ||||
| *       localName extraced from qualfiedName, nodeName of qualfiedName, | ||||
| *	    namespaceURI of namespaceURI. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Element * | ||||
| ixmlDocument_createElementNS( IN IXML_Document * doc, | ||||
|                               IN const DOMString namespaceURI, | ||||
|                               IN const DOMString qualifiedName ) | ||||
| { | ||||
|     IXML_Element *newElement = NULL; | ||||
|  | ||||
| 	ixmlDocument_createElementNSEx(doc, namespaceURI, qualifiedName, &newElement); | ||||
|  | ||||
|     ixmlDocument_createElementNSEx( doc, namespaceURI, qualifiedName, | ||||
|                                     &newElement ); | ||||
|     return newElement; | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_NodeList *ixmlDocument_getElementsByTagName( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString tagName) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_getElementsByTagName | ||||
| *       Returns a nodeList of all the Elements with a given tag name | ||||
| *       in the order in which they are encountered in a preorder traversal | ||||
| *       of the document tree. | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       tagName: the name of the tag to match on. The special value "*" | ||||
| *                matches all tags. | ||||
| *   Return Value: | ||||
| *       A new nodeList object containing all the matched Elements.     | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_NodeList * | ||||
| ixmlDocument_getElementsByTagName( IN IXML_Document * doc, | ||||
|                                    IN const char *tagName ) | ||||
| { | ||||
|     IXML_NodeList *returnNodeList = NULL; | ||||
|  | ||||
| 	if (doc == NULL || tagName == NULL) { | ||||
|     if( ( doc == NULL ) || ( tagName == NULL ) ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
| 	ixmlNode_getElementsByTagName((IXML_Node *)doc, tagName, &returnNodeList); | ||||
|  | ||||
|     ixmlNode_getElementsByTagName( ( IXML_Node * ) doc, tagName, | ||||
|                                    &returnNodeList ); | ||||
|     return returnNodeList; | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_NodeList *ixmlDocument_getElementsByTagNameNS( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString namespaceURI, | ||||
| 	const DOMString localName) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_getElementsByTagNameNS | ||||
| *       Returns a nodeList of all the Elements with a given local name and | ||||
| *       namespace URI in the order in which they are encountered in a  | ||||
| *       preorder traversal of the document tree. | ||||
| *       External function. | ||||
| *   Parameters: | ||||
| *       namespaceURI: the namespace of the elements to match on. The special | ||||
| *               value "*" matches all namespaces. | ||||
| *       localName: the local name of the elements to match on. The special | ||||
| *               value "*" matches all local names. | ||||
| *   Return Value: | ||||
| *       A new nodeList object containing all the matched Elements.     | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_NodeList * | ||||
| ixmlDocument_getElementsByTagNameNS( IN IXML_Document * doc, | ||||
|                                      IN const DOMString namespaceURI, | ||||
|                                      IN const DOMString localName ) | ||||
| { | ||||
|     IXML_NodeList *returnNodeList = NULL; | ||||
|  | ||||
| 	if (doc == NULL || namespaceURI == NULL || localName == NULL) { | ||||
|     if( ( doc == NULL ) || ( namespaceURI == NULL ) | ||||
|         || ( localName == NULL ) ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
| 	ixmlNode_getElementsByTagNameNS( | ||||
| 		(IXML_Node *)doc, namespaceURI, localName, &returnNodeList); | ||||
|  | ||||
|     ixmlNode_getElementsByTagNameNS( ( IXML_Node * ) doc, namespaceURI, | ||||
|                                      localName, &returnNodeList ); | ||||
|     return returnNodeList; | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Element *ixmlDocument_getElementById( | ||||
| 	IXML_Document *doc, | ||||
| 	const DOMString tagName) | ||||
| /*================================================================ | ||||
| *   ixmlDocument_getElementById | ||||
| *       Returns the element whose ID is given by tagName. If no such | ||||
| *       element exists, returns null.  | ||||
| *       External function. | ||||
| *   Parameter: | ||||
| *       tagName: the tag name for an element. | ||||
| *   Return Values: | ||||
| *       The matching element. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Element * | ||||
| ixmlDocument_getElementById( IN IXML_Document * doc, | ||||
|                              IN const DOMString tagName ) | ||||
| { | ||||
|     IXML_Element *rtElement = NULL; | ||||
|     IXML_Node *nodeptr = ( IXML_Node * ) doc; | ||||
|     const char *name; | ||||
|  | ||||
| 	if (nodeptr == NULL || tagName == NULL) { | ||||
|     if( ( nodeptr == NULL ) || ( tagName == NULL ) ) { | ||||
|         return rtElement; | ||||
|     } | ||||
|  | ||||
| @@ -558,26 +776,29 @@ IXML_Element *ixmlDocument_getElementById( | ||||
|             rtElement = ( IXML_Element * ) nodeptr; | ||||
|             return rtElement; | ||||
|         } else { | ||||
| 			rtElement = ixmlDocument_getElementById( | ||||
| 				(IXML_Document *)ixmlNode_getFirstChild(nodeptr), | ||||
|             rtElement = ixmlDocument_getElementById( ( IXML_Document * ) | ||||
|                                                      ixmlNode_getFirstChild | ||||
|                                                      ( nodeptr ), | ||||
|                                                      tagName ); | ||||
|             if( rtElement == NULL ) { | ||||
| 				rtElement = ixmlDocument_getElementById( | ||||
| 					(IXML_Document *)ixmlNode_getNextSibling(nodeptr), | ||||
|                 rtElement = ixmlDocument_getElementById( ( IXML_Document | ||||
|                                                            * ) | ||||
|                                                          ixmlNode_getNextSibling | ||||
|                                                          ( nodeptr ), | ||||
|                                                          tagName ); | ||||
|             } | ||||
|         } | ||||
|     } else { | ||||
| 		rtElement = ixmlDocument_getElementById( | ||||
| 			(IXML_Document *)ixmlNode_getFirstChild(nodeptr), | ||||
| 			tagName); | ||||
|         rtElement = ixmlDocument_getElementById( ( IXML_Document * ) | ||||
|                                                  ixmlNode_getFirstChild | ||||
|                                                  ( nodeptr ), tagName ); | ||||
|         if( rtElement == NULL ) { | ||||
| 			rtElement = ixmlDocument_getElementById( | ||||
| 				(IXML_Document *)ixmlNode_getNextSibling(nodeptr), | ||||
|             rtElement = ixmlDocument_getElementById( ( IXML_Document * ) | ||||
|                                                      ixmlNode_getNextSibling | ||||
|                                                      ( nodeptr ), | ||||
|                                                      tagName ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return rtElement; | ||||
| } | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,173 +1,73 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef IXML_MEMBUF_H | ||||
| #define IXML_MEMBUF_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef _IXML_MEMBUF_H | ||||
| #define _IXML_MEMBUF_H | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include "ixml.h" | ||||
|  | ||||
|  | ||||
| #include <stdlib.h> /* for size_t */ | ||||
|  | ||||
|  | ||||
| #define MINVAL( a, b ) ( (a) < (b) ? (a) : (b) ) | ||||
| #define MAXVAL( a, b ) ( (a) > (b) ? (a) : (b) ) | ||||
|  | ||||
|  | ||||
| #define MEMBUF_DEF_SIZE_INC 20 | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief The ixml_membuf type. | ||||
|  */ | ||||
| typedef struct | ||||
| typedef struct // ixml_membuf  | ||||
| { | ||||
| 	char	*buf; | ||||
| 				 | ||||
| 	size_t	length; | ||||
| 	size_t	capacity; | ||||
| 	size_t	size_inc; | ||||
|  | ||||
| } ixml_membuf; | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief ixml_membuf initialization routine. | ||||
| //-------------------------------------------------- | ||||
| //////////////// functions ///////////////////////// | ||||
| //-------------------------------------------------- | ||||
| /* | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif // __cplusplus | ||||
| */ | ||||
| void ixml_membuf_init( | ||||
| 	/*! [in,out] The memory buffer to initializa. */ | ||||
| 	ixml_membuf *m); | ||||
|  | ||||
| void ixml_membuf_init(INOUT ixml_membuf *m); | ||||
| void ixml_membuf_destroy(INOUT ixml_membuf *m); | ||||
| int ixml_membuf_assign(INOUT ixml_membuf *m, IN const void *buf,  | ||||
| 					 IN size_t buf_len ); | ||||
| int ixml_membuf_assign_str(INOUT ixml_membuf *m, IN const char *c_str ); | ||||
| int ixml_membuf_append(INOUT ixml_membuf *m, IN const void *buf); | ||||
| int ixml_membuf_append_str(INOUT ixml_membuf *m, IN const char *c_str); | ||||
| int ixml_membuf_insert(INOUT ixml_membuf *m, IN const void* buf,  | ||||
| 					 IN size_t buf_len, int index ); | ||||
|  | ||||
| /*! | ||||
|  * \brief ixml_membuf clearing routine. | ||||
|  * | ||||
|  * The internal buffer is deleted and ixml_membuf_init() is called in the end | ||||
|  * to reinitialize the buffer. | ||||
|  */ | ||||
| void ixml_membuf_destroy( | ||||
| 	/*! [in,out] The memory buffer to clear. */ | ||||
| 	ixml_membuf *m); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Copies the contents o a buffer to the designated ixml_membuf. | ||||
|  * | ||||
|  * The previous contents of the ixml_membuf are destroyed. | ||||
|  * | ||||
|  * \return IXML_SUCCESS if successfull, or the error code returned | ||||
|  * by ixml_membuf_set_size(). | ||||
|  * | ||||
|  * \sa ixml_membuf_assign_str(). | ||||
|  */ | ||||
| int ixml_membuf_assign( | ||||
| 	/*! [in,out] The memory buffer on which to operate. */ | ||||
| 	ixml_membuf *m, | ||||
| 	/*! [in] The input buffer to copy from. */ | ||||
| 	const void *buf,  | ||||
| 	/*! [in] The number of bytes to copy from the input buffer. */ | ||||
| 	size_t buf_len); | ||||
|  | ||||
| /*! | ||||
|  * \brief Copies a \b NULL terminated string to the ixml_buffer. | ||||
|  * | ||||
|  * This is a convenience function that internally uses ixml_membuf_assign(). | ||||
|  * | ||||
|  * \return The return value of ixml_membuf_assign(). | ||||
|  * | ||||
|  * \sa ixml_membuf_assign(). | ||||
|  */ | ||||
| int ixml_membuf_assign_str( | ||||
| 	/*! [in,out] The memory buffer on which to operate. */ | ||||
| 	ixml_membuf *m, | ||||
| 	/*! [in] The input string to copy from. */ | ||||
| 	const char *c_str); | ||||
|  | ||||
| /*! | ||||
|  * \brief Appends one byte to the designated ixml_membuffer. | ||||
|  * | ||||
|  * This is a convenience function that internally uses ixml_membuf_insert(). | ||||
|  * | ||||
|  * \return The return value of ixml_membuf_insert(). | ||||
|  * | ||||
|  * \sa ixml_membuf_insert() | ||||
|  */ | ||||
| int ixml_membuf_append( | ||||
| 	/*! [in,out] The memory buffer on which to operate. */ | ||||
| 	ixml_membuf *m, | ||||
| 	/*! [in] The pointer to the byte to append. */ | ||||
| 	const void *buf); | ||||
|  | ||||
| /*! | ||||
|  * \brief Appends the contents of a \b NULL terminated string to the designated | ||||
|  * ixml_membuf. | ||||
|  * | ||||
|  * This is a convenience function that internally uses ixml_membuf_insert(). | ||||
|  * | ||||
|  * \return The return value of ixml_membuf_insert(). | ||||
|  * | ||||
|  * \sa ixml_membuf_insert(). | ||||
|  */ | ||||
| int ixml_membuf_append_str( | ||||
| 	/*! [in,out] The memory buffer on which to operate. */ | ||||
| 	ixml_membuf *m, | ||||
| 	/*! [in] The input string to copy from. */ | ||||
| 	const char *c_str); | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  * | ||||
|  * \return | ||||
|  * 	\li 0 if successfull. | ||||
|  * 	\li IXML_INDEX_SIZE_ERR if the index parameter is out of range. | ||||
|  * 	\li Or the return code of ixml_membuf_set_size() | ||||
|  * | ||||
|  * \sa ixml_membuf_set_size() | ||||
|  */ | ||||
| int ixml_membuf_insert( | ||||
| 	/*! [in,out] The memory buffer on which to operate. */ | ||||
| 	ixml_membuf *m, | ||||
| 	/*! [in] The pointer to the input buffer. */ | ||||
| 	const void *buf,  | ||||
| 	/*! [in] The buffer length. */ | ||||
| 	size_t buf_len, | ||||
| 	/*! [in] The point of insertion relative to the beggining of the | ||||
| 	 * ixml_membuf internal buffer. */ | ||||
| 	size_t index); | ||||
|  | ||||
|  | ||||
| #endif /* IXML_MEMBUF_H */ | ||||
|  | ||||
| #endif // _IXML_MEMBUF_H | ||||
|   | ||||
| @@ -1,49 +1,41 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef IXMLPARSER_H | ||||
| #define IXMLPARSER_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|   | ||||
| #ifndef _IXMLPARSER_H | ||||
| #define _IXMLPARSER_H | ||||
|  | ||||
| #include "ixml.h" | ||||
| #include "ixmlmembuf.h" | ||||
|  | ||||
|  | ||||
| /* Parser definitions */ | ||||
| // Parser definitions | ||||
| #define QUOT        """ | ||||
| #define LT          "<" | ||||
| #define GT          ">" | ||||
| @@ -52,7 +44,6 @@ | ||||
| #define ESC_HEX     "&#x" | ||||
| #define ESC_DEC     "&#" | ||||
|  | ||||
|  | ||||
| typedef struct _IXML_NamespaceURI  | ||||
| { | ||||
|     char                        *nsURI; | ||||
| @@ -78,192 +69,52 @@ typedef enum | ||||
|     eCONTENT, | ||||
| } PARSER_STATE; | ||||
|  | ||||
|  | ||||
| typedef struct _Parser | ||||
| { | ||||
| 	/*! Data buffer. */ | ||||
| 	char *dataBuffer; | ||||
| 	/*! Pointer to the token parsed. */ | ||||
| 	char *curPtr; | ||||
| 	/*! Saves for backup. */ | ||||
| 	char *savePtr; | ||||
|     char            *dataBuffer;	//data buffer | ||||
|     char            *curPtr;		//ptr to the token parsed  | ||||
|     char            *savePtr;		//Saves for backup | ||||
|     ixml_membuf     lastElem; | ||||
|     ixml_membuf     tokenBuf;     | ||||
|  | ||||
|     IXML_Node           *pNeedPrefixNode; | ||||
|     IXML_ElementStack   *pCurElement; | ||||
|     IXML_Node           *currentNodePtr; | ||||
|     PARSER_STATE        state; | ||||
|  | ||||
|     BOOL                bHasTopLevel; | ||||
|  | ||||
| } Parser; | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Check to see whether name is a valid xml name. | ||||
|  */ | ||||
| BOOL Parser_isValidXmlName( | ||||
| 	/*! [in] The string to be checked. */ | ||||
| 	const DOMString name); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the error character. | ||||
|  * | ||||
|  * If 'c' is 0 (default), the parser is strict about XML encoding: | ||||
|  * invalid UTF-8 sequences or "&" entities are rejected, and the parsing  | ||||
|  * aborts. | ||||
|  * | ||||
|  * If 'c' is not 0, the parser is relaxed: invalid UTF-8 characters | ||||
|  * are replaced by this character, and invalid "&" entities are left | ||||
|  * untranslated. The parsing is then allowed to continue. | ||||
|  */ | ||||
| void Parser_setErrorChar( | ||||
| 	/*! [in] The character to become the error character. */ | ||||
| 	char c); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Fees a node contents. | ||||
|  */ | ||||
| void Parser_freeNodeContent( | ||||
| 	/*! [in] The Node to process. */ | ||||
| 	IXML_Node *IXML_Nodeptr); | ||||
|  | ||||
| int     Parser_LoadDocument( IXML_Document **retDoc, const char * xmlFile, BOOL file); | ||||
|  | ||||
| BOOL    Parser_isValidXmlName( const DOMString name); | ||||
| int     Parser_setNodePrefixAndLocalName(IXML_Node *newIXML_NodeIXML_Attr); | ||||
| void    Parser_freeNodeContent( IXML_Node *IXML_Nodeptr); | ||||
|  | ||||
| void    Parser_setErrorChar( char c ); | ||||
|  | ||||
| void    ixmlAttr_free(IXML_Attr *attrNode); | ||||
| void    ixmlAttr_init(IXML_Attr *attrNode); | ||||
|  | ||||
| /*! | ||||
|  * \brief Set the given element's tagName. | ||||
|  * | ||||
|  * \return One of the following: | ||||
|  * 	\li \b IXML_SUCCESS, if successfull. | ||||
|  * 	\li \b IXML_FAILED, if element of tagname is \b NULL. | ||||
|  * 	\li \b IXML_INSUFFICIENT_MEMORY, if there is no memory to allocate the | ||||
|  * 		buffer for the element's tagname. | ||||
|  */ | ||||
| int ixmlElement_setTagName( | ||||
| 	/*! [in] The element to change the tagname. */ | ||||
| 	IXML_Element *element, | ||||
| 	/*! [in] The new tagName for the element. */ | ||||
| 	const char *tagName); | ||||
| int     ixmlElement_setTagName(IXML_Element *element, const char *tagName); | ||||
|  | ||||
| void    ixmlNamedNodeMap_init(IXML_NamedNodeMap *nnMap); | ||||
| int     ixmlNamedNodeMap_addToNamedNodeMap(IXML_NamedNodeMap **nnMap, IXML_Node *add); | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes a NamedNodeMap object. | ||||
|  */ | ||||
| void ixmlNamedNodeMap_init( | ||||
| 	/*! [in] The named node map to process. */ | ||||
| 	IXML_NamedNodeMap *nnMap); | ||||
| void    ixmlNode_init(IXML_Node *IXML_Nodeptr); | ||||
| BOOL    ixmlNode_compare(IXML_Node *srcIXML_Node, IXML_Node *destIXML_Node); | ||||
|  | ||||
| void    ixmlNode_getElementsByTagName( IXML_Node *n, const char *tagname, IXML_NodeList **list); | ||||
| void    ixmlNode_getElementsByTagNameNS( IXML_Node *IXML_Node, const char *namespaceURI, | ||||
|                 const char *localName, IXML_NodeList **list); | ||||
|  | ||||
| /*! | ||||
|  * \brief Add a node to a NamedNodeMap. | ||||
|  * | ||||
|  * \return IXML_SUCCESS or failure. | ||||
|  */ | ||||
| int ixmlNamedNodeMap_addToNamedNodeMap( | ||||
| 	/* [in] The named node map. */ | ||||
| 	IXML_NamedNodeMap **nnMap, | ||||
| 	/* [in] The node to add. */ | ||||
| 	IXML_Node *add); | ||||
| int     ixmlNode_setNodeProperties(IXML_Node* node, IXML_Node *src); | ||||
| int     ixmlNode_setNodeName( IXML_Node* node, const DOMString qualifiedName); | ||||
|  | ||||
| /*! | ||||
|  * \brief Add a node to nodelist. | ||||
|  */ | ||||
| int ixmlNodeList_addToNodeList( | ||||
| 	/*! [in] The pointer to the nodelist. */ | ||||
| 	IXML_NodeList **nList, | ||||
| 	/*! [in] The node to add. */ | ||||
| 	IXML_Node *add); | ||||
| void    ixmlNodeList_init(IXML_NodeList *nList); | ||||
| int     ixmlNodeList_addToNodeList(IXML_NodeList **nList, IXML_Node *add); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Intializes a node. | ||||
|  */ | ||||
| void ixmlNode_init( | ||||
| 	/*! [in] The \b Node to iniatialize. */ | ||||
| 	IN IXML_Node *nodeptr); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Compare two nodes to see whether they are the same node. | ||||
|  * Parent, sibling and children node are ignored. | ||||
|  * | ||||
|  * \return | ||||
|  * 	\li TRUE, the two nodes are the same. | ||||
|  * 	\li FALSE, the two nodes are not the same. | ||||
|  */ | ||||
| BOOL ixmlNode_compare( | ||||
| 	/*! [in] The first \b Node. */ | ||||
| 	IXML_Node *srcNode, | ||||
| 	/*! [in] The second \b Node. */ | ||||
|  	IXML_Node *destNode); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns a nodeList of all descendant Elements with a given tagName, | ||||
|  * in the order in which they are encountered in a traversal of this element | ||||
|  * tree. | ||||
|  */ | ||||
| void ixmlNode_getElementsByTagName( | ||||
| 	/*! [in] The \b Node tree. */ | ||||
| 	IXML_Node *n, | ||||
| 	/*! [in] The tag name to match. */ | ||||
| 	const char *tagname, | ||||
| 	/*! [out] The output \b NodeList. */ | ||||
| 	IXML_NodeList **list); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns a nodeList of all the descendant Elements with a given local | ||||
|  * name and namespace URI in the order in which they are encountered in a | ||||
|  * preorder traversal of this Elememt tree.		 | ||||
|  */ | ||||
| void ixmlNode_getElementsByTagNameNS( | ||||
| 	/*! [in] The \b Element tree. */ | ||||
| 	IXML_Node *n, | ||||
| 	/*! [in] The name space to match. */ | ||||
| 	const char *namespaceURI, | ||||
| 	/*! [in] The local name to match. */ | ||||
| 	const char *localName, | ||||
| 	/*! [out] The output \b NodeList. */ | ||||
| 	IXML_NodeList **list); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  * | ||||
|  * \return  | ||||
|  */ | ||||
| int ixmlNode_setNodeName( | ||||
| 	/*! [in] The \b Node. */ | ||||
| 	IXML_Node *node, | ||||
| 	/*! [in] . */ | ||||
| 	const DOMString qualifiedName); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  * | ||||
|  * \return  | ||||
|  */ | ||||
| int ixmlNode_setNodeProperties( | ||||
| 	/*! [in] . */ | ||||
| 	IXML_Node *destNode, | ||||
| 	/*! [in] . */ | ||||
| 	IXML_Node *src); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes a nodelist  | ||||
|  */ | ||||
| void ixmlNodeList_init( | ||||
| 	/*! [in,out] The \b NodeList to initialize. */ | ||||
| 	IXML_NodeList *nList); | ||||
|  | ||||
|  | ||||
| #endif  /* IXMLPARSER_H */ | ||||
| #endif  // _IXMLPARSER_H | ||||
|  | ||||
|   | ||||
							
								
								
									
										368
									
								
								ixml/src/ixml.c
									
									
									
									
									
								
							
							
						
						
									
										368
									
								
								ixml/src/ixml.c
									
									
									
									
									
								
							| @@ -1,99 +1,91 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #include "ixmldebug.h" | ||||
| #include "ixmlmembuf.h" | ||||
| #include "ixmlparser.h" | ||||
|  | ||||
|  | ||||
| #include <stdlib.h> /* for free() */ | ||||
| #include <string.h> | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Appends a string to a buffer, substituting some characters by escape | ||||
|  * sequences. | ||||
|  */ | ||||
| static void copy_with_escape( | ||||
| 	/*! [in,out] The input/output buffer. */ | ||||
| 	ixml_membuf *buf, | ||||
| 	/*! [in] The string to copy from. */ | ||||
| 	const char *p) | ||||
| /*================================================================ | ||||
| *   copy_with_escape | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| static void | ||||
| copy_with_escape( INOUT ixml_membuf * buf, | ||||
|                   IN const char *p ) | ||||
| { | ||||
| 	size_t i; | ||||
| 	size_t plen; | ||||
|     int i; | ||||
|     int plen; | ||||
|  | ||||
|     if( p == NULL ) | ||||
|         return; | ||||
|  | ||||
|     plen = strlen( p ); | ||||
| 	for (i = 0; i < plen; ++i) { | ||||
|  | ||||
|     for( i = 0; i < plen; i++ ) { | ||||
|         switch ( p[i] ) { | ||||
|             case '<': | ||||
|                 ixml_membuf_append_str( buf, "<" ); | ||||
|                 break; | ||||
|  | ||||
|             case '>': | ||||
|                 ixml_membuf_append_str( buf, ">" ); | ||||
|                 break; | ||||
|  | ||||
|             case '&': | ||||
|                 ixml_membuf_append_str( buf, "&" ); | ||||
|                 break; | ||||
|  | ||||
|             case '\'': | ||||
|                 ixml_membuf_append_str( buf, "'" ); | ||||
|                 break; | ||||
|  | ||||
|             case '\"': | ||||
|                 ixml_membuf_append_str( buf, """ ); | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 ixml_membuf_append( buf, &p[i] ); | ||||
| 			break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Recursive function to print all the node in a tree. | ||||
| /*================================================================ | ||||
| *	ixmlPrintDomTreeRecursive | ||||
| *       It is a recursive function to print all the node in a tree. | ||||
| *       Internal to parser only. | ||||
|  */ | ||||
| static void ixmlPrintDomTreeRecursive( | ||||
| 	/*! [in] \todo documentation. */ | ||||
| 	IXML_Node *nodeptr, | ||||
| 	/*! [in] \todo documentation. */ | ||||
| 	ixml_membuf *buf) | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlPrintDomTreeRecursive( IN IXML_Node * nodeptr, | ||||
|                            IN ixml_membuf * buf ) | ||||
| { | ||||
|     const char *nodeName = NULL; | ||||
|     const char *nodeValue = NULL; | ||||
| @@ -105,6 +97,7 @@ static void ixmlPrintDomTreeRecursive( | ||||
|         nodeValue = ixmlNode_getNodeValue( nodeptr ); | ||||
|  | ||||
|         switch ( ixmlNode_getNodeType( nodeptr ) ) { | ||||
|  | ||||
|             case eTEXT_NODE: | ||||
|                 copy_with_escape( buf, nodeValue ); | ||||
|                 break; | ||||
| @@ -124,8 +117,8 @@ static void ixmlPrintDomTreeRecursive( | ||||
|                 break; | ||||
|  | ||||
|             case eDOCUMENT_NODE: | ||||
| 			ixmlPrintDomTreeRecursive( | ||||
| 				ixmlNode_getFirstChild(nodeptr), buf); | ||||
|                 ixmlPrintDomTreeRecursive( ixmlNode_getFirstChild | ||||
|                                            ( nodeptr ), buf ); | ||||
|                 break; | ||||
|  | ||||
|             case eATTRIBUTE_NODE: | ||||
| @@ -133,6 +126,7 @@ static void ixmlPrintDomTreeRecursive( | ||||
|                 ixml_membuf_append_str( buf, "=\"" ); | ||||
|                 copy_with_escape( buf, nodeValue ); | ||||
|                 ixml_membuf_append_str( buf, "\"" ); | ||||
|  | ||||
|                 if( nodeptr->nextSibling != NULL ) { | ||||
|                     ixml_membuf_append_str( buf, " " ); | ||||
|                     ixmlPrintDomTreeRecursive( nodeptr->nextSibling, buf ); | ||||
| @@ -142,69 +136,71 @@ static void ixmlPrintDomTreeRecursive( | ||||
|             case eELEMENT_NODE: | ||||
|                 ixml_membuf_append_str( buf, "<" ); | ||||
|                 ixml_membuf_append_str( buf, nodeName ); | ||||
|  | ||||
|                 if( nodeptr->firstAttr != NULL ) { | ||||
|                     ixml_membuf_append_str( buf, " " ); | ||||
|                     ixmlPrintDomTreeRecursive( nodeptr->firstAttr, buf ); | ||||
|                 } | ||||
|  | ||||
|                 child = ixmlNode_getFirstChild( nodeptr ); | ||||
| 			if (child != NULL && | ||||
| 			    ixmlNode_getNodeType(child) == eELEMENT_NODE) { | ||||
|                 if( ( child != NULL ) | ||||
|                     && ( ixmlNode_getNodeType( child ) == | ||||
|                          eELEMENT_NODE ) ) { | ||||
|                     ixml_membuf_append_str( buf, ">\r\n" ); | ||||
|                 } else { | ||||
|                     ixml_membuf_append_str( buf, ">" ); | ||||
|                 } | ||||
| 			/* output the children */ | ||||
| 			ixmlPrintDomTreeRecursive( | ||||
| 				ixmlNode_getFirstChild(nodeptr), buf); | ||||
|  | ||||
| 			/* Done with children.  Output the end tag. */ | ||||
|                 //  output the children | ||||
|                 ixmlPrintDomTreeRecursive( ixmlNode_getFirstChild | ||||
|                                            ( nodeptr ), buf ); | ||||
|  | ||||
|                 // Done with children.  Output the end tag. | ||||
|                 ixml_membuf_append_str( buf, "</" ); | ||||
|                 ixml_membuf_append_str( buf, nodeName ); | ||||
|  | ||||
|                 sibling = ixmlNode_getNextSibling( nodeptr ); | ||||
| 			if (sibling != NULL && | ||||
| 			    ixmlNode_getNodeType(sibling) == eTEXT_NODE) { | ||||
|                 if( sibling != NULL | ||||
|                     && ixmlNode_getNodeType( sibling ) == eTEXT_NODE ) { | ||||
|                     ixml_membuf_append_str( buf, ">" ); | ||||
|                 } else { | ||||
|                     ixml_membuf_append_str( buf, ">\r\n" ); | ||||
|                 } | ||||
| 			ixmlPrintDomTreeRecursive( | ||||
| 				ixmlNode_getNextSibling(nodeptr), buf); | ||||
|                 ixmlPrintDomTreeRecursive( ixmlNode_getNextSibling | ||||
|                                            ( nodeptr ), buf ); | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
| 			IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTreeRecursive", | ||||
| 				"Warning, unknown node type %d\n", | ||||
| 				ixmlNode_getNodeType(nodeptr)); | ||||
|                 break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Print a DOM tree. | ||||
| /*================================================================ | ||||
| *   ixmlPrintDomTree | ||||
| *       Print a DOM tree. | ||||
| *       Element, and Attribute nodes are handled differently. | ||||
| *       We don't want to print the Element and Attribute nodes' sibling. | ||||
| *       External function. | ||||
| * | ||||
|  * Element, and Attribute nodes are handled differently. We don't want to print | ||||
|  * the Element and Attribute nodes' sibling. | ||||
|  */ | ||||
| static void ixmlPrintDomTree( | ||||
| 	/*! [in] \todo documentation. */ | ||||
| 	IXML_Node *nodeptr, | ||||
| 	/*! [in] \todo documentation. */ | ||||
| 	ixml_membuf *buf) | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlPrintDomTree( IN IXML_Node * nodeptr, | ||||
|                   IN ixml_membuf * buf ) | ||||
| { | ||||
|     const char *nodeName = NULL; | ||||
|     const char *nodeValue = NULL; | ||||
|     IXML_Node *child = NULL; | ||||
|  | ||||
| 	if (nodeptr == NULL || buf == NULL) { | ||||
|     if( ( nodeptr == NULL ) || ( buf == NULL ) ) { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     nodeName = ( const char * )ixmlNode_getNodeName( nodeptr ); | ||||
|     nodeValue = ixmlNode_getNodeValue( nodeptr ); | ||||
|  | ||||
|     switch ( ixmlNode_getNodeType( nodeptr ) ) { | ||||
|  | ||||
|         case eTEXT_NODE: | ||||
|         case eCDATA_SECTION_NODE: | ||||
|         case ePROCESSING_INSTRUCTION_NODE: | ||||
| @@ -222,54 +218,52 @@ static void ixmlPrintDomTree( | ||||
|         case eELEMENT_NODE: | ||||
|             ixml_membuf_append_str( buf, "<" ); | ||||
|             ixml_membuf_append_str( buf, nodeName ); | ||||
|  | ||||
|             if( nodeptr->firstAttr != NULL ) { | ||||
|                 ixml_membuf_append_str( buf, " " ); | ||||
|                 ixmlPrintDomTreeRecursive( nodeptr->firstAttr, buf ); | ||||
|             } | ||||
|  | ||||
|             child = ixmlNode_getFirstChild( nodeptr ); | ||||
| 		if (child != NULL && | ||||
| 		    ixmlNode_getNodeType(child) == eELEMENT_NODE) { | ||||
|             if( ( child != NULL ) | ||||
|                 && ( ixmlNode_getNodeType( child ) == eELEMENT_NODE ) ) { | ||||
|                 ixml_membuf_append_str( buf, ">\r\n" ); | ||||
|             } else { | ||||
|                 ixml_membuf_append_str( buf, ">" ); | ||||
|             } | ||||
|  | ||||
| 		/* output the children */ | ||||
| 		ixmlPrintDomTreeRecursive( | ||||
| 			ixmlNode_getFirstChild(nodeptr), buf); | ||||
|             //  output the children | ||||
|             ixmlPrintDomTreeRecursive( ixmlNode_getFirstChild( nodeptr ), | ||||
|                                        buf ); | ||||
|  | ||||
| 		/* Done with children. Output the end tag. */ | ||||
|             // Done with children.  Output the end tag. | ||||
|             ixml_membuf_append_str( buf, "</" ); | ||||
|             ixml_membuf_append_str( buf, nodeName ); | ||||
|             ixml_membuf_append_str( buf, ">\r\n" ); | ||||
|             break; | ||||
|  | ||||
|         default: | ||||
| 		IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTree", | ||||
| 			"Warning, unknown node type %d\n", | ||||
| 			ixmlNode_getNodeType(nodeptr)); | ||||
|             break; | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Converts a DOM tree into a text string. | ||||
| /*================================================================ | ||||
| *   ixmlDomTreetoString | ||||
| *       Converts a DOM tree into a text string | ||||
| *       Element, and Attribute nodes are handled differently. | ||||
| *       We don't want to print the Element and Attribute nodes' sibling. | ||||
| *       External function. | ||||
| * | ||||
|  * Element, and Attribute nodes are handled differently. We don't want to print | ||||
|  * the Element and Attribute nodes' sibling. | ||||
|  */ | ||||
| static void ixmlDomTreetoString( | ||||
| 	/*! [in] \todo documentation. */ | ||||
| 	IXML_Node *nodeptr, | ||||
| 	/*! [in] \todo documentation. */ | ||||
| 	ixml_membuf *buf) | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlDomTreetoString( IN IXML_Node * nodeptr, | ||||
|                      IN ixml_membuf * buf ) | ||||
| { | ||||
|     const char *nodeName = NULL; | ||||
|     const char *nodeValue = NULL; | ||||
|     IXML_Node *child = NULL; | ||||
|  | ||||
| 	if (nodeptr == NULL || buf == NULL) { | ||||
|     if( ( nodeptr == NULL ) || ( buf == NULL ) ) { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
| @@ -277,6 +271,7 @@ static void ixmlDomTreetoString( | ||||
|     nodeValue = ixmlNode_getNodeValue( nodeptr ); | ||||
|  | ||||
|     switch ( ixmlNode_getNodeType( nodeptr ) ) { | ||||
|  | ||||
|         case eTEXT_NODE: | ||||
|         case eCDATA_SECTION_NODE: | ||||
|         case ePROCESSING_INSTRUCTION_NODE: | ||||
| @@ -294,57 +289,79 @@ static void ixmlDomTreetoString( | ||||
|         case eELEMENT_NODE: | ||||
|             ixml_membuf_append_str( buf, "<" ); | ||||
|             ixml_membuf_append_str( buf, nodeName ); | ||||
|  | ||||
|             if( nodeptr->firstAttr != NULL ) { | ||||
|                 ixml_membuf_append_str( buf, " " ); | ||||
|                 ixmlPrintDomTreeRecursive( nodeptr->firstAttr, buf ); | ||||
|             } | ||||
|  | ||||
|             child = ixmlNode_getFirstChild( nodeptr ); | ||||
| 		if (child != NULL && | ||||
| 		    ixmlNode_getNodeType(child) == eELEMENT_NODE) { | ||||
|             if( ( child != NULL ) | ||||
|                 && ( ixmlNode_getNodeType( child ) == eELEMENT_NODE ) ) { | ||||
|                 ixml_membuf_append_str( buf, ">" ); | ||||
|             } else { | ||||
|                 ixml_membuf_append_str( buf, ">" ); | ||||
|             } | ||||
|  | ||||
| 		/* output the children */ | ||||
| 		ixmlPrintDomTreeRecursive(ixmlNode_getFirstChild(nodeptr), buf); | ||||
|             //  output the children | ||||
|             ixmlPrintDomTreeRecursive( ixmlNode_getFirstChild( nodeptr ), | ||||
|                                        buf ); | ||||
|  | ||||
| 		/* Done with children. Output the end tag. */ | ||||
|             // Done with children.  Output the end tag. | ||||
|             ixml_membuf_append_str( buf, "</" ); | ||||
|             ixml_membuf_append_str( buf, nodeName ); | ||||
|             ixml_membuf_append_str( buf, ">" ); | ||||
|             break; | ||||
|  | ||||
|         default: | ||||
| 		IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTreeRecursive", | ||||
| 			"Warning, unknown node type %d\n", | ||||
| 			ixmlNode_getNodeType(nodeptr)); | ||||
|             break; | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlLoadDocumentEx(const char *xmlFile, IXML_Document **doc) | ||||
| /*================================================================ | ||||
| *   ixmlLoadDocumentEx | ||||
| *       Parses the given file, and returns the DOM tree from it. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlLoadDocumentEx( IN const char *xmlFile, | ||||
|                     IXML_Document ** doc ) | ||||
| { | ||||
| 	if (xmlFile == NULL || doc == NULL) { | ||||
|  | ||||
|     if( ( xmlFile == NULL ) || ( doc == NULL ) ) { | ||||
|         return IXML_INVALID_PARAMETER; | ||||
|     } | ||||
|  | ||||
|     return Parser_LoadDocument( doc, xmlFile, TRUE ); | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Document *ixmlLoadDocument(const char *xmlFile) | ||||
| /*================================================================ | ||||
| *   ixmlLoadDocument | ||||
| *       Parses the given file, and returns the DOM tree from it. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Document * | ||||
| ixmlLoadDocument( IN const char *xmlFile ) | ||||
| { | ||||
|  | ||||
|     IXML_Document *doc = NULL; | ||||
|  | ||||
|     ixmlLoadDocumentEx( xmlFile, &doc ); | ||||
|  | ||||
|     return doc; | ||||
| } | ||||
|  | ||||
| /*================================================================ | ||||
| *   ixmlPrintDocument | ||||
| *       Prints entire document, prepending XML prolog first. | ||||
| *       Puts lots of white spaces. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
|  | ||||
| DOMString ixmlPrintDocument(IXML_Document *doc) | ||||
| DOMString | ||||
| ixmlPrintDocument(IXML_Document *doc) | ||||
| { | ||||
|     IXML_Node* rootNode = ( IXML_Node * )doc; | ||||
|     ixml_membuf memBuf; | ||||
| @@ -357,13 +374,20 @@ DOMString ixmlPrintDocument(IXML_Document *doc) | ||||
|     ixml_membuf_init( buf ); | ||||
|     ixml_membuf_append_str( buf, "<?xml version=\"1.0\"?>\r\n" ); | ||||
|     ixmlPrintDomTree( rootNode, buf ); | ||||
|  | ||||
|     return buf->buf; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| DOMString ixmlPrintNode(IXML_Node *node) | ||||
| /*================================================================ | ||||
| *   ixmlPrintNode | ||||
| *       Print DOM tree under node. Puts lots of white spaces | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| DOMString | ||||
| ixmlPrintNode( IN IXML_Node * node ) | ||||
| { | ||||
|  | ||||
|     ixml_membuf memBuf; | ||||
|     ixml_membuf *buf = &memBuf; | ||||
|  | ||||
| @@ -373,12 +397,20 @@ DOMString ixmlPrintNode(IXML_Node *node) | ||||
|  | ||||
|     ixml_membuf_init( buf ); | ||||
|     ixmlPrintDomTree( node, buf ); | ||||
|  | ||||
|     return buf->buf; | ||||
|  | ||||
| } | ||||
|  | ||||
| /*================================================================ | ||||
| *   ixmlDocumenttoString | ||||
| *       converts DOM tree under node to text string, | ||||
| *       prepending XML prolog first. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
|  | ||||
| DOMString ixmlDocumenttoString(IXML_Document *doc) | ||||
| DOMString | ||||
| ixmlDocumenttoString(IXML_Document *doc) | ||||
| { | ||||
|     IXML_Node* rootNode = ( IXML_Node * )doc; | ||||
|     ixml_membuf memBuf; | ||||
| @@ -391,13 +423,20 @@ DOMString ixmlDocumenttoString(IXML_Document *doc) | ||||
|     ixml_membuf_init( buf ); | ||||
|     ixml_membuf_append_str( buf, "<?xml version=\"1.0\"?>\r\n" ); | ||||
|     ixmlDomTreetoString( rootNode, buf ); | ||||
|  | ||||
|     return buf->buf; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| DOMString ixmlNodetoString(IXML_Node *node) | ||||
| /*================================================================ | ||||
| *   ixmlNodetoString | ||||
| *       converts DOM tree under node to text string | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| DOMString | ||||
| ixmlNodetoString( IN IXML_Node * node ) | ||||
| { | ||||
|  | ||||
|     ixml_membuf memBuf; | ||||
|     ixml_membuf *buf = &memBuf; | ||||
|  | ||||
| @@ -407,20 +446,35 @@ DOMString ixmlNodetoString(IXML_Node *node) | ||||
|  | ||||
|     ixml_membuf_init( buf ); | ||||
|     ixmlDomTreetoString( node, buf ); | ||||
|  | ||||
|     return buf->buf; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixmlRelaxParser(char errorChar) | ||||
| /*================================================================ | ||||
| *   ixmlRelaxParser | ||||
| *       Makes the XML parser more tolerant to malformed text. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlRelaxParser(char errorChar) | ||||
| { | ||||
|     Parser_setErrorChar( errorChar ); | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlParseBufferEx(const char *buffer, IXML_Document **retDoc) | ||||
| /*================================================================ | ||||
| *   ixmlParseBufferEx | ||||
| *       Parse xml file stored in buffer. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlParseBufferEx( IN const char *buffer, | ||||
|                    IXML_Document ** retDoc ) | ||||
| { | ||||
| 	if (buffer == NULL || retDoc == NULL) { | ||||
|  | ||||
|     if( ( buffer == NULL ) || ( retDoc == NULL ) ) { | ||||
|         return IXML_INVALID_PARAMETER; | ||||
|     } | ||||
|  | ||||
| @@ -431,31 +485,47 @@ int ixmlParseBufferEx(const char *buffer, IXML_Document **retDoc) | ||||
|     return Parser_LoadDocument( retDoc, buffer, FALSE ); | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Document *ixmlParseBuffer(const char *buffer) | ||||
| /*================================================================ | ||||
| *   ixmlParseBuffer | ||||
| *       Parse xml file stored in buffer. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Document * | ||||
| ixmlParseBuffer( IN const char *buffer ) | ||||
| { | ||||
|     IXML_Document *doc = NULL; | ||||
|  | ||||
|     ixmlParseBufferEx( buffer, &doc ); | ||||
|  | ||||
|     return doc; | ||||
| } | ||||
|  | ||||
|  | ||||
| DOMString ixmlCloneDOMString(const DOMString src) | ||||
| /*================================================================ | ||||
| *   ixmlCloneDOMString | ||||
| *       Clones a DOM String. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| DOMString | ||||
| ixmlCloneDOMString( IN const DOMString src ) | ||||
| { | ||||
|     if( src == NULL ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
| 	return strdup(src); | ||||
|     return ( strdup( src ) ); | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixmlFreeDOMString(DOMString buf) | ||||
| /*================================================================ | ||||
| *   ixmlFreeDOMString | ||||
| *       Frees a DOM String. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlFreeDOMString( IN DOMString buf ) | ||||
| { | ||||
|     if( buf != NULL ) { | ||||
|         free( buf ); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,70 +0,0 @@ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #include "autoconfig.h" | ||||
|  | ||||
|  | ||||
| #include "ixmldebug.h" | ||||
|  | ||||
|  | ||||
| #include <stdarg.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
|  | ||||
| #ifdef DEBUG | ||||
| void IxmlPrintf( | ||||
| 	const char *DbgFileName, | ||||
| 	int DbgLineNo, | ||||
| 	const char *FunctionName, | ||||
| 	const char *FmtStr, | ||||
| 	...) | ||||
| { | ||||
| 	va_list ArgList; | ||||
| 	 | ||||
| 	FILE *fp = stdout; | ||||
| 	fprintf(fp, "(%s::%s), line %d", DbgFileName, FunctionName, DbgLineNo); | ||||
| 	if (FmtStr) { | ||||
| 		fprintf(fp, ": "); | ||||
| 		va_start(ArgList, FmtStr); | ||||
| 		vfprintf(fp, FmtStr, ArgList); | ||||
| 		fflush(fp); | ||||
| 		va_end(ArgList); | ||||
| 	} else { | ||||
| 		fprintf(fp, "\n"); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
| void printNodes(IXML_Node *tmpRoot, int depth) | ||||
| { | ||||
|     unsigned long i; | ||||
|     IXML_NodeList *NodeList1; | ||||
|     IXML_Node *ChildNode1; | ||||
|     unsigned short NodeType; | ||||
|     const DOMString NodeValue; | ||||
|     const DOMString NodeName; | ||||
|     NodeList1 = ixmlNode_getChildNodes(tmpRoot); | ||||
|     for (i = 0; i < 100; ++i) { | ||||
|         ChildNode1 = ixmlNodeList_item(NodeList1, i); | ||||
|         if (ChildNode1 == NULL) { | ||||
|             break; | ||||
|         } | ||||
|      | ||||
|         printNodes(ChildNode1, depth+1); | ||||
|         NodeType = ixmlNode_getNodeType(ChildNode1); | ||||
|         NodeValue = ixmlNode_getNodeValue(ChildNode1); | ||||
|         NodeName = ixmlNode_getNodeName(ChildNode1); | ||||
| 	IxmlPrintf(__FILE__, __LINE__, "printNodes", | ||||
|             "DEPTH-%2d-IXML_Node Type %d, " | ||||
|             "IXML_Node Name: %s, IXML_Node Value: %s\n", | ||||
|             depth, NodeType, NodeName, NodeValue); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| #endif | ||||
|  | ||||
| @@ -1,87 +1,79 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #include "ixmlmembuf.h" | ||||
| #include "ixml.h" | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include <assert.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include "ixmlmembuf.h" | ||||
| #include "ixml.h" | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Increases or decreases buffer capacity so that at least 'new_length' | ||||
|  * bytes can be stored. | ||||
| /*================================================================ | ||||
| *   ixml_membuf_set_size | ||||
| * | ||||
| *   Increases or decreases buffer cap so that at least | ||||
| *   'new_length' bytes can be stored | ||||
| * | ||||
| *   On error, m's fields do not change. | ||||
| * | ||||
|  * \return | ||||
|  * 	\li UPNP_E_SUCCESS | ||||
|  * 	\li UPNP_E_OUTOF_MEMORY | ||||
|  */ | ||||
| static int ixml_membuf_set_size( | ||||
| 	/*! [in,out] The memory buffer. */ | ||||
| 	INOUT ixml_membuf *m, | ||||
| 	/*! [in] The new lenght. */ | ||||
| *   returns: | ||||
| *       UPNP_E_SUCCESS | ||||
| *       UPNP_E_OUTOF_MEMORY | ||||
| * | ||||
| *=================================================================*/ | ||||
| static int | ||||
| ixml_membuf_set_size( INOUT ixml_membuf * m, | ||||
|                       IN size_t new_length ) | ||||
| { | ||||
|     size_t diff; | ||||
|     size_t alloc_len; | ||||
|     char *temp_buf; | ||||
|  | ||||
| 	if (new_length >= m->length) { | ||||
| 		/* increase length */ | ||||
| 		/* need more mem? */ | ||||
|     if( new_length >= m->length )   // increase length | ||||
|     { | ||||
|         // need more mem? | ||||
|         if( new_length <= m->capacity ) { | ||||
| 			/* have enough mem; done */ | ||||
| 			return 0; | ||||
|             return 0;           // have enough mem; done | ||||
|         } | ||||
|  | ||||
|         diff = new_length - m->length; | ||||
|         alloc_len = MAXVAL( m->size_inc, diff ) + m->capacity; | ||||
| 	} else { | ||||
| 		/* decrease length */ | ||||
|     } else                      // decrease length | ||||
|     { | ||||
|         assert( new_length <= m->length ); | ||||
|  | ||||
| 		/* if diff is 0..m->size_inc, don't free */ | ||||
|         // if diff is 0..m->size_inc, don't free | ||||
|         if( ( m->capacity - new_length ) <= m->size_inc ) { | ||||
|             return 0; | ||||
|         } | ||||
|  | ||||
|         alloc_len = new_length + m->size_inc; | ||||
|     } | ||||
|  | ||||
| @@ -89,22 +81,27 @@ static int ixml_membuf_set_size( | ||||
|  | ||||
|     temp_buf = realloc( m->buf, alloc_len + 1 ); | ||||
|     if( temp_buf == NULL ) { | ||||
| 		/* try smaller size */ | ||||
|         // try smaller size | ||||
|         alloc_len = new_length; | ||||
|         temp_buf = realloc( m->buf, alloc_len + 1 ); | ||||
|  | ||||
|         if( temp_buf == NULL ) { | ||||
|             return IXML_INSUFFICIENT_MEMORY; | ||||
|         } | ||||
|     } | ||||
| 	/* save */ | ||||
|     // save | ||||
|     m->buf = temp_buf; | ||||
|     m->capacity = alloc_len; | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixml_membuf_init(ixml_membuf *m) | ||||
| /*================================================================ | ||||
| *   membuffer_init | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixml_membuf_init( INOUT ixml_membuf * m ) | ||||
| { | ||||
|     assert( m != NULL ); | ||||
|  | ||||
| @@ -114,8 +111,13 @@ void ixml_membuf_init(ixml_membuf *m) | ||||
|     m->capacity = 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixml_membuf_destroy(ixml_membuf *m) | ||||
| /*================================================================ | ||||
| *   membuffer_destroy | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixml_membuf_destroy( INOUT ixml_membuf * m ) | ||||
| { | ||||
|     if( m == NULL ) { | ||||
|         return; | ||||
| @@ -125,48 +127,59 @@ void ixml_membuf_destroy(ixml_membuf *m) | ||||
|     ixml_membuf_init( m ); | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixml_membuf_assign( | ||||
| 	ixml_membuf *m, | ||||
| 	const void *buf, | ||||
| 	size_t buf_len) | ||||
| /*================================================================ | ||||
| *   ixml_membuf_assign | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixml_membuf_assign( INOUT ixml_membuf * m, | ||||
|                     IN const void *buf, | ||||
|                     IN size_t buf_len ) | ||||
| { | ||||
|     int return_code; | ||||
|  | ||||
|     assert( m != NULL ); | ||||
|  | ||||
| 	/* set value to null */ | ||||
|     // set value to null | ||||
|     if( buf == NULL ) { | ||||
|         ixml_membuf_destroy( m ); | ||||
|         return IXML_SUCCESS; | ||||
|     } | ||||
| 	/* alloc mem */ | ||||
|     // alloc mem | ||||
|     return_code = ixml_membuf_set_size( m, buf_len ); | ||||
|     if( return_code != 0 ) { | ||||
|         return return_code; | ||||
|     } | ||||
|  | ||||
| 	/* copy */ | ||||
|     // copy | ||||
|     memcpy( m->buf, buf, buf_len ); | ||||
|     m->buf[buf_len] = 0;        // null-terminate | ||||
|  | ||||
| 	/* null-terminate */ | ||||
| 	m->buf[buf_len] = 0; | ||||
|     m->length = buf_len; | ||||
|  | ||||
|     return IXML_SUCCESS; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixml_membuf_assign_str( | ||||
| 	ixml_membuf *m, | ||||
| 	const char *c_str) | ||||
| /*================================================================ | ||||
| *   ixml_membuf_assign_str | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixml_membuf_assign_str( INOUT ixml_membuf * m, | ||||
|                         IN const char *c_str ) | ||||
| { | ||||
|     return ixml_membuf_assign( m, c_str, strlen( c_str ) ); | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixml_membuf_append( | ||||
| 	INOUT ixml_membuf *m, | ||||
| /*================================================================ | ||||
| *   ixml_membuf_append | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixml_membuf_append( INOUT ixml_membuf * m, | ||||
|                     IN const void *buf ) | ||||
| { | ||||
|     assert( m != NULL ); | ||||
| @@ -174,45 +187,50 @@ int ixml_membuf_append( | ||||
|     return ixml_membuf_insert( m, buf, 1, m->length ); | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixml_membuf_append_str( | ||||
| 	INOUT ixml_membuf *m, | ||||
| /*================================================================ | ||||
| *   ixml_membuf_append_str | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixml_membuf_append_str( INOUT ixml_membuf * m, | ||||
|                         IN const char *c_str ) | ||||
| { | ||||
|     return ixml_membuf_insert( m, c_str, strlen( c_str ), m->length ); | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixml_membuf_insert( | ||||
| 	INOUT ixml_membuf *m, | ||||
| /*================================================================ | ||||
| *   ixml_membuf_insert | ||||
| * | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixml_membuf_insert( INOUT ixml_membuf * m, | ||||
|                     IN const void *buf, | ||||
|                     IN size_t buf_len, | ||||
| 	size_t index) | ||||
|                     int index ) | ||||
| { | ||||
| 	int return_code = 0; | ||||
|     int return_code; | ||||
|  | ||||
|     assert( m != NULL ); | ||||
|  | ||||
| 	if (index > m->length) { | ||||
|     if( index < 0 || index > ( int )m->length ) | ||||
|         return IXML_INDEX_SIZE_ERR; | ||||
| 	} | ||||
|  | ||||
|     if( buf == NULL || buf_len == 0 ) { | ||||
|         return 0; | ||||
|     } | ||||
| 	/* alloc mem */ | ||||
|     // alloc mem | ||||
|     return_code = ixml_membuf_set_size( m, m->length + buf_len ); | ||||
|     if( return_code != 0 ) { | ||||
|         return return_code; | ||||
|     } | ||||
| 	/* insert data */ | ||||
| 	/* move data to right of insertion point */ | ||||
|     // insert data | ||||
|     // move data to right of insertion point | ||||
|     memmove( m->buf + index + buf_len, m->buf + index, m->length - index ); | ||||
|     memcpy( m->buf + index, buf, buf_len ); | ||||
|     m->length += buf_len; | ||||
| 	/* Null terminate */ | ||||
| 	m->buf[m->length] = 0; | ||||
|     m->buf[m->length] = 0;      // null-terminate | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,62 +1,53 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "ixmlparser.h" | ||||
|  | ||||
|  | ||||
| #include <assert.h> | ||||
| #include <stdlib.h> /* for free(), malloc() */ | ||||
| #include <string.h> | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Return the item number of a item in NamedNodeMap. | ||||
|  */ | ||||
| static unsigned long ixmlNamedNodeMap_getItemNumber( | ||||
| 	/*! [in] The named node map to process. */ | ||||
| 	IN IXML_NamedNodeMap *nnMap, | ||||
| 	/*! [in] The name of the item to find. */ | ||||
| /*================================================================ | ||||
| *   NamedNodeMap_getItemNumber | ||||
| *       return the item number of a item in NamedNodeMap. | ||||
| *       Internal to parser only. | ||||
| *   Parameters: | ||||
| *       name: the name of the item to find | ||||
| *    | ||||
| *=================================================================*/ | ||||
| unsigned long | ||||
| ixmlNamedNodeMap_getItemNumber( IN IXML_NamedNodeMap * nnMap, | ||||
|                                 IN const char *name ) | ||||
| { | ||||
|     IXML_Node *tempNode; | ||||
|     unsigned long returnItemNo = 0; | ||||
|  | ||||
|     assert( nnMap != NULL && name != NULL ); | ||||
| 	if (nnMap == NULL || name == NULL) { | ||||
|     if( ( nnMap == NULL ) || ( name == NULL ) ) { | ||||
|         return IXML_INVALID_ITEM_NUMBER; | ||||
|     } | ||||
|  | ||||
| @@ -65,6 +56,7 @@ static unsigned long ixmlNamedNodeMap_getItemNumber( | ||||
|         if( strcmp( name, tempNode->nodeName ) == 0 ) { | ||||
|             return returnItemNo; | ||||
|         } | ||||
|  | ||||
|         tempNode = tempNode->nextSibling; | ||||
|         returnItemNo++; | ||||
|     } | ||||
| @@ -72,22 +64,39 @@ static unsigned long ixmlNamedNodeMap_getItemNumber( | ||||
|     return IXML_INVALID_ITEM_NUMBER; | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixmlNamedNodeMap_init(IXML_NamedNodeMap *nnMap) | ||||
| /*================================================================ | ||||
| *   NamedNodeMap_init | ||||
| *       Initializes a NamedNodeMap object. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlNamedNodeMap_init( IN IXML_NamedNodeMap * nnMap ) | ||||
| { | ||||
|     assert( nnMap != NULL ); | ||||
|  | ||||
|     memset( nnMap, 0, sizeof( IXML_NamedNodeMap ) ); | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Node *ixmlNamedNodeMap_getNamedItem( | ||||
| 	IXML_NamedNodeMap *nnMap, | ||||
| 	const DOMString name) | ||||
| /*================================================================ | ||||
| *   NamedNodeMap_getNamedItem | ||||
| *       Retrieves a node specified by name. | ||||
| *       External function. | ||||
| * | ||||
| *   Parameter: | ||||
| *       name: type nodeName of a node to retrieve. | ||||
| * | ||||
| *   Return Value: | ||||
| *       A Node with the specified nodeName, or null if it | ||||
| *       does not identify any node in this map. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Node * | ||||
| ixmlNamedNodeMap_getNamedItem( IN IXML_NamedNodeMap * nnMap, | ||||
|                                IN const char *name ) | ||||
| { | ||||
| 	unsigned long index; | ||||
|     long index; | ||||
|  | ||||
| 	if (nnMap == NULL || name == NULL) { | ||||
|     if( ( nnMap == NULL ) || ( name == NULL ) ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
| @@ -95,13 +104,26 @@ IXML_Node *ixmlNamedNodeMap_getNamedItem( | ||||
|     if( index == IXML_INVALID_ITEM_NUMBER ) { | ||||
|         return NULL; | ||||
|     } else { | ||||
| 		return ixmlNamedNodeMap_item(nnMap, index); | ||||
|         return ( ixmlNamedNodeMap_item( nnMap, ( unsigned long )index ) ); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Node *ixmlNamedNodeMap_item( | ||||
| 	IN IXML_NamedNodeMap *nnMap, | ||||
| /*================================================================ | ||||
| *   NamedNodeMap_item | ||||
| *       Returns the indexth item in the map. If index is greater than or | ||||
| *       equal to the number of nodes in this map, this returns null. | ||||
| *       External function. | ||||
| * | ||||
| *   Parameter: | ||||
| *       index: index into this map. | ||||
| * | ||||
| *   Return Value: | ||||
| *       The node at the indexth position in the map, or null if that is | ||||
| *       not a valid index. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Node * | ||||
| ixmlNamedNodeMap_item( IN IXML_NamedNodeMap * nnMap, | ||||
|                        IN unsigned long index ) | ||||
| { | ||||
|     IXML_Node *tempNode; | ||||
| @@ -123,8 +145,16 @@ IXML_Node *ixmlNamedNodeMap_item( | ||||
|     return tempNode; | ||||
| } | ||||
|  | ||||
|  | ||||
| unsigned long ixmlNamedNodeMap_getLength(IXML_NamedNodeMap *nnMap) | ||||
| /*================================================================ | ||||
| *   NamedNodeMap_getLength	 | ||||
| *       Return the number of Nodes in this map.        | ||||
| *       External function. | ||||
| *    | ||||
| *   Parameters: | ||||
| * | ||||
| *=================================================================*/ | ||||
| unsigned long | ||||
| ixmlNamedNodeMap_getLength( IN IXML_NamedNodeMap * nnMap ) | ||||
| { | ||||
|     IXML_Node *tempNode; | ||||
|     unsigned long length = 0; | ||||
| @@ -135,12 +165,17 @@ unsigned long ixmlNamedNodeMap_getLength(IXML_NamedNodeMap *nnMap) | ||||
|             tempNode = tempNode->nextSibling; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return length; | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixmlNamedNodeMap_free(IXML_NamedNodeMap *nnMap) | ||||
| /*================================================================ | ||||
| *   ixmlNamedNodeMap_free | ||||
| *       frees a NamedNodeMap. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlNamedNodeMap_free( IXML_NamedNodeMap * nnMap ) | ||||
| { | ||||
|     IXML_NamedNodeMap *pNext; | ||||
|  | ||||
| @@ -151,27 +186,38 @@ void ixmlNamedNodeMap_free(IXML_NamedNodeMap *nnMap) | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| int ixmlNamedNodeMap_addToNamedNodeMap( | ||||
| 	IXML_NamedNodeMap **nnMap, | ||||
| 	IXML_Node *add) | ||||
| /*================================================================ | ||||
| *   NamedNodeMap_addToNamedNodeMap | ||||
| *       add a node to a NamedNodeMap. | ||||
| *       Internal to parser only. | ||||
| *   Parameters: | ||||
| *       add: the node to add into NamedNodeMap. | ||||
| *   Return: | ||||
| *       IXML_SUCCESS or failure. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlNamedNodeMap_addToNamedNodeMap( IN IXML_NamedNodeMap ** nnMap, | ||||
|                                     IN IXML_Node * add ) | ||||
| { | ||||
| 	IXML_NamedNodeMap *traverse = NULL; | ||||
| 	IXML_NamedNodeMap *p = NULL; | ||||
|     IXML_NamedNodeMap *traverse = NULL, | ||||
|      *p = NULL; | ||||
|     IXML_NamedNodeMap *newItem = NULL; | ||||
|  | ||||
|     if( add == NULL ) { | ||||
|         return IXML_SUCCESS; | ||||
|     } | ||||
|  | ||||
| 	if (*nnMap == NULL) { | ||||
| 		/* nodelist is empty */ | ||||
| 		*nnMap = (IXML_NamedNodeMap *)malloc(sizeof (IXML_NamedNodeMap)); | ||||
|     if( *nnMap == NULL )        // nodelist is empty | ||||
|     { | ||||
|         *nnMap = | ||||
|             ( IXML_NamedNodeMap * ) malloc( sizeof( IXML_NamedNodeMap ) ); | ||||
|         if( *nnMap == NULL ) { | ||||
|             return IXML_INSUFFICIENT_MEMORY; | ||||
|         } | ||||
|         ixmlNamedNodeMap_init( *nnMap ); | ||||
|     } | ||||
|  | ||||
|     if( ( *nnMap )->nodeItem == NULL ) { | ||||
|         ( *nnMap )->nodeItem = add; | ||||
|     } else { | ||||
| @@ -181,7 +227,9 @@ int ixmlNamedNodeMap_addToNamedNodeMap( | ||||
|             p = traverse; | ||||
|             traverse = traverse->next; | ||||
|         } | ||||
| 		newItem = (IXML_NamedNodeMap *)malloc(sizeof (IXML_NamedNodeMap)); | ||||
|  | ||||
|         newItem = | ||||
|             ( IXML_NamedNodeMap * ) malloc( sizeof( IXML_NamedNodeMap ) ); | ||||
|         if( newItem == NULL ) { | ||||
|             return IXML_INSUFFICIENT_MEMORY; | ||||
|         } | ||||
| @@ -192,4 +240,3 @@ int ixmlNamedNodeMap_addToNamedNodeMap( | ||||
|  | ||||
|     return IXML_SUCCESS; | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										1097
									
								
								ixml/src/node.c
									
									
									
									
									
								
							
							
						
						
									
										1097
									
								
								ixml/src/node.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,67 +1,71 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "ixmlparser.h" | ||||
|  | ||||
|  | ||||
| #include <assert.h> | ||||
| #include <string.h> | ||||
|  | ||||
|  | ||||
| void ixmlNodeList_init(IXML_NodeList *nList) | ||||
| /*================================================================ | ||||
| *   ixmlNodeList_init | ||||
| *       initializes a nodelist  | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlNodeList_init( IXML_NodeList * nList ) | ||||
| { | ||||
|     assert( nList != NULL ); | ||||
|  | ||||
|     memset( nList, 0, sizeof( IXML_NodeList ) ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Node *ixmlNodeList_item( | ||||
| 	IXML_NodeList *nList, | ||||
| /*================================================================ | ||||
| *   ixmlNodeList_item | ||||
| *       Returns the indexth item in the collection. If index is greater | ||||
| *       than or equal to the number of nodes in the list, this returns  | ||||
| *       null. | ||||
| *       External function. | ||||
| * | ||||
| *=================================================================*/ | ||||
| IXML_Node * | ||||
| ixmlNodeList_item( IXML_NodeList * nList, | ||||
|                    unsigned long index ) | ||||
| { | ||||
|     IXML_NodeList *next; | ||||
|     unsigned int i; | ||||
|  | ||||
| 	/* if the list ptr is NULL */ | ||||
|     // if the list ptr is NULL | ||||
|     if( nList == NULL ) { | ||||
|         return NULL; | ||||
|     } | ||||
| 	/* if index is more than list length */ | ||||
|     // if index is more than list length | ||||
|     if( index > ixmlNodeList_length( nList ) - 1 ) { | ||||
|         return NULL; | ||||
|     } | ||||
| @@ -71,19 +75,24 @@ IXML_Node *ixmlNodeList_item( | ||||
|         next = next->next; | ||||
|     } | ||||
|  | ||||
| 	if (next == NULL) { | ||||
| 		return NULL; | ||||
| 	} | ||||
|     if( next == NULL ) return NULL; | ||||
|  | ||||
|     return next->nodeItem; | ||||
|  | ||||
| } | ||||
|  | ||||
| int ixmlNodeList_addToNodeList( | ||||
| 	IXML_NodeList **nList, | ||||
| 	IXML_Node *add) | ||||
| /*================================================================ | ||||
| *   ixmlNodeList_addToNodeList | ||||
| *       Add a node to nodelist | ||||
| *       Internal to parser only. | ||||
| * | ||||
| *=================================================================*/ | ||||
| int | ||||
| ixmlNodeList_addToNodeList( IN IXML_NodeList ** nList, | ||||
|                             IN IXML_Node * add ) | ||||
| { | ||||
| 	IXML_NodeList *traverse = NULL; | ||||
| 	IXML_NodeList *p = NULL; | ||||
|     IXML_NodeList *traverse, | ||||
|      *p = NULL; | ||||
|     IXML_NodeList *newListItem; | ||||
|  | ||||
|     assert( add != NULL ); | ||||
| @@ -92,8 +101,8 @@ int ixmlNodeList_addToNodeList( | ||||
|         return IXML_FAILED; | ||||
|     } | ||||
|  | ||||
| 	if (*nList == NULL) { | ||||
| 		/* nodelist is empty */ | ||||
|     if( *nList == NULL )        // nodelist is empty | ||||
|     { | ||||
|         *nList = ( IXML_NodeList * ) malloc( sizeof( IXML_NodeList ) ); | ||||
|         if( *nList == NULL ) { | ||||
|             return IXML_INSUFFICIENT_MEMORY; | ||||
| @@ -111,7 +120,8 @@ int ixmlNodeList_addToNodeList( | ||||
|             traverse = traverse->next; | ||||
|         } | ||||
|  | ||||
| 		newListItem = (IXML_NodeList *)malloc(sizeof (IXML_NodeList)); | ||||
|         newListItem = | ||||
|             ( IXML_NodeList * ) malloc( sizeof( IXML_NodeList ) ); | ||||
|         if( newListItem == NULL ) { | ||||
|             return IXML_INSUFFICIENT_MEMORY; | ||||
|         } | ||||
| @@ -123,8 +133,15 @@ int ixmlNodeList_addToNodeList( | ||||
|     return IXML_SUCCESS; | ||||
| } | ||||
|  | ||||
|  | ||||
| unsigned long ixmlNodeList_length(IXML_NodeList *nList) | ||||
| /*================================================================ | ||||
| *   ixmlNodeList_length | ||||
| *       Returns the number of nodes in the list.  The range of valid | ||||
| *       child node indices is 0 to length-1 inclusive. | ||||
| *       External function.        | ||||
| * | ||||
| *=================================================================*/ | ||||
| unsigned long | ||||
| ixmlNodeList_length( IN IXML_NodeList * nList ) | ||||
| { | ||||
|     IXML_NodeList *list; | ||||
|     unsigned long length = 0; | ||||
| @@ -138,15 +155,22 @@ unsigned long ixmlNodeList_length(IXML_NodeList *nList) | ||||
|     return length; | ||||
| } | ||||
|  | ||||
|  | ||||
| void ixmlNodeList_free(IXML_NodeList *nList) | ||||
| /*================================================================ | ||||
| *   ixmlNodeList_free | ||||
| *       frees a nodeList | ||||
| *       External function | ||||
| *        | ||||
| *=================================================================*/ | ||||
| void | ||||
| ixmlNodeList_free( IN IXML_NodeList * nList ) | ||||
| { | ||||
|     IXML_NodeList *next; | ||||
|  | ||||
|     while( nList != NULL ) { | ||||
|         next = nList->next; | ||||
|  | ||||
|         free( nList ); | ||||
|         nList = next; | ||||
|     } | ||||
| } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -6,6 +6,6 @@ includedir=@includedir@ | ||||
| Name: libupnp | ||||
| Description: Linux SDK for UPnP Devices | ||||
| Version: @VERSION@ | ||||
| Libs: @PTHREAD_CFLAGS@ @PTHREAD_LIBS@ -L${libdir} -lupnp -lthreadutil -lixml  | ||||
| Libs: @PTHREAD_LIBS@ -L${libdir} -lupnp -lthreadutil -lixml  | ||||
| Cflags: @PTHREAD_CFLAGS@ -I${includedir}/upnp | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| Version: 1.6.10 | ||||
| Version: 1.6.6 | ||||
| Summary: Universal Plug and Play (UPnP) SDK | ||||
| Name: libupnp | ||||
| Release: 1%{?dist} | ||||
|   | ||||
| @@ -32,96 +32,105 @@ | ||||
| #ifndef FREE_LIST_H | ||||
| #define FREE_LIST_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include "ithread.h" | ||||
|  | ||||
| #include <errno.h> | ||||
|  | ||||
| /*! | ||||
|  * Free list node. points to next free item. | ||||
|  * Memory for node is borrowed from allocated items. | ||||
|  * \internal | ||||
|  */ | ||||
| /**************************************************************************** | ||||
|  * Name: FreeListNode | ||||
|  * | ||||
|  *  Description: | ||||
|  *      free list node. points to next free item. | ||||
|  *      memory for node is borrowed from allocated items. | ||||
|  *      Internal Use Only. | ||||
|  *****************************************************************************/ | ||||
| typedef struct FREELISTNODE | ||||
| { | ||||
| 	struct FREELISTNODE *next; | ||||
| } FreeListNode; | ||||
|  | ||||
| /*! | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Name: FreeList | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Stores head and size of free list, as well as mutex for protection. | ||||
|  * \internal | ||||
|  */ | ||||
|  *      Internal Use Only. | ||||
|  *****************************************************************************/ | ||||
| typedef struct FREELIST | ||||
| { | ||||
| 	FreeListNode *head; | ||||
| 	size_t element_size; | ||||
|  	int maxFreeListLength; | ||||
| 	int freeListLength; | ||||
|          | ||||
| }FreeList; | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes Free List. | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListInit | ||||
|  * | ||||
|  * Must be called first and only once for FreeList. | ||||
|  * | ||||
|  * \return: | ||||
|  *	\li \c 0 on success. | ||||
|  *	\li \c EINVAL on failure. | ||||
|  */ | ||||
| int FreeListInit( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	FreeList *free_list, | ||||
| 	/*! Size of elements to store in free list. */ | ||||
|  *  Description: | ||||
|  *      Initializes Free List. Must be called first. | ||||
|  *      And only once for FreeList. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a linked list. | ||||
|  *      size_t -     size of elements to store in free list | ||||
|  *      maxFreeListSize - max size that the free list can grow to | ||||
|  *                        before returning memory to O.S. | ||||
|  *  Returns: | ||||
|  *      0 on success. Nonzero on failure. | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int FreeListInit(FreeList *free_list,  | ||||
| 				 size_t elementSize,  | ||||
| 	/*! Max size that the free list can grow to before returning | ||||
| 	 * memory to O.S. */ | ||||
| 	int maxFreeListLength); | ||||
| 				 int maxFreeListSize); | ||||
|  | ||||
| /*! | ||||
|  * \brief Allocates chunk of set size. | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListAlloc | ||||
|  * | ||||
|  * If a free item is available in the list, returnes the stored item, | ||||
|  * otherwise calls the O.S. to allocate memory. | ||||
|  * | ||||
|  * \return Non NULL on success. NULL on failure. | ||||
|  */ | ||||
| void *FreeListAlloc( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	FreeList *free_list); | ||||
|  *  Description: | ||||
|  *      Allocates chunk of set size. | ||||
|  *      If a free item is available in the list, returnes the stored item. | ||||
|  *      Otherwise calls the O.S. to allocate memory. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a linked list. | ||||
|  *  Returns: | ||||
|  *      Non NULL on success. NULL on failure. | ||||
|  *****************************************************************************/ | ||||
| void * FreeListAlloc (FreeList *free_list); | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns an item to the Free List. | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListFree | ||||
|  * | ||||
|  * If the free list is smaller than the max size then adds the item to the | ||||
|  * free list, otherwise returns the item to the O.S. | ||||
|  * | ||||
|  * \return: | ||||
|  *	\li \c 0 on success. | ||||
|  *	\li \c EINVAL on failure. | ||||
|  */ | ||||
| int FreeListFree( | ||||
| 	/*! Must be valid, non null, pointer to a free list. */ | ||||
| 	FreeList *free_list, | ||||
| 	/*! Must be a pointer allocated by FreeListAlloc. */ | ||||
| 	void *element); | ||||
|  *  Description: | ||||
|  *      Returns an item to the Free List. | ||||
|  *      If the free list is smaller than the max size than | ||||
|  *      adds the item to the free list. | ||||
|  *      Otherwise returns the item to the O.S. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a linked list. | ||||
|  *  Returns: | ||||
|  *      0 on success. Nonzero on failure. | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int FreeListFree (FreeList *free_list,void * element); | ||||
|  | ||||
| /*! | ||||
|  * \brief Releases the resources stored with the free list. | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListDestroy | ||||
|  * | ||||
|  * \return: | ||||
|  *	\li \c 0 on success. | ||||
|  *	\li \c EINVAL on failure. | ||||
|  */ | ||||
| int FreeListDestroy( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	FreeList *free_list); | ||||
|  *  Description: | ||||
|  *      Releases the resources stored with the free list. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a linked list. | ||||
|  *  Returns: | ||||
|  *      0 on success. Nonzero on failure. | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int FreeListDestroy (FreeList *free_list); | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
|   | ||||
| @@ -32,10 +32,6 @@ | ||||
| #ifndef LINKED_LIST_H | ||||
| #define LINKED_LIST_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #include "FreeList.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| @@ -48,15 +44,30 @@ extern "C" { | ||||
| #define LIST_SUCCESS 1 | ||||
| #define LIST_FAIL 0 | ||||
|  | ||||
| /*! Function for freeing list items. */ | ||||
| /**************************************************************************** | ||||
|  * Name: free_routine | ||||
|  * | ||||
|  *  Description: | ||||
|  *     Function for freeing list items | ||||
|  *****************************************************************************/ | ||||
| typedef void (*free_function)(void *arg); | ||||
|  | ||||
| /*! Function for comparing list items. Returns 1 if itemA==itemB */ | ||||
| /**************************************************************************** | ||||
|  * Name: cmp_routine | ||||
|  * | ||||
|  *  Description: | ||||
|  *     Function for comparing list items | ||||
|  *     Returns 1 if itemA==itemB | ||||
|  *****************************************************************************/ | ||||
| typedef int (*cmp_routine)(void *itemA,void *itemB); | ||||
|  | ||||
| /*! Linked list node. Stores generic item and pointers to next and prev. | ||||
|  * \internal | ||||
|  */ | ||||
| /**************************************************************************** | ||||
|  * Name: ListNode | ||||
|  * | ||||
|  *  Description: | ||||
|  *      linked list node. stores generic item and pointers to next and prev. | ||||
|  *      Internal Use Only. | ||||
|  *****************************************************************************/ | ||||
| typedef struct LISTNODE | ||||
| { | ||||
|   struct LISTNODE *prev; | ||||
| @@ -64,10 +75,13 @@ typedef struct LISTNODE | ||||
|   void *item; | ||||
| } ListNode; | ||||
|  | ||||
| /*! | ||||
|  * Linked list (no protection). | ||||
| /**************************************************************************** | ||||
|  * Name: LinkedList | ||||
|  * | ||||
|  * Because this is for internal use, parameters are NOT checked for validity. | ||||
|  *  Description: | ||||
|  *      linked list (no protection). Internal Use Only. | ||||
|  *      Because this is for internal use, parameters are NOT checked for  | ||||
|  *      validity. | ||||
|  *      The first item of the list is stored at node: head->next | ||||
|  *      The last item of the list is stored at node: tail->prev | ||||
|  *      If head->next=tail, then list is empty. | ||||
| @@ -75,211 +89,239 @@ typedef struct LISTNODE | ||||
|  * | ||||
|  *       LinkedList g; | ||||
|  *       ListNode *temp = NULL; | ||||
|  *	for (temp = ListHead(g);temp!=NULL;temp = ListNext(g,temp)) { | ||||
|  *       for (temp = ListHead(g);temp!=NULL;temp = ListNext(g,temp)) | ||||
|  *       { | ||||
|  *        } | ||||
|  * | ||||
|  * \internal | ||||
|  */ | ||||
|  *****************************************************************************/ | ||||
| typedef struct LINKEDLIST | ||||
| { | ||||
| 	/*! head, first item is stored at: head->next */ | ||||
| 	ListNode head; | ||||
| 	/*! tail, last item is stored at: tail->prev  */ | ||||
| 	ListNode tail; | ||||
| 	/*! size of list */ | ||||
| 	long size; | ||||
| 	/*! free list to use */ | ||||
| 	FreeList freeNodeList; | ||||
| 	/*! free function to use */ | ||||
| 	free_function free_func; | ||||
| 	/*! compare function to use */ | ||||
| 	cmp_routine cmp_func; | ||||
|   ListNode head; /* head, first item is stored at: head->next */ | ||||
|   ListNode tail; /* tail, last item is stored at: tail->prev  */ | ||||
|   long size;     /* size of list */ | ||||
|   FreeList freeNodeList;   /* free list to use */ | ||||
|   free_function free_func; /* free function to use */ | ||||
|   cmp_routine cmp_func;    /* compare function to use */ | ||||
| } LinkedList; | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes LinkedList. Must be called first and only once for List. | ||||
| /**************************************************************************** | ||||
|  * Function: ListInit | ||||
|  * | ||||
|  *  \return | ||||
|  *	\li \c 0 on success. | ||||
|  *	\li \c EOUTOFMEM on failure. | ||||
|  */ | ||||
| int ListInit( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Function used to compare items. (May be NULL). */ | ||||
| 	cmp_routine cmp_func, | ||||
| 	/*! Function used to free items. (May be NULL). */ | ||||
| 	free_function free_func); | ||||
|  *  Description: | ||||
|  *      Initializes LinkedList. Must be called first. | ||||
|  *      And only once for List. | ||||
|  *  Parameters: | ||||
|  *      list  - must be valid, non null, pointer to a linked list. | ||||
|  *      cmp_func - function used to compare items. (May be NULL) | ||||
|  *      free_func - function used to free items. (May be NULL) | ||||
|  *  Returns: | ||||
|  *      0 on success, EOUTOFMEM on failure. | ||||
|  *****************************************************************************/ | ||||
| int ListInit(LinkedList *list,cmp_routine cmp_func, free_function free_func); | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds a node to the head of the list. Node gets immediately after | ||||
|  * list head. | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddHead | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Adds a node to the head of the list. | ||||
|  *      Node gets immediately after list.head. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      void * item - item to be added | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  * | ||||
|  * \return The pointer to the ListNode on success, NULL on failure. | ||||
|  */ | ||||
| ListNode *ListAddHead( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Item to be added. */ | ||||
| 	void *item); | ||||
|  *****************************************************************************/ | ||||
| ListNode *ListAddHead(LinkedList *list, void *item); | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds a node to the tail of the list. Node gets added immediately | ||||
|  * before list.tail. | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddTail | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The pointer to the ListNode on success, NULL on failure. | ||||
|  */ | ||||
| ListNode *ListAddTail( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Item to be added. */ | ||||
| 	void *item); | ||||
|  *  Description: | ||||
|  *      Adds a node to the tail of the list. | ||||
|  *      Node gets added immediately before list.tail. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      void * item - item to be added | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode *ListAddTail(LinkedList *list, void *item); | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds a node after the specified node. Node gets added immediately | ||||
|  * after bnode. | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddAfter | ||||
|  * | ||||
|  *  Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The pointer to the ListNode on success, NULL on failure. | ||||
|  */ | ||||
| ListNode *ListAddAfter( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Item to be added. */ | ||||
| 	void *item, | ||||
| 	/*! Node to add after. */ | ||||
| 	ListNode *bnode); | ||||
|  *  Description: | ||||
|  *      Adds a node after the specified node. | ||||
|  *      Node gets added immediately after bnode. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      void * item - item to be added | ||||
|  *      ListNode * bnode - node to add after | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode *ListAddAfter(LinkedList *list, void *item, ListNode *bnode); | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds a node before the specified node. Node gets added immediately | ||||
|  * before anode. | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The pointer to the ListNode on success, NULL on failure. | ||||
|  */ | ||||
| ListNode *ListAddBefore( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Item to be added. */ | ||||
| 	void *item, | ||||
| 	/*! Node to add in front of. */ | ||||
| 	ListNode *anode); | ||||
|  | ||||
| /*! | ||||
|  * \brief Removes a node from the list. The memory for the node is freed. | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddBefore | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The pointer to the item stored in the node or NULL if the item | ||||
|  * is freed. | ||||
|  */ | ||||
| void *ListDelNode( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Node to delete. */ | ||||
| 	ListNode *dnode, | ||||
| 	/*! if !0 then item is freed using free function. If 0 (or free | ||||
| 	 * function is NULL) then item is not freed. */ | ||||
| 	int freeItem); | ||||
|  *  Description: | ||||
|  *      Adds a node before the specified node. | ||||
|  *      Node gets added immediately before anode. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      ListNode * anode  - node to add the in front of. | ||||
|  *      void * item - item to be added | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode *ListAddBefore(LinkedList *list,void *item, ListNode *anode); | ||||
|  | ||||
| /*! | ||||
|  * \brief Removes all memory associated with list nodes. Does not free | ||||
|  * LinkedList *list. | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return 0 on success, EINVAL on failure. | ||||
|  */ | ||||
| int ListDestroy( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! if !0 then item is freed using free function. If 0 (or free | ||||
| 	 * function is NULL) then item is not freed. */ | ||||
| 	int freeItem); | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the head of the list. | ||||
| /**************************************************************************** | ||||
|  * Function: ListDelNode | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The head of the list. NULL if list is empty. | ||||
|  */ | ||||
| ListNode *ListHead( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list); | ||||
|  *  Description: | ||||
|  *      Removes a node from the list | ||||
|  *      The memory for the node is freed. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      ListNode *dnode - done to delete. | ||||
|  *      freeItem - if !0 then item is freed using free function. | ||||
|  *                 if 0 (or free function is NULL) then item is not freed | ||||
|  *  Returns: | ||||
|  *      The pointer to the item stored in the node or NULL if the item is freed. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| void *ListDelNode(LinkedList *list,ListNode *dnode, int freeItem); | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the tail of the list. | ||||
| /**************************************************************************** | ||||
|  * Function: ListDestroy | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  *  Description: | ||||
|  *      Removes all memory associated with list nodes.  | ||||
|  *      Does not free LinkedList *list.  | ||||
|  *     | ||||
|  * \return The tail of the list. NULL if list is empty. | ||||
|  */ | ||||
| ListNode *ListTail( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list); | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      freeItem - if !0 then items are freed using the free_function. | ||||
|  *                 if 0 (or free function is NULL) then items are not freed. | ||||
|  *  Returns: | ||||
|  *      0 on success. Always returns 0. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| int ListDestroy(LinkedList *list, int freeItem); | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the next item in the list. | ||||
|  *     | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The next item in the list. NULL if there are no more items in list. | ||||
|  */ | ||||
| ListNode *ListNext( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Node from the list. */ | ||||
| 	ListNode *node); | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the previous item in the list. | ||||
| /**************************************************************************** | ||||
|  * Function: ListHead | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  *  Description: | ||||
|  *      Returns the head of the list. | ||||
|  *     | ||||
|  * \return The previous item in the list. NULL if there are no more items in list. | ||||
|  */ | ||||
| ListNode *ListPrev( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! Node from the list. */ | ||||
| 	ListNode *node); | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The head of the list. NULL if list is empty. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode* ListHead(LinkedList *list); | ||||
|  | ||||
| /*! | ||||
|  * \brief Finds the specified item in the list. | ||||
| /**************************************************************************** | ||||
|  * Function: ListTail | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns the tail of the list. | ||||
|  *     | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The tail of the list. NULL if list is empty. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode* ListTail(LinkedList *list); | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ListNext | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns the next item in the list. | ||||
|  *     | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The next item in the list. NULL if there are no more items in list. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode* ListNext(LinkedList *list, ListNode * node); | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ListPrev | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns the previous item in the list. | ||||
|  *     | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The previous item in the list. NULL if there are no more items in list. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode* ListPrev(LinkedList *list, ListNode * node); | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ListFind | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Finds the specified item in the list. | ||||
|  *      Uses the compare function specified in ListInit. If compare function | ||||
|  *      is NULL then compares items as pointers. | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The node containing the item. NULL if no node contains the item. | ||||
|  */ | ||||
| ListNode* ListFind( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList *list, | ||||
| 	/*! The node to start from, NULL if to start from beginning. */ | ||||
| 	ListNode *start, | ||||
| 	/*! The item to search for. */ | ||||
| 	void *item); | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      ListNode *start - the node to start from, NULL if to start from  | ||||
|  *                        beginning. | ||||
|  *      void * item - the item to search for. | ||||
|  *  Returns: | ||||
|  *      The node containing the item. NULL if no node contains the item. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode* ListFind(LinkedList *list, ListNode *start, void * item); | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the size of the list. | ||||
| /**************************************************************************** | ||||
|  * Function: ListSize | ||||
|  * | ||||
|  * Precondition: The list has been initialized. | ||||
|  * | ||||
|  * \return The number of items in the list. | ||||
|  */ | ||||
| long ListSize( | ||||
| 	/*! Must be valid, non null, pointer to a linked list. */ | ||||
| 	LinkedList* list); | ||||
|  *  Description: | ||||
|  *     Returns the size of the list. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|   | ||||
|  *  Returns: | ||||
|  *      The number of items in the list. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| int ListSize(LinkedList* list); | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
|   | ||||
| @@ -32,20 +32,57 @@ | ||||
| #ifndef THREADPOOL_H | ||||
| #define THREADPOOL_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
| #ifdef UPNP_USE_MSVCPP | ||||
| 	#define UPNP_INLINE | ||||
| #else | ||||
| 	#define UPNP_INLINE inline | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /* Size of job free list */ | ||||
| #define JOBFREELISTSIZE 100 | ||||
|  | ||||
| #define INFINITE_THREADS -1 | ||||
|  | ||||
| #define EMAXTHREADS (-8 & 1<<29) | ||||
|  | ||||
| /* Invalid Policy */ | ||||
| #define INVALID_POLICY (-9 & 1<<29) | ||||
|  | ||||
| /* Invalid JOB Id */ | ||||
| #define INVALID_JOB_ID (-2 & 1<<29) | ||||
|  | ||||
| typedef enum duration {SHORT_TERM,PERSISTENT} Duration; | ||||
|  | ||||
| typedef enum priority {LOW_PRIORITY, | ||||
| 		       MED_PRIORITY, | ||||
| 		       HIGH_PRIORITY} ThreadPriority; | ||||
|  | ||||
| #define DEFAULT_PRIORITY MED_PRIORITY /* default priority used by TPJobInit */ | ||||
| #define DEFAULT_MIN_THREADS 1	      /* default minimum used by TPAttrInit */ | ||||
| #define DEFAULT_MAX_THREADS 10	      /* default max used by TPAttrInit	*/ | ||||
| #define DEFAULT_JOBS_PER_THREAD 10    /* default jobs per thread used by TPAttrInit */ | ||||
| #define DEFAULT_STARVATION_TIME	500   /* default starvation time used by TPAttrInit */ | ||||
| #define DEFAULT_IDLE_TIME 10 * 1000   /* default idle time used by TPAttrInit */ | ||||
| #define DEFAULT_FREE_ROUTINE NULL     /* default free routine used TPJobInit */ | ||||
| #define DEFAULT_MAX_JOBS_TOTAL 100    /* default max jobs used TPAttrInit */ | ||||
|  | ||||
| /* Statistics */ | ||||
| /* always include stats because code change is minimal */ | ||||
| #define STATS 1 | ||||
|  | ||||
| #ifdef _DEBUG | ||||
| 	#define DEBUG 1 | ||||
| #endif | ||||
|  | ||||
| #include "FreeList.h" | ||||
| #include "ithread.h" | ||||
| #include "LinkedList.h" | ||||
| #include "UpnpInet.h" | ||||
| #include "UpnpGlobal.h" /* for UPNP_INLINE, EXPORT_SPEC */ | ||||
|  | ||||
| #include <errno.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
|     #include <time.h> | ||||
|     #include <winsock2.h> | ||||
|     struct timezone  | ||||
|     { | ||||
|         int  tz_minuteswest; /* minutes W of Greenwich */ | ||||
| @@ -53,112 +90,67 @@ | ||||
|     }; | ||||
|     int gettimeofday(struct timeval *tv, struct timezone *tz); | ||||
| #else /* WIN32 */ | ||||
| 	#include <sys/param.h> | ||||
|     #include <sys/time.h> /* for gettimeofday() */ | ||||
| 	#if defined(__OSX__) || defined(__APPLE__) || defined(__NetBSD__) | ||||
| 		#include <sys/resource.h>	/* for setpriority() */ | ||||
| 	#endif | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| #include "FreeList.h" | ||||
|  | ||||
| /*! Size of job free list */ | ||||
| #define JOBFREELISTSIZE 100 | ||||
| #include "ithread.h" | ||||
| #include <errno.h> | ||||
|  | ||||
| #define INFINITE_THREADS -1 | ||||
|  | ||||
| #define EMAXTHREADS (-8 & 1<<29) | ||||
|  | ||||
| /*! Invalid Policy */ | ||||
| #define INVALID_POLICY (-9 & 1<<29) | ||||
|  | ||||
| /*! Invalid JOB Id */ | ||||
| #define INVALID_JOB_ID (-2 & 1<<29) | ||||
|  | ||||
| typedef enum duration { | ||||
| 	SHORT_TERM, | ||||
| 	PERSISTENT | ||||
| } Duration; | ||||
|  | ||||
| typedef enum priority { | ||||
| 	LOW_PRIORITY, | ||||
| 	MED_PRIORITY, | ||||
| 	HIGH_PRIORITY | ||||
| } ThreadPriority; | ||||
|  | ||||
| /*! default priority used by TPJobInit */ | ||||
| #define DEFAULT_PRIORITY MED_PRIORITY | ||||
|  | ||||
| /*! default minimum used by TPAttrInit */ | ||||
| #define DEFAULT_MIN_THREADS 1 | ||||
|  | ||||
| /*! default max used by TPAttrInit */ | ||||
| #define DEFAULT_MAX_THREADS 10 | ||||
|  | ||||
| /*! default stack size used by TPAttrInit */ | ||||
| #define DEFAULT_STACK_SIZE 0 | ||||
|  | ||||
| /*! default jobs per thread used by TPAttrInit */ | ||||
| #define DEFAULT_JOBS_PER_THREAD 10 | ||||
|  | ||||
| /*! default starvation time used by TPAttrInit */ | ||||
| #define DEFAULT_STARVATION_TIME	500 | ||||
|  | ||||
| /*! default idle time used by TPAttrInit */ | ||||
| #define DEFAULT_IDLE_TIME 10 * 1000 | ||||
|  | ||||
| /*! default free routine used TPJobInit */ | ||||
| #define DEFAULT_FREE_ROUTINE NULL | ||||
|  | ||||
| /*! default max jobs used TPAttrInit */ | ||||
| #define DEFAULT_MAX_JOBS_TOTAL 100 | ||||
|  | ||||
| /*! | ||||
|  * \brief Statistics. | ||||
|  * | ||||
|  * Always include stats because code change is minimal. | ||||
|  */ | ||||
| #define STATS 1 | ||||
|  | ||||
| #ifdef _DEBUG | ||||
| 	#define DEBUG 1 | ||||
| #endif | ||||
| #define EXPORT | ||||
|  | ||||
| typedef int PolicyType; | ||||
|  | ||||
| #define DEFAULT_POLICY SCHED_OTHER | ||||
| #define DEFAULT_SCHED_PARAM 0 /* default priority */ | ||||
|  | ||||
| /*! Function for freeing a thread argument. */ | ||||
| /**************************************************************************** | ||||
|  * Name: free_routine | ||||
|  * | ||||
|  *  Description: | ||||
|  *     Function for freeing a thread argument | ||||
|  *****************************************************************************/ | ||||
| typedef void (*free_routine)(void *arg); | ||||
|  | ||||
|  | ||||
| /*! Attributes for thread pool. Used to set and change parameters of thread | ||||
|  * pool. */ | ||||
| /**************************************************************************** | ||||
|  * Name: ThreadPoolAttr | ||||
|  * | ||||
|  *  Description: | ||||
|  *     Attributes for thread pool. Used to set and change parameters of | ||||
|  *     thread pool | ||||
|  *****************************************************************************/ | ||||
| typedef struct THREADPOOLATTR | ||||
| { | ||||
| 	/*! ThreadPool will always maintain at least this many threads. */ | ||||
| 	/* minThreads, ThreadPool will always maintain at least this many threads */ | ||||
| 	int minThreads; | ||||
| 	/*! ThreadPool will never have more than this number of threads. */ | ||||
|  | ||||
| 	/* maxThreads, ThreadPool will never have more than this number of threads */ | ||||
| 	int maxThreads; | ||||
| 	/*! This is the minimum stack size allocated for each thread. */ | ||||
| 	size_t stackSize; | ||||
| 	/*! This is the maximum time a thread will | ||||
| 	 * remain idle before dying (in milliseconds). */ | ||||
|  | ||||
| 	/* maxIdleTime (in milliseconds) this is the maximum time a thread will | ||||
| 	 * remain idle before dying */ | ||||
| 	int maxIdleTime; | ||||
| 	/*! Jobs per thread to maintain. */ | ||||
|  | ||||
| 	/* jobs per thread to maintain */ | ||||
| 	int jobsPerThread; | ||||
| 	/*! Maximum number of jobs that can be queued totally. */ | ||||
|  | ||||
| 	/* maximum number of jobs that can be queued totally. */ | ||||
| 	int maxJobsTotal; | ||||
| 	/*! the time a low priority or med priority job waits before getting | ||||
| 	 * bumped up a priority (in milliseconds). */ | ||||
|  | ||||
| 	/* the time a low priority or med priority job waits before getting bumped | ||||
| 	 * up a priority (in milliseconds) */ | ||||
| 	int starvationTime; | ||||
| 	/*! scheduling policy to use. */ | ||||
|  | ||||
| 	/* scheduling policy to use */ | ||||
| 	PolicyType schedPolicy; | ||||
| } ThreadPoolAttr; | ||||
|  | ||||
| /*! Internal ThreadPool Job. */ | ||||
| /**************************************************************************** | ||||
|  * Name: ThreadPool | ||||
|  * | ||||
|  *  Description: | ||||
|  *     Internal ThreadPool Job | ||||
|  *****************************************************************************/ | ||||
| typedef struct THREADPOOLJOB | ||||
| { | ||||
| 	start_routine func; | ||||
| @@ -169,7 +161,13 @@ typedef struct THREADPOOLJOB | ||||
| 	int jobId; | ||||
| } ThreadPoolJob; | ||||
|  | ||||
| /*! Structure to hold statistics. */ | ||||
| /**************************************************************************** | ||||
|  * Name: ThreadPoolStats | ||||
|  * | ||||
|  *  Description: | ||||
|  *     Structure to hold statistics | ||||
|  *****************************************************************************/ | ||||
|  | ||||
| typedef struct TPOOLSTATS | ||||
| { | ||||
| 	double totalTimeHQ; | ||||
| @@ -193,12 +191,16 @@ typedef struct TPOOLSTATS | ||||
| 	int currentJobsMQ; | ||||
| } ThreadPoolStats; | ||||
|  | ||||
| /*! | ||||
|  * \brief A thread pool similar to the thread pool in the UPnP SDK. | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Name: ThreadPool | ||||
|  * | ||||
|  *  Description: | ||||
|  *     A thread pool similar to the thread pool in the UPnP SDK. | ||||
|  *     Allows jobs to be scheduled for running by threads in a  | ||||
|  *     thread pool. The thread pool is initialized with a  | ||||
|  * minimum and maximum thread number as well as a max idle time | ||||
|  *     minimum and maximum thread number as well as a  | ||||
|  *	   max idle time | ||||
|  *     and a jobs per thread ratio. If a worker thread waits the whole | ||||
|  *     max idle time without receiving a job and the thread pool | ||||
|  *     currently has more threads running than the minimum | ||||
| @@ -207,327 +209,349 @@ typedef struct TPOOLSTATS | ||||
|  *     becomes greater than the set ratio and the thread pool currently has | ||||
|  *     less than the maximum threads then a new thread will | ||||
|  *     be created. | ||||
|  */ | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
|  | ||||
| typedef struct THREADPOOL | ||||
| { | ||||
| 	/*! Mutex to protect job qs. */ | ||||
| 	ithread_mutex_t mutex; | ||||
| 	/*! Condition variable to signal Q. */ | ||||
| 	ithread_cond_t condition; | ||||
| 	/*! Condition variable for start and stop. */ | ||||
| 	ithread_cond_t start_and_shutdown; | ||||
| 	/*! ids for jobs */ | ||||
| 	int lastJobId; | ||||
| 	/*! whether or not we are shutting down */ | ||||
| 	int shutdown; | ||||
| 	/*! total number of threads */ | ||||
| 	int totalThreads; | ||||
| 	/*! number of threads that are currently executing jobs */ | ||||
| 	int busyThreads; | ||||
| 	/*! number of persistent threads */ | ||||
| 	int persistentThreads; | ||||
| 	/*! free list of jobs */ | ||||
| 	FreeList jobFreeList; | ||||
| 	/*! low priority job Q */ | ||||
| 	LinkedList lowJobQ; | ||||
| 	/*! med priority job Q */ | ||||
| 	LinkedList medJobQ; | ||||
| 	/*! high priority job Q */ | ||||
| 	LinkedList highJobQ; | ||||
| 	/*! persistent job */ | ||||
| 	ThreadPoolJob *persistentJob; | ||||
| 	/*! thread pool attributes */ | ||||
| 	ThreadPoolAttr attr; | ||||
| 	/*! statistics */ | ||||
| 	ithread_mutex_t mutex; /* mutex to protect job qs */ | ||||
| 	ithread_cond_t condition; /* condition variable to signal Q */ | ||||
| 	ithread_cond_t start_and_shutdown; /* condition variable for start  | ||||
| 					and stop */ | ||||
| 	int lastJobId; /* ids for jobs */ | ||||
| 	int shutdown;  /* whether or not we are shutting down */ | ||||
| 	int totalThreads;      /* total number of threads */ | ||||
| 	int persistentThreads; /* number of persistent threads */ | ||||
| 	FreeList jobFreeList;  /* free list of jobs */ | ||||
| 	LinkedList lowJobQ;    /* low priority job Q */ | ||||
| 	LinkedList medJobQ;    /* med priority job Q */ | ||||
| 	LinkedList highJobQ;   /* high priority job Q */ | ||||
| 	ThreadPoolJob *persistentJob; /* persistent job */ | ||||
|  | ||||
| 	ThreadPoolAttr attr; /* thread pool attributes */ | ||||
|  | ||||
| 	/* statistics */ | ||||
| 	ThreadPoolStats stats; | ||||
| } ThreadPool; | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes and starts ThreadPool. Must be called first and | ||||
|  * only once for ThreadPool. | ||||
|  * | ||||
|  * \return | ||||
|  * \li \c 0 on success. | ||||
|  * \li \c EAGAIN if not enough system resources to create minimum threads. | ||||
|  * \li \c INVALID_POLICY if schedPolicy can't be set. | ||||
|  * \li \c EMAXTHREADS if minimum threads is greater than maximum threads. | ||||
|  */ | ||||
| int ThreadPoolInit( | ||||
| 	/*! Must be valid, non null, pointer to ThreadPool. */ | ||||
| 	ThreadPool *tp, | ||||
| 	/*! Can be null. if not null then attr contains the following fields: | ||||
| 	 * \li \c minWorkerThreads - minimum number of worker threads thread | ||||
| 	 * pool will never have less than this number of threads. | ||||
| 	 * \li \c maxWorkerThreads - maximum number of worker threads thread | ||||
| 	 * pool will never have more than this number of threads. | ||||
| 	 * \li \c maxIdleTime - maximum time that a worker thread will spend | ||||
| 	 * idle. If a worker is idle longer than this time and there are more | ||||
| 	 * than the min number of workers running, then the worker thread | ||||
| 	 * exits. | ||||
| 	 * \li \c jobsPerThread - ratio of jobs to thread to try and maintain | ||||
| 	 * if a job is scheduled and the number of jobs per thread is greater | ||||
| 	 * than this number,and if less than the maximum number of workers are | ||||
| 	 * running then a new thread is started to help out with efficiency. | ||||
| 	 * \li \c schedPolicy - scheduling policy to try and set (OS dependent). | ||||
| 	 */ | ||||
| 	ThreadPoolAttr *attr); | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds a persistent job to the thread pool. | ||||
|  * | ||||
|  * Job will be run as soon as possible. Call will block until job is scheduled. | ||||
|  *  | ||||
|  * \return | ||||
|  *	\li \c 0 on success. | ||||
|  *	\li \c EOUTOFMEM not enough memory to add job. | ||||
|  *	\li \c EMAXTHREADS not enough threads to add persistent job. | ||||
|  */ | ||||
| int ThreadPoolAddPersistent( | ||||
| 	/*! Valid thread pool pointer. */ | ||||
| 	ThreadPool*tp, | ||||
| 	/*! Valid thread pool job. */ | ||||
| 	ThreadPoolJob *job, | ||||
| 	/*! . */ | ||||
| 	int *jobId); | ||||
|  | ||||
| /*! | ||||
|  * \brief Gets the current set of attributes associated with the thread pool. | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolInit | ||||
|  * | ||||
|  * \return | ||||
|  * 	\li \c 0 on success, nonzero on failure. | ||||
|  */ | ||||
| int ThreadPoolGetAttr( | ||||
| 	/*! valid thread pool pointer. */ | ||||
| 	ThreadPool *tp, | ||||
| 	/*! non null pointer to store attributes. */ | ||||
| 	ThreadPoolAttr *out); | ||||
|  *  Description: | ||||
|  *      Initializes and starts ThreadPool. Must be called first. | ||||
|  *      And only once for ThreadPool. | ||||
|  *  Parameters: | ||||
|  *      tp  - must be valid, non null, pointer to ThreadPool. | ||||
|  *      attr - can be null | ||||
|  * | ||||
|  *       if not null then attr contains the following fields: | ||||
|  * | ||||
|  *      minWorkerThreads - minimum number of worker threads | ||||
|  *                                 thread pool will never have less than this | ||||
|  *                                  number of threads. | ||||
|  *      maxWorkerThreads - maximum number of worker threads | ||||
|  *                         thread pool will never have more than this | ||||
|  *                         number of threads. | ||||
|  *      maxIdleTime      - maximum time that a worker thread will spend | ||||
|  *                         idle. If a worker is idle longer than this | ||||
|  *                         time and there are more than the min | ||||
|  *                         number of workers running, than the | ||||
|  *                         worker thread exits. | ||||
|  *      jobsPerThread    - ratio of jobs to thread to try and maintain | ||||
|  *                         if a job is scheduled and the number of jobs per | ||||
|  *                         thread is greater than this number,and   | ||||
|  *                         if less than the maximum number of | ||||
|  *                         workers are running then a new thread is  | ||||
|  *                         started to help out with efficiency. | ||||
|  *      schedPolicy      - scheduling policy to try and set (OS dependent) | ||||
|  *  Returns: | ||||
|  *      0 on success, nonzero on failure. | ||||
|  *      EAGAIN if not enough system resources to create minimum threads. | ||||
|  *      INVALID_POLICY if schedPolicy can't be set | ||||
|  *      EMAXTHREADS if minimum threads is greater than maximum threads | ||||
|  *****************************************************************************/ | ||||
| int ThreadPoolInit(ThreadPool *tp, ThreadPoolAttr *attr); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the attributes for the thread pool. | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolAddPersistent | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Adds a persistent job to the thread pool. | ||||
|  *      Job will be run as soon as possible. | ||||
|  *      Call will block until job is scheduled. | ||||
|  *  Parameters: | ||||
|  *      tp - valid thread pool pointer | ||||
|  *      ThreadPoolJob - valid thread pool job with the following fields: | ||||
|  * | ||||
|  *        func - ThreadFunction to run | ||||
|  *        arg - argument to function. | ||||
|  *        priority - priority of job. | ||||
|  *  | ||||
|  *  Returns: | ||||
|  *      0 on success, nonzero on failure | ||||
|  *      EOUTOFMEM not enough memory to add job. | ||||
|  *      EMAXTHREADS not enough threads to add persistent job. | ||||
|  *****************************************************************************/ | ||||
| int ThreadPoolAddPersistent(ThreadPool*tp, ThreadPoolJob *job, int *jobId); | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolGetAttr | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Gets the current set of attributes | ||||
|  *      associated with the thread pool. | ||||
|  *  Parameters: | ||||
|  *      tp - valid thread pool pointer | ||||
|  *      out - non null pointer to store attributes | ||||
|  *  Returns: | ||||
|  *      0 on success, nonzero on failure | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int ThreadPoolGetAttr(ThreadPool *tp, ThreadPoolAttr *out); | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolSetAttr | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Sets the attributes for the thread pool. | ||||
|  *      Only affects future calculations.  | ||||
|  * | ||||
|  * \return | ||||
|  * 	\li \c 0 on success, nonzero on failure. | ||||
|  * 	\li \c INVALID_POLICY if policy can not be set. | ||||
|  */ | ||||
| int ThreadPoolSetAttr( | ||||
| 	/*! valid thread pool pointer. */ | ||||
| 	ThreadPool *tp, | ||||
| 	/*! pointer to attributes, null sets attributes to default. */ | ||||
| 	ThreadPoolAttr *attr); | ||||
|  *  Parameters: | ||||
|  *      tp - valid thread pool pointer | ||||
|  *      attr - pointer to attributes, null sets attributes to default. | ||||
|  *  Returns: | ||||
|  *      0 on success, nonzero on failure | ||||
|  *      Returns INVALID_POLICY if policy can not be set. | ||||
|  *****************************************************************************/ | ||||
| int ThreadPoolSetAttr(ThreadPool *tp, ThreadPoolAttr *attr); | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds a job to the thread pool. Job will be run as soon as possible. | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolAdd | ||||
|  * | ||||
|  * \return | ||||
|  * 	\li \c 0 on success, nonzero on failure. | ||||
|  * 	\li \c EOUTOFMEM if not enough memory to add job. | ||||
|  */ | ||||
| int ThreadPoolAdd( | ||||
| 	/*! valid thread pool pointer. */ | ||||
| 	ThreadPool*tp, | ||||
| 	/*! . */ | ||||
| 	ThreadPoolJob *job, | ||||
| 	/*! id of job. */ | ||||
| 	int *jobId); | ||||
|  *  Description: | ||||
|  *      Adds a job to the thread pool. | ||||
|  *      Job will be run as soon as possible. | ||||
|  *  Parameters: | ||||
|  *      tp - valid thread pool pointer | ||||
|  *      func - ThreadFunction to run | ||||
|  *      arg - argument to function. | ||||
|  *      priority - priority of job. | ||||
|  *      poolid - id of job | ||||
|  *      free_function - function to use when freeing argument  | ||||
|  *  Returns: | ||||
|  *      0 on success, nonzero on failure | ||||
|  *      EOUTOFMEM if not enough memory to add job. | ||||
|  *****************************************************************************/ | ||||
| int ThreadPoolAdd (ThreadPool*tp, ThreadPoolJob *job, int *jobId); | ||||
|  | ||||
| /*! | ||||
|  * \brief Removes a job from the thread pool. Can only remove jobs which | ||||
|  * are not currently running. | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolRemove | ||||
|  * | ||||
|  * \return | ||||
|  * 	\li \c 0 on success, nonzero on failure. | ||||
|  * 	\li \c INVALID_JOB_ID if job not found.  | ||||
|  */ | ||||
| int ThreadPoolRemove( | ||||
| 	/*! valid thread pool pointer. */ | ||||
| 	ThreadPool *tp, | ||||
| 	/*! id of job. */ | ||||
| 	int jobId, | ||||
| 	/*! space for removed job. */ | ||||
| 	ThreadPoolJob *out); | ||||
|  *  Description: | ||||
|  *      Removes a job from the thread pool. | ||||
|  *      Can only remove jobs which are not | ||||
|  *      currently running. | ||||
|  *  Parameters: | ||||
|  *      tp - valid thread pool pointer | ||||
|  *      jobid - id of job | ||||
|  *      out - space for removed job. | ||||
|  *  Returns: | ||||
|  *      0 on success, nonzero on failure. | ||||
|  *      INVALID_JOB_ID if job not found.  | ||||
|  *****************************************************************************/ | ||||
| int ThreadPoolRemove(ThreadPool *tp, int jobId, ThreadPoolJob *out); | ||||
|  | ||||
| /*! | ||||
|  * \brief Shuts the thread pool down. Waits for all threads to finish. | ||||
|  * May block indefinitely if jobs do not exit. | ||||
|  * | ||||
|  * \return 0 on success, nonzero on failure | ||||
|  */ | ||||
| int ThreadPoolShutdown( | ||||
| 	/*! must be valid tp. */ | ||||
| 	ThreadPool *tp); | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes thread pool job. Sets the priority to default defined | ||||
|  * in ThreadPool.h. Sets the free_routine to default defined in ThreadPool.h. | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPJobInit( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolJob *job, | ||||
| 	/*! function to run, must be valid. */ | ||||
| 	start_routine func, | ||||
| 	/*! argument to pass to function. */ | ||||
| 	void *arg); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the max threads for the thread pool attributes. | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolShutdown | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPJobSetPriority( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolJob *job, | ||||
| 	/*! value to set. */ | ||||
| 	ThreadPriority priority); | ||||
|  *  Description: | ||||
|  *      Shuts the thread pool down. | ||||
|  *      Waits for all threads to finish.  | ||||
|  *      May block indefinitely if jobs do not | ||||
|  *      exit. | ||||
|  *  Parameters: | ||||
|  *      tp - must be valid tp      | ||||
|  *  Returns: | ||||
|  *      0 on success, nonzero on failure | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int ThreadPoolShutdown(ThreadPool *tp); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the max threads for the thread pool attributes. | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPJobSetFreeFunction( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolJob *job, | ||||
| 	/*! value to set. */ | ||||
| 	free_routine func); | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes thread pool attributes. Sets values to defaults defined | ||||
|  * in ThreadPool.h. | ||||
| /**************************************************************************** | ||||
|  * Function: TPJobInit | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrInit( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr); | ||||
|  *  Description: | ||||
|  *      Initializes thread pool job. | ||||
|  *      Sets the priority to default defined in ThreadPool.h. | ||||
|  *      Sets the free_routine to default defined in ThreadPool.h | ||||
|  *  Parameters: | ||||
|  *      ThreadPoolJob *job - must be valid thread pool attributes.     | ||||
|  *      start_routine func - function to run, must be valid | ||||
|  *      void * arg - argument to pass to function. | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPJobInit(ThreadPoolJob *job, start_routine func, void *arg); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the max threads for the thread pool attributes. | ||||
| /**************************************************************************** | ||||
|  * Function: TPJobSetPriority | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetMaxThreads( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! value to set. */ | ||||
| 	int maxThreads); | ||||
|  *  Description: | ||||
|  *      Sets the max threads for the thread pool attributes. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.  | ||||
|  *      maxThreads - value to set | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPJobSetPriority(ThreadPoolJob *job, ThreadPriority priority); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the min threads for the thread pool attributes. | ||||
| /**************************************************************************** | ||||
|  * Function: TPJobSetFreeFunction | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetMinThreads( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! value to set. */ | ||||
| 	int minThreads); | ||||
|  *  Description: | ||||
|  *      Sets the max threads for the thread pool attributes. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.  | ||||
|  *      maxThreads - value to set | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPJobSetFreeFunction(ThreadPoolJob *job, free_routine func); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the stack size for the thread pool attributes. | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrInit | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetStackSize( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! value to set. */ | ||||
| 	size_t stackSize); | ||||
|  *  Description: | ||||
|  *      Initializes thread pool attributes. | ||||
|  *      Sets values to defaults defined in ThreadPool.h. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.     | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrInit(ThreadPoolAttr *attr); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the idle time for the thread pool attributes. | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrSetMaxThreads | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetIdleTime( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! . */ | ||||
| 	int idleTime); | ||||
|  *  Description: | ||||
|  *      Sets the max threads for the thread pool attributes. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.  | ||||
|  *      maxThreads - value to set | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrSetMaxThreads(ThreadPoolAttr *attr, int maxThreads); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the jobs per thread ratio | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrSetMinThreads | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetJobsPerThread( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! number of jobs per thread to maintain. */ | ||||
| 	int jobsPerThread); | ||||
|  *  Description: | ||||
|  *      Sets the min threads for the thread pool attributes. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.  | ||||
|  *      minThreads - value to set | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrSetMinThreads(ThreadPoolAttr *attr, int minThreads); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the starvation time for the thread pool attributes. | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrSetIdleTime | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetStarvationTime( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! milliseconds. */ | ||||
| 	int starvationTime); | ||||
|  *  Description: | ||||
|  *      Sets the idle time for the thread pool attributes. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.     | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrSetIdleTime(ThreadPoolAttr *attr, int idleTime); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the scheduling policy for the thread pool attributes. | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrSetJobsPerThread | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetSchedPolicy( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! must be a valid policy type. */ | ||||
| 	PolicyType schedPolicy); | ||||
|  *  Description: | ||||
|  *      Sets the jobs per thread ratio | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes. | ||||
|  *      jobsPerThread - number of jobs per thread to maintain | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrSetJobsPerThread(ThreadPoolAttr *attr, int jobsPerThread); | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the maximum number jobs that can be qeued totally. | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrSetStarvationTime | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
| int TPAttrSetMaxJobsTotal( | ||||
| 	/*! must be valid thread pool attributes. */ | ||||
| 	ThreadPoolAttr *attr, | ||||
| 	/*! maximum number of jobs. */ | ||||
| 	int maxJobsTotal); | ||||
|  *  Description: | ||||
|  *      Sets the starvation time for the thread pool attributes. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.     | ||||
|  *      int starvationTime - milliseconds | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrSetStarvationTime(ThreadPoolAttr *attr, int starvationTime); | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns various statistics about the thread pool. | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrSetSchedPolicy | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Sets the scheduling policy for the thread pool attributes. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes.     | ||||
|  *      PolicyType schedPolicy - must be a valid policy type. | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrSetSchedPolicy(ThreadPoolAttr *attr, PolicyType schedPolicy); | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: TPAttrSetMaxJobsTotal | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Sets the maximum number jobs that can be qeued totally. | ||||
|  *  Parameters: | ||||
|  *      attr - must be valid thread pool attributes. | ||||
|  *      maxJobsTotal - maximum number of jobs | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int TPAttrSetMaxJobsTotal(ThreadPoolAttr *attr, int maxJobsTotal); | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ThreadPoolGetStats | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns various statistics about the | ||||
|  *      thread pool. | ||||
|  *      Only valid if STATS has been defined. | ||||
|  * | ||||
|  * \return Always returns 0. | ||||
|  */ | ||||
|  *  Parameters: | ||||
|  *      ThreadPool *tp - valid initialized threadpool     | ||||
|  *      ThreadPoolStats *stats - valid stats, out parameter | ||||
|  *  Returns: | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| #ifdef STATS | ||||
| 	EXPORT_SPEC int ThreadPoolGetStats( | ||||
| 		/*! Valid initialized threadpool. */ | ||||
| 		ThreadPool *tp, | ||||
| 		/*! Valid stats, out parameter. */ | ||||
| 		ThreadPoolStats *stats); | ||||
| #else | ||||
| 	static UPNP_INLINE int ThreadPoolGetStats( | ||||
| 		/*! Valid initialized threadpool. */ | ||||
| 		ThreadPool *tp, | ||||
| 		/*! Valid stats, out parameter. */ | ||||
| 		ThreadPoolStats *stats) {} | ||||
| #endif | ||||
| 	EXPORT int ThreadPoolGetStats(ThreadPool *tp, ThreadPoolStats *stats); | ||||
|  | ||||
| /*! | ||||
|  * \brief | ||||
|  */ | ||||
| #ifdef STATS | ||||
| 	EXPORT_SPEC void ThreadPoolPrintStats( | ||||
| 		/*! . */ | ||||
| 		ThreadPoolStats *stats); | ||||
| 	EXPORT void ThreadPoolPrintStats(ThreadPoolStats *stats); | ||||
| #else | ||||
| 	static UPNP_INLINE void ThreadPoolPrintStats( | ||||
| 		/*! . */ | ||||
| 		ThreadPoolStats *stats) {} | ||||
| 	static UPNP_INLINE int ThreadPoolGetStats(ThreadPool *tp, ThreadPoolStats *stats) {} | ||||
|  | ||||
| 	static UPNP_INLINE void ThreadPoolPrintStats(ThreadPoolStats *stats) {} | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* THREADPOOL_H */ | ||||
| #endif /* ThreadPool */ | ||||
|  | ||||
|   | ||||
| @@ -32,13 +32,9 @@ | ||||
| #ifndef TIMERTHREAD_H | ||||
| #define TIMERTHREAD_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #include "FreeList.h" | ||||
| #include "ithread.h" | ||||
| #include "LinkedList.h" | ||||
| #include "FreeList.h" | ||||
| #include "ThreadPool.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| @@ -47,23 +43,24 @@ extern "C" { | ||||
|  | ||||
| #define INVALID_EVENT_ID (-10 & 1<<29) | ||||
|  | ||||
| /*! Timeout Types. */ | ||||
| typedef enum timeoutType { | ||||
| 	/*! seconds from Jan 1, 1970. */ | ||||
| 	ABS_SEC, | ||||
| 	/*! seconds from current time. */ | ||||
| 	REL_SEC | ||||
| } TimeoutType; | ||||
| /* Timeout Types */ | ||||
| /* absolute means in seconds from Jan 1, 1970 */ | ||||
| /* relative means in seconds from current time */ | ||||
| typedef enum timeoutType {ABS_SEC,REL_SEC} TimeoutType; | ||||
|  | ||||
| /*! | ||||
|  * A timer thread similar to the one in the Upnp SDK that allows | ||||
|  * the scheduling of a job to run at a specified time in the future. | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Name: TimerThread | ||||
|  *  | ||||
|  *   Description: | ||||
|  *     A timer thread similar to the one in the Upnp SDK that allows | ||||
|  *     the scheduling of a job to run at a specified time in the future | ||||
|  *     Because the timer thread uses the thread pool there is no  | ||||
|  *     gurantee of timing, only approximate timing. | ||||
|  *     Uses ThreadPool, Mutex, Condition, Thread | ||||
|  *     | ||||
|  * Uses ThreadPool, Mutex, Condition, Thread. | ||||
|  */ | ||||
|  *  | ||||
|  *****************************************************************************/ | ||||
| typedef struct TIMERTHREAD | ||||
| { | ||||
|   ithread_mutex_t mutex; | ||||
| @@ -75,83 +72,117 @@ typedef struct TIMERTHREAD | ||||
|   ThreadPool *tp; | ||||
| } TimerThread; | ||||
|  | ||||
| /*! | ||||
|  * Struct to contain information for a timer event. | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Name: TimerEvent | ||||
|  *  | ||||
|  * Internal to the TimerThread. | ||||
|  */ | ||||
|  *   Description: | ||||
|  *      | ||||
|  *     Struct to contain information for a timer event. | ||||
|  *     Internal to the TimerThread | ||||
|  *    | ||||
|  *****************************************************************************/ | ||||
| typedef struct TIMEREVENT | ||||
| { | ||||
|   ThreadPoolJob job; | ||||
| 	/*! [in] Absolute time for event in seconds since Jan 1, 1970. */ | ||||
| 	time_t eventTime; | ||||
| 	/*! [in] Long term or short term job. */ | ||||
| 	Duration persistent; | ||||
|   time_t eventTime; /* absolute time for event in seconds since Jan 1, 1970 */ | ||||
|   Duration persistent;  /* long term or short term job */ | ||||
|   int id; | ||||
| } TimerEvent; | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes and starts timer thread. | ||||
|  | ||||
|  | ||||
|  | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadInit | ||||
|  *  | ||||
|  * \return 0 on success, nonzero on failure. Returns error from | ||||
|  * 	ThreadPoolAddPersistent on failure. | ||||
|  */ | ||||
| int TimerThreadInit( | ||||
| 	/*! [in] Valid timer thread pointer. */ | ||||
| 	TimerThread *timer, | ||||
| 	/*! [in] Valid thread pool to use. Must be started. Must be valid for | ||||
| 	 * lifetime of timer. Timer must be shutdown BEFORE thread pool. */ | ||||
|  *  Description: | ||||
|  *     Initializes and starts timer thread. | ||||
|  * | ||||
|  *  Parameters: | ||||
|  *             timer - valid timer thread pointer. | ||||
|  *             tp  - valid thread pool to use. Must be | ||||
|  *                   started. Must be valid for lifetime | ||||
|  *                   of timer.  Timer must be shutdown | ||||
|  *                   BEFORE thread pool. | ||||
|  *  Return: | ||||
|  *            0 on success, nonzero on failure | ||||
|  *            Returns error from ThreadPoolAddPersistent on failure. | ||||
|  * | ||||
|  ************************************************************************/ | ||||
| int TimerThreadInit(TimerThread *timer, | ||||
| 		    ThreadPool *tp); | ||||
|  | ||||
| /*! | ||||
|  * \brief Schedules an event to run at a specified time. | ||||
|  | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadSchedule | ||||
|  *  | ||||
|  * \return 0 on success, nonzero on failure, EOUTOFMEM if not enough memory | ||||
|  * 	to schedule job. | ||||
|  */ | ||||
| int TimerThreadSchedule( | ||||
| 	/*! [in] Valid timer thread pointer. */ | ||||
| 	TimerThread* timer, | ||||
| 	/*! [in] time of event. Either in absolute seconds, or relative | ||||
| 	 * seconds in the future. */ | ||||
|  *  Description: | ||||
|  *     Schedules an event to run at a specified time. | ||||
|  * | ||||
|  *  Parameters: | ||||
|  *             timer - valid timer thread pointer. | ||||
|  *             time_t - time of event. | ||||
|  *                      either in absolute seconds, | ||||
|  *                      or relative seconds in the future. | ||||
|  *             timeoutType - either ABS_SEC, or REL_SEC. | ||||
|  *                           if REL_SEC, then the event | ||||
|  *                           will be scheduled at the | ||||
|  *                           current time + REL_SEC. | ||||
|  *             job-> valid Thread pool job with following fields | ||||
|  *             func - function to schedule | ||||
|  *             arg - argument to function | ||||
|  *             priority - priority of job. | ||||
|  *          | ||||
|  *             id - id of timer event. (out, can be null) | ||||
|  *  Return: | ||||
|  *            0 on success, nonzero on failure | ||||
|  *            EOUTOFMEM if not enough memory to schedule job. | ||||
|  * | ||||
|  ************************************************************************/ | ||||
| int TimerThreadSchedule(TimerThread* timer, | ||||
| 			time_t time,  | ||||
| 	/*! [in] either ABS_SEC, or REL_SEC. If REL_SEC, then the event | ||||
| 	 * will be scheduled at the current time + REL_SEC. */ | ||||
| 			TimeoutType type, | ||||
| 	/*! [in] Valid Thread pool job with following fields. */ | ||||
| 			ThreadPoolJob *job, | ||||
| 	/*! [in] . */ | ||||
| 			Duration duration, | ||||
| 	/*! [in] Id of timer event. (out, can be null). */ | ||||
| 			int *id); | ||||
|  | ||||
| /*! | ||||
|  * \brief Removes an event from the timer Q. | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadRemove | ||||
|  *  | ||||
|  * Events can only be removed before they have been placed in the thread pool. | ||||
|  *  Description: | ||||
|  *     Removes an event from the timer Q. | ||||
|  *     Events can only be removed  | ||||
|  *     before they have been placed in the | ||||
|  *     thread pool. | ||||
|  * | ||||
|  * \return 0 on success, INVALID_EVENT_ID on failure. | ||||
|  */ | ||||
| int TimerThreadRemove( | ||||
| 	/*! [in] Valid timer thread pointer. */ | ||||
| 	TimerThread *timer, | ||||
| 	/*! [in] Id of event to remove. */ | ||||
|  *  Parameters: | ||||
|  *             timer - valid timer thread pointer. | ||||
|  *             id - id of event to remove. | ||||
|  *             ThreadPoolJob *out - space for thread pool job. | ||||
|  *  Return: | ||||
|  *            0 on success,  | ||||
|  *            INVALID_EVENT_ID on failure | ||||
|  *			  | ||||
|  ************************************************************************/ | ||||
| int TimerThreadRemove(TimerThread *timer, | ||||
| 			   int id, | ||||
| 	/*! [in] Space for thread pool job. */ | ||||
| 			   ThreadPoolJob *out); | ||||
|  | ||||
| /*! | ||||
|  * \brief Shutdown the timer thread. | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadShutdown | ||||
|  *  | ||||
|  *  Description: | ||||
|  *    Shutdown the timer thread | ||||
|  *    Events scheduled in the future will NOT be run. | ||||
|  * | ||||
|  * Timer thread should be shutdown BEFORE it's associated thread pool. | ||||
|  * | ||||
|  * \return 0 if succesfull, nonzero otherwise. Always returns 0. | ||||
|  */ | ||||
| int TimerThreadShutdown( | ||||
| 	/*! [in] Valid timer thread pointer. */ | ||||
| 	TimerThread *timer); | ||||
|  *    Timer thread should be shutdown BEFORE it's associated | ||||
|  *    thread pool. | ||||
|  *  Returns: | ||||
|  *    returns 0 if succesfull, | ||||
|  *            nonzero otherwise. | ||||
|  *            Always returns 0. | ||||
|  ***********************************************************************/    | ||||
| int TimerThreadShutdown(TimerThread *timer); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
|   | ||||
| @@ -29,43 +29,23 @@ | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef ITHREAD_H | ||||
| #define ITHREAD_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #if !defined(WIN32) | ||||
| 	#include <sys/param.h> | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #include "UpnpGlobal.h" /* For UPNP_INLINE, EXPORT_SPEC */ | ||||
|  | ||||
|  | ||||
| #ifndef ITHREADH | ||||
| #define ITHREADH | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #include <pthread.h> | ||||
| #ifdef WIN32 | ||||
| 	/* Do not #include <unistd.h> */ | ||||
| #else | ||||
| #ifndef WIN32 | ||||
| 	#include <unistd.h> | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if defined(BSD) | ||||
| #ifdef __FreeBSD__ | ||||
| 	#define PTHREAD_MUTEX_RECURSIVE_NP PTHREAD_MUTEX_RECURSIVE | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if defined(PTHREAD_MUTEX_RECURSIVE) || defined(__DragonFly__) | ||||
| #ifdef PTHREAD_MUTEX_RECURSIVE | ||||
| 	/* This system has SuS2-compliant mutex attributes. | ||||
| 	 * E.g. on Cygwin, where we don't have the old nonportable (NP) symbols | ||||
| 	 */ | ||||
| @@ -86,9 +66,6 @@ extern "C" { | ||||
| #define ITHREAD_CANCELED PTHREAD_CANCELED | ||||
|  | ||||
|    | ||||
| #define ITHREAD_STACK_MIN PTHREAD_STACK_MIN | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Name: ithread_t | ||||
|  * | ||||
| @@ -99,7 +76,6 @@ extern "C" { | ||||
|  ***************************************************************************/ | ||||
| typedef pthread_t ithread_t;  | ||||
|    | ||||
|    | ||||
| /**************************************************************************** | ||||
|  * Name: ithread_attr_t | ||||
|  * | ||||
| @@ -174,9 +150,7 @@ typedef pthread_condattr_t ithread_condattr_t; | ||||
|  *      typedef to pthread_rwlockattr_t | ||||
|  *      Internal Use Only | ||||
|  ***************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| typedef pthread_rwlockattr_t ithread_rwlockattr_t;	 | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
| @@ -187,101 +161,7 @@ typedef pthread_rwlockattr_t ithread_rwlockattr_t; | ||||
|  *      typedef to pthread_rwlock_t | ||||
|  *      Internal Use Only | ||||
|  ***************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| typedef pthread_rwlock_t ithread_rwlock_t;	 | ||||
| #else | ||||
| 	/* Read-write locks aren't available: use mutex instead. */ | ||||
| 	typedef ithread_mutex_t ithread_rwlock_t; | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_initialize_library | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Initializes the library. Does nothing in all implementations, except | ||||
|  *      when statically linked for WIN32. | ||||
|  *  Parameters: | ||||
|  *      none. | ||||
|  *  Returns: | ||||
|  *      0 on success, Nonzero on failure. | ||||
|  ***************************************************************************/ | ||||
| static UPNP_INLINE int ithread_initialize_library(void) { | ||||
| 	int ret = 0; | ||||
|  | ||||
| #if defined(WIN32) && defined(PTW32_STATIC_LIB) | ||||
| 	ret = !pthread_win32_process_attach_np(); | ||||
| #endif | ||||
|  | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_cleanup_library | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Clean up library resources. Does nothing in all implementations, except | ||||
|  *      when statically linked for WIN32. | ||||
|  *  Parameters: | ||||
|  *      none. | ||||
|  *  Returns: | ||||
|  *      0 on success, Nonzero on failure. | ||||
|  ***************************************************************************/ | ||||
| static UPNP_INLINE int ithread_cleanup_library(void) { | ||||
| 	int ret = 0; | ||||
|  | ||||
| #if defined(WIN32) && defined(PTW32_STATIC_LIB) | ||||
| 	ret = !pthread_win32_process_detach_np(); | ||||
| #endif | ||||
|  | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_initialize_thread | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Initializes the thread. Does nothing in all implementations, except | ||||
|  *      when statically linked for WIN32. | ||||
|  *  Parameters: | ||||
|  *      none. | ||||
|  *  Returns: | ||||
|  *      0 on success, Nonzero on failure. | ||||
|  ***************************************************************************/ | ||||
| static UPNP_INLINE int ithread_initialize_thread(void) { | ||||
| 	int ret = 0; | ||||
|  | ||||
| #if defined(WIN32) && defined(PTW32_STATIC_LIB) | ||||
| 	ret = !pthread_win32_thread_attach_np(); | ||||
| #endif | ||||
|  | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_cleanup_thread | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Clean up thread resources. Does nothing in all implementations, except | ||||
|  *      when statically linked for WIN32. | ||||
|  *  Parameters: | ||||
|  *      none. | ||||
|  *  Returns: | ||||
|  *      0 on success, Nonzero on failure. | ||||
|  ***************************************************************************/ | ||||
| static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
| 	int ret = 0; | ||||
|  | ||||
| #if defined(WIN32) && defined(PTW32_STATIC_LIB) | ||||
| 	ret = !pthread_win32_thread_detach_np(); | ||||
| #endif | ||||
|  | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_mutexattr_init | ||||
| @@ -336,11 +216,11 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Returns EINVAL if the kind is not supported. | ||||
|  *      See man page for pthread_mutexattr_setkind_np | ||||
|  *****************************************************************************/ | ||||
| #if defined(PTHREAD_MUTEX_RECURSIVE) || defined(__DragonFly__) | ||||
| #ifdef PTHREAD_MUTEX_RECURSIVE | ||||
| 	#define ithread_mutexattr_setkind_np pthread_mutexattr_settype | ||||
| #else | ||||
| 	#define ithread_mutexattr_setkind_np pthread_mutexattr_setkind_np | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
| #endif | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_mutexattr_getkind_np | ||||
| @@ -361,11 +241,11 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_mutexattr_getkind_np | ||||
|  *****************************************************************************/ | ||||
| #if defined(PTHREAD_MUTEX_RECURSIVE) || defined(__DragonFly__) | ||||
| #ifdef PTHREAD_MUTEX_RECURSIVE | ||||
| 	#define ithread_mutexattr_getkind_np pthread_mutexattr_gettype | ||||
| #else | ||||
| 	#define ithread_mutexattr_getkind_np pthread_mutexattr_getkind_np | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
| #endif | ||||
|  | ||||
|    | ||||
| /**************************************************************************** | ||||
| @@ -453,9 +333,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlockattr_init | ||||
|  ***************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlockattr_init pthread_rwlockattr_init | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
| @@ -471,9 +349,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlockattr_destroy | ||||
|  ***************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlockattr_destroy pthread_rwlockattr_destroy | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|    | ||||
|    | ||||
| /**************************************************************************** | ||||
| @@ -494,9 +370,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Returns EINVAL if the kind is not supported. | ||||
|  *      See man page for pthread_rwlockattr_setkind_np | ||||
|  *****************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlockatttr_setpshared pthread_rwlockatttr_setpshared | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
| @@ -517,9 +391,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlockatttr_getpshared | ||||
|  *****************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlockatttr_getpshared pthread_rwlockatttr_getpshared | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|    | ||||
| /**************************************************************************** | ||||
| @@ -537,12 +409,8 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlock_init | ||||
|  *****************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlock_init pthread_rwlock_init | ||||
| #else | ||||
| 	/* Read-write locks aren't available: use mutex instead. */ | ||||
| 	#define ithread_rwlock_init ithread_mutex_init | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_rwlock_rdlock | ||||
| @@ -558,12 +426,8 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlock_rdlock | ||||
|  *****************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlock_rdlock pthread_rwlock_rdlock | ||||
| #else | ||||
| 	/* Read-write locks aren't available: use mutex instead. */ | ||||
| 	#define ithread_rwlock_rdlock ithread_mutex_lock | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_rwlock_wrlock | ||||
| @@ -579,12 +443,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlock_wrlock | ||||
|  *****************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlock_wrlock pthread_rwlock_wrlock | ||||
| #else | ||||
| 	/* Read-write locks aren't available: use mutex instead. */ | ||||
| 	#define ithread_rwlock_wrlock ithread_mutex_lock | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
| @@ -602,12 +461,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlock_unlock | ||||
|  *****************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlock_unlock pthread_rwlock_unlock | ||||
| #else | ||||
| 	/* Read-write locks aren't available: use mutex instead. */ | ||||
| 	#define ithread_rwlock_unlock ithread_mutex_unlock | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
| @@ -626,12 +480,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *      Always returns 0. | ||||
|  *      See man page for pthread_rwlock_destroy | ||||
|  *****************************************************************************/ | ||||
| #if UPNP_USE_RWLOCK | ||||
| #define ithread_rwlock_destroy pthread_rwlock_destroy | ||||
| #else | ||||
| 	/* Read-write locks aren't available: use mutex instead. */ | ||||
| 	#define ithread_rwlock_destroy ithread_mutex_destroy | ||||
| #endif /* UPNP_USE_RWLOCK */ | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
| @@ -650,6 +499,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
| #define ithread_cond_init pthread_cond_init | ||||
|  | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: ithread_cond_signal | ||||
|  * | ||||
| @@ -709,18 +559,22 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|    * Function: pthread_cond_timedwait | ||||
|    * | ||||
|    *  Description:       | ||||
|    *		Atomically releases the associated mutex and waits on the | ||||
|    *	condition. | ||||
|    *		If the condition is not signaled in the specified time than the | ||||
|    *      Atomically releases the associated mutex and waits on the condition.  | ||||
|    *		If the condition is not signaled in the specified time  | ||||
|    *              than the  | ||||
|    *		call times out and returns. | ||||
|    *		Associated mutex MUST be locked by thread before entering this call. | ||||
|    *		Associated mutex MUST be locked by thread before entering  | ||||
|    *              this call. | ||||
|    *      Mutex is reacquired when call returns. | ||||
|    *  Parameters: | ||||
|    *      ithread_cond_t *cond (must be valid non NULL pointer to ithread_cond_t) | ||||
|    *      ithread_cond_t * cond (must be valid non NULL pointer to  | ||||
|    *      ithread_cond_t) | ||||
|    *      cond must be initialized | ||||
|    *      ithread_mutex_t *mutex (must be valid non NULL pointer to ithread_mutex_t) | ||||
|    *      ithread_mutex_t *mutex (must be valid non NULL pointer to  | ||||
|    *      ithread_mutex_t) | ||||
|    *      Mutex must be locked. | ||||
|    *      const struct timespec *abstime (absolute time, measured from Jan 1, 1970) | ||||
|    *      const struct timespec *abstime (absolute time, measured  | ||||
|    *      from Jan 1, 1970) | ||||
|    *  Returns: | ||||
|    *      0 on success. ETIMEDOUT on timeout. Nonzero on failure. | ||||
|    *      See man page for pthread_cond_timedwait | ||||
| @@ -745,49 +599,6 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|    ***************************************************************************/ | ||||
| #define ithread_cond_destroy pthread_cond_destroy | ||||
|  | ||||
|   /**************************************************************************** | ||||
|    * Function: ithread_attr_init | ||||
|    * | ||||
|    *  Description: | ||||
|    *      Initialises thread attribute object. | ||||
|    *  Parameters: | ||||
|    *      ithread_attr_t *attr (must be valid non NULL pointer to | ||||
|    *      ithread_attr_t) | ||||
|    *  Returns: | ||||
|    *      0 on success. Nonzero on failure. | ||||
|    *      See man page for pthread_attr_init | ||||
|    ***************************************************************************/ | ||||
| #define ithread_attr_init pthread_attr_init | ||||
|  | ||||
|   /**************************************************************************** | ||||
|    * Function: ithread_attr_destroy | ||||
|    * | ||||
|    *  Description: | ||||
|    *      Destroys thread attribute object. | ||||
|    *  Parameters: | ||||
|    *      ithread_attr_t *attr (must be valid non NULL pointer to | ||||
|    *      ithread_attr_t) | ||||
|    *  Returns: | ||||
|    *      0 on success. Nonzero on failure. | ||||
|    *      See man page for pthread_attr_destroy | ||||
|    ***************************************************************************/ | ||||
| #define ithread_attr_destroy pthread_attr_destroy | ||||
|  | ||||
|   /**************************************************************************** | ||||
|    * Function: ithread_attr_setstacksize | ||||
|    * | ||||
|    *  Description: | ||||
|    *      Sets stack size of a thread attribute object. | ||||
|    *  Parameters: | ||||
|    *      ithread_attr_t *attr (must be valid non NULL pointer to | ||||
|    *      ithread_attr_t) | ||||
|    *      size_t stacksize (value of stacksize must be greater than | ||||
|    *      ITHREAD_STACK_MIN and lower than system-imposed limits | ||||
|    *  Returns: | ||||
|    *      0 on success. Nonzero on failure. | ||||
|    *      See man page for pthread_attr_setstacksize | ||||
|    ***************************************************************************/ | ||||
| #define ithread_attr_setstacksize pthread_attr_setstacksize | ||||
|  | ||||
|   /**************************************************************************** | ||||
|    * Function: ithread_create | ||||
| @@ -797,7 +608,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|    *      and argument. | ||||
|    *  Parameters: | ||||
|    *      ithread_t * thread (must be valid non NULL pointer to pthread_t) | ||||
|    *      ithread_attr_t *attr | ||||
|    *      ithread_attr_t *attr, IGNORED | ||||
|    *      void * (start_routine) (void *arg) (start routine) | ||||
|    *      void * arg - argument. | ||||
|    *  Returns: | ||||
| @@ -835,7 +646,6 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|    ***************************************************************************/ | ||||
| #define ithread_exit pthread_exit | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|    * Function: ithread_get_current_thread_id | ||||
|    * | ||||
| @@ -859,7 +669,6 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|    ***************************************************************************/ | ||||
| #define ithread_self pthread_self | ||||
|  | ||||
|  | ||||
|   /**************************************************************************** | ||||
|    * Function: ithread_detach | ||||
|    * | ||||
| @@ -873,7 +682,6 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|    ***************************************************************************/ | ||||
| #define ithread_detach pthread_detach   | ||||
|  | ||||
|  | ||||
|   /**************************************************************************** | ||||
|    * Function: ithread_join | ||||
|    * | ||||
| @@ -893,6 +701,7 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
| #define ithread_join pthread_join | ||||
|    | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: isleep | ||||
|  * | ||||
| @@ -906,13 +715,12 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *		0 on success, Nonzero on failure. | ||||
|  *              See man page for sleep (man 3 sleep) | ||||
|  *****************************************************************************/ | ||||
| #ifdef WIN32 | ||||
| 	#define isleep(x) Sleep((x)*1000) | ||||
| #else | ||||
| #ifndef WIN32 | ||||
| #define isleep sleep | ||||
| #else | ||||
| #define isleep(x) Sleep((x)*1000) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /**************************************************************************** | ||||
|  * Function: isleep | ||||
|  * | ||||
| @@ -926,23 +734,36 @@ static UPNP_INLINE int ithread_cleanup_thread(void) { | ||||
|  *		0 on success, Nonzero on failure. | ||||
|  *              See man page for sleep (man 3 sleep) | ||||
|  *****************************************************************************/ | ||||
| #ifdef WIN32 | ||||
| 	#define imillisleep Sleep | ||||
| #else | ||||
| #ifndef WIN32 | ||||
| #define imillisleep(x) usleep(1000*x) | ||||
| #else | ||||
| #define imillisleep	Sleep | ||||
| #endif | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	#ifndef UPNP_STATIC_LIB | ||||
| 		#ifdef LIBUPNP_EXPORTS | ||||
| 			/* set up declspec for dll export to make functions visible to library users */ | ||||
| 			#define EXPORT_SPEC __declspec(dllexport) | ||||
| 		#else | ||||
| 			#define EXPORT_SPEC __declspec(dllimport) | ||||
| 		#endif | ||||
| 	#else | ||||
| 		#define EXPORT_SPEC | ||||
| 	#endif | ||||
| #else | ||||
| 	#define EXPORT_SPEC | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if !defined(PTHREAD_MUTEX_RECURSIVE) && !defined(__DragonFly__) | ||||
| #ifndef PTHREAD_MUTEX_RECURSIVE | ||||
| /* NK: Added for satisfying the gcc compiler */ | ||||
| EXPORT_SPEC int pthread_mutexattr_setkind_np(pthread_mutexattr_t *attr, int kind); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #endif /* ITHREAD_H */ | ||||
| #endif /* ITHREADH */ | ||||
|  | ||||
|   | ||||
| @@ -1,54 +1,85 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "FreeList.h" | ||||
|  | ||||
| #include <assert.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| int FreeListInit(FreeList *free_list, size_t elementSize, int maxFreeListLength) | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListInit | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Initializes Free List. Must be called first. | ||||
|  *      And only once for FreeList. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a linked list. | ||||
|  *      size_t -     size of elements to store in free list | ||||
|  *      maxFreeListSize - max size that the free list can grow to | ||||
|  *                        before returning memory to O.S. | ||||
|  *  Returns: | ||||
|  *      0 on success. Nonzero on failure. | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int | ||||
| FreeListInit( FreeList * free_list, | ||||
|               size_t elementSize, | ||||
|               int maxFreeListLength ) | ||||
| { | ||||
|     assert( free_list != NULL ); | ||||
|  | ||||
|     if( free_list == NULL ) | ||||
|         return EINVAL; | ||||
|  | ||||
|     free_list->element_size = elementSize; | ||||
|     free_list->maxFreeListLength = maxFreeListLength; | ||||
|     free_list->head = NULL; | ||||
|     free_list->freeListLength = 0; | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| void *FreeListAlloc(FreeList *free_list) | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListAlloc | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Allocates chunk of set size. | ||||
|  *      If a free item is available in the list, returnes the stored item. | ||||
|  *      Otherwise calls the O.S. to allocate memory. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a linked list. | ||||
|  *  Returns: | ||||
|  *      Non NULL on success. NULL on failure. | ||||
|  *****************************************************************************/ | ||||
| void * | ||||
| FreeListAlloc( FreeList * free_list ) | ||||
| { | ||||
|     FreeListNode *ret = NULL; | ||||
|  | ||||
| @@ -68,44 +99,79 @@ void *FreeListAlloc(FreeList *free_list) | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| int FreeListFree(FreeList *free_list, void *element) | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListFree | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns an item to the Free List. | ||||
|  *      If the free list is smaller than the max size than | ||||
|  *      adds the item to the free list. | ||||
|  *      Otherwise returns the item to the O.S. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a free list. | ||||
|  *      element - must be a pointer allocated by FreeListAlloc | ||||
|  *  Returns: | ||||
|  *      0 on success. Nonzero on failure. | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int | ||||
| FreeListFree( FreeList * free_list, | ||||
|               void *element ) | ||||
| { | ||||
|  | ||||
|     FreeListNode *temp = NULL; | ||||
|  | ||||
|     assert( free_list != NULL ); | ||||
|  | ||||
|     if( free_list == NULL ) | ||||
|         return EINVAL; | ||||
| 	if (element != NULL && | ||||
| 	    free_list->freeListLength + 1 < free_list->maxFreeListLength) { | ||||
|  | ||||
|     if( ( element != NULL ) && | ||||
|         ( ( free_list->freeListLength + 1 ) < | ||||
|           free_list->maxFreeListLength ) ) { | ||||
|         free_list->freeListLength++; | ||||
|         temp = ( FreeListNode * ) element; | ||||
|         temp->next = free_list->head; | ||||
|         free_list->head = temp; | ||||
|  | ||||
|     } else { | ||||
|  | ||||
|         free( element ); | ||||
|     } | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| int FreeListDestroy(FreeList *free_list) | ||||
| /**************************************************************************** | ||||
|  * Function: FreeListDestroy | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Releases the resources stored with the free list. | ||||
|  *  Parameters: | ||||
|  *      free_list  - must be valid, non null, pointer to a linked list. | ||||
|  *  Returns: | ||||
|  *      0 on success. Nonzero on failure. | ||||
|  *      Always returns 0. | ||||
|  *****************************************************************************/ | ||||
| int | ||||
| FreeListDestroy( FreeList * free_list ) | ||||
| { | ||||
|     FreeListNode *temp = NULL; | ||||
|     int i = 0; | ||||
|  | ||||
|     assert( free_list != NULL ); | ||||
|  | ||||
| 	if (!free_list) | ||||
|     if( free_list == NULL ) | ||||
|         return EINVAL; | ||||
|  | ||||
|     while( free_list->head ) { | ||||
|         i++; | ||||
|         temp = free_list->head->next; | ||||
|         free( free_list->head ); | ||||
|         free_list->head = temp; | ||||
|     } | ||||
|  | ||||
|     free_list->freeListLength = 0; | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,71 +1,70 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "LinkedList.h" | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	/* Do not #include <sys/param.h> */ | ||||
| #else | ||||
| #ifndef WIN32 | ||||
| 	#include <sys/param.h> | ||||
| #endif | ||||
|  | ||||
| #if (defined(BSD) && BSD >= 199306) || defined(__OSX__) || defined(__APPLE__) | ||||
| 	#include <stdlib.h> | ||||
| #else | ||||
| 	#include <malloc.h> | ||||
| #endif | ||||
|  | ||||
| #include <assert.h> | ||||
|  | ||||
| static int freeListNode(ListNode *node, LinkedList *list) | ||||
| static int | ||||
| freeListNode( ListNode * node, | ||||
|               LinkedList * list ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|  | ||||
|     return FreeListFree( &list->freeNodeList, node ); | ||||
| } | ||||
|  | ||||
| /*! | ||||
|  * \brief Dynamically creates a list node. | ||||
| /**************************************************************************** | ||||
|  * Function: CreateListNode | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Creates a list node. Dynamically. | ||||
|  *       | ||||
|  *  Parameters: | ||||
|  *      void * item - the item to store | ||||
|  *  Returns: | ||||
|  *      The new node, NULL on failure. | ||||
|  */ | ||||
| static ListNode *CreateListNode( | ||||
| 	/*! the item to store. */ | ||||
| 	void *item, | ||||
| 	/*! The list to add it to. */ | ||||
|  *****************************************************************************/ | ||||
| static ListNode * | ||||
| CreateListNode( void *item, | ||||
|                 LinkedList * list ) | ||||
| { | ||||
|  | ||||
|     ListNode *temp = NULL; | ||||
|  | ||||
|     assert( list != NULL ); | ||||
| @@ -76,28 +75,49 @@ static ListNode *CreateListNode( | ||||
|         temp->next = NULL; | ||||
|         temp->item = item; | ||||
|     } | ||||
|  | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| int ListInit(LinkedList *list, cmp_routine cmp_func, free_function free_func) | ||||
| /**************************************************************************** | ||||
|  * Function: ListInit | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Initializes LinkedList. Must be called first. | ||||
|  *      And only once for List. | ||||
|  *  Parameters: | ||||
|  *      list  - must be valid, non null, pointer to a linked list. | ||||
|  *      cmp_func - function used to compare items. (May be NULL) | ||||
|  *      free_func - function used to free items. (May be NULL) | ||||
|  *  Returns: | ||||
|  *      0 on success, EOUTOFMEM on failure. | ||||
|  *****************************************************************************/ | ||||
| int | ||||
| ListInit( LinkedList * list, | ||||
|           cmp_routine cmp_func, | ||||
|           free_function free_func ) | ||||
| { | ||||
|  | ||||
|     int retCode = 0; | ||||
|  | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| 	if (!list) | ||||
|     if( list == NULL ) | ||||
|         return EINVAL; | ||||
|  | ||||
|     list->size = 0; | ||||
|     list->cmp_func = cmp_func; | ||||
|     list->free_func = free_func; | ||||
| 	retCode = FreeListInit(&list->freeNodeList, sizeof(ListNode), FREELISTSIZE); | ||||
|  | ||||
|     retCode = | ||||
|         FreeListInit( &list->freeNodeList, sizeof( ListNode ), | ||||
|                       FREELISTSIZE ); | ||||
|  | ||||
|     assert( retCode == 0 ); | ||||
|  | ||||
|     list->head.item = NULL; | ||||
|     list->head.next = &list->tail; | ||||
|     list->head.prev = NULL; | ||||
|  | ||||
|     list->tail.item = NULL; | ||||
|     list->tail.prev = &list->head; | ||||
|     list->tail.next = NULL; | ||||
| @@ -105,7 +125,23 @@ int ListInit(LinkedList *list, cmp_routine cmp_func, free_function free_func) | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| ListNode *ListAddHead(LinkedList *list, void *item) | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddHead | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Adds a node to the head of the list. | ||||
|  *      Node gets immediately after list.head. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      void * item - item to be added | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListAddHead( LinkedList * list, | ||||
|              void *item ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| @@ -115,24 +151,59 @@ ListNode *ListAddHead(LinkedList *list, void *item) | ||||
|     return ListAddAfter( list, item, &list->head ); | ||||
| } | ||||
|  | ||||
| ListNode *ListAddTail(LinkedList *list, void *item) | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddTail | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Adds a node to the tail of the list. | ||||
|  *      Node gets added immediately before list.tail. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      void * item - item to be added | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListAddTail( LinkedList * list, | ||||
|              void *item ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| 	if (!list) | ||||
|     if( list == NULL ) | ||||
|         return NULL; | ||||
|  | ||||
|     return ListAddBefore( list, item, &list->tail ); | ||||
| } | ||||
|  | ||||
| ListNode *ListAddAfter(LinkedList *list, void *item, ListNode *bnode) | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddAfter | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Adds a node after the specified node. | ||||
|  *      Node gets added immediately after bnode. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      void * item - item to be added | ||||
|  *      ListNode * bnode - node to add after | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListAddAfter( LinkedList * list, | ||||
|               void *item, | ||||
|               ListNode * bnode ) | ||||
| { | ||||
|     ListNode *newNode = NULL; | ||||
|  | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| 	if (!list || !bnode) | ||||
|     if( ( list == NULL ) || ( bnode == NULL ) ) | ||||
|         return NULL; | ||||
|  | ||||
|     newNode = CreateListNode( item, list ); | ||||
|     if( newNode ) { | ||||
|         ListNode *temp = bnode->next; | ||||
| @@ -142,22 +213,40 @@ ListNode *ListAddAfter(LinkedList *list, void *item, ListNode *bnode) | ||||
|         newNode->next = temp; | ||||
|         temp->prev = newNode; | ||||
|         list->size++; | ||||
|  | ||||
|         return newNode; | ||||
|     } | ||||
|  | ||||
|     return NULL; | ||||
| } | ||||
|  | ||||
| ListNode *ListAddBefore(LinkedList *list, void *item, ListNode *anode) | ||||
| /**************************************************************************** | ||||
|  * Function: ListAddBefore | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Adds a node before the specified node. | ||||
|  *      Node gets added immediately before anode. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      ListNode * anode  - node to add the in front of. | ||||
|  *      void * item - item to be added | ||||
|  *  Returns: | ||||
|  *      The pointer to the ListNode on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListAddBefore( LinkedList * list, | ||||
|                void *item, | ||||
|                ListNode * anode ) | ||||
| { | ||||
|     ListNode *newNode = NULL; | ||||
|  | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| 	if (!list || !anode) | ||||
|     if( ( list == NULL ) || ( anode == NULL ) ) | ||||
|         return NULL; | ||||
|  | ||||
|     newNode = CreateListNode( item, list ); | ||||
|  | ||||
|     if( newNode ) { | ||||
|         ListNode *temp = anode->prev; | ||||
|  | ||||
| @@ -166,14 +255,30 @@ ListNode *ListAddBefore(LinkedList *list, void *item, ListNode *anode) | ||||
|         newNode->prev = temp; | ||||
|         temp->next = newNode; | ||||
|         list->size++; | ||||
|  | ||||
|         return newNode; | ||||
|     } | ||||
|  | ||||
|     return NULL; | ||||
| } | ||||
|  | ||||
| void *ListDelNode(LinkedList *list, ListNode *dnode, int freeItem) | ||||
| /**************************************************************************** | ||||
|  * Function: ListDelNode | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Removes a node from the list | ||||
|  *      The memory for the node is freed but the | ||||
|  *      the memory for the items are not. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      ListNode *dnode - done to delete. | ||||
|  *  Returns: | ||||
|  *      The pointer to the item stored in node on success, NULL on failure. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| void * | ||||
| ListDelNode( LinkedList * list, | ||||
|              ListNode * dnode, | ||||
|              int freeItem ) | ||||
| { | ||||
|     void *temp; | ||||
|  | ||||
| @@ -181,13 +286,19 @@ void *ListDelNode(LinkedList *list, ListNode *dnode, int freeItem) | ||||
|     assert( dnode != &list->head ); | ||||
|     assert( dnode != &list->tail ); | ||||
|  | ||||
| 	if (!list || dnode == &list->head || dnode == &list->tail || !dnode) | ||||
|     if( ( list == NULL ) || | ||||
|         ( dnode == &list->head ) || | ||||
|         ( dnode == &list->tail ) || ( dnode == NULL ) ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     temp = dnode->item; | ||||
|     dnode->prev->next = dnode->next; | ||||
|     dnode->next->prev = dnode->prev; | ||||
|  | ||||
|     freeListNode( dnode, list ); | ||||
|     list->size--; | ||||
|  | ||||
|     if( freeItem && list->free_func ) { | ||||
|         list->free_func( temp ); | ||||
|         temp = NULL; | ||||
| @@ -196,12 +307,29 @@ void *ListDelNode(LinkedList *list, ListNode *dnode, int freeItem) | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| int ListDestroy(LinkedList *list, int freeItem) | ||||
| /**************************************************************************** | ||||
|  * Function: ListDestroy | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Removes all memory associated with list nodes.  | ||||
|  *      Does not free LinkedList *list.  | ||||
|  *      Items stored in the list are not freed, only nodes are. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *  Returns: | ||||
|  *      0 on success. Nonzero on failure. | ||||
|  *      Always returns 0. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| int | ||||
| ListDestroy( LinkedList * list, | ||||
|              int freeItem ) | ||||
| { | ||||
|     ListNode *dnode = NULL; | ||||
|     ListNode *temp = NULL; | ||||
|  | ||||
| 	if(!list) | ||||
|     if( list == NULL ) | ||||
|         return EINVAL; | ||||
|  | ||||
|     for( dnode = list->head.next; dnode != &list->tail; ) { | ||||
| @@ -209,57 +337,120 @@ int ListDestroy(LinkedList *list, int freeItem) | ||||
|         ListDelNode( list, dnode, freeItem ); | ||||
|         dnode = temp; | ||||
|     } | ||||
|  | ||||
|     list->size = 0; | ||||
|     FreeListDestroy( &list->freeNodeList ); | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| ListNode *ListHead(LinkedList *list) | ||||
| /**************************************************************************** | ||||
|  * Function: ListHead | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns the head of the list. | ||||
|  *     | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The head of the list. NULL if list is empty. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListHead( LinkedList * list ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| 	if (!list) | ||||
|     if( list == NULL ) | ||||
|         return NULL; | ||||
|  | ||||
| 	if (!list->size) | ||||
|     if( list->size == 0 ) | ||||
|         return NULL; | ||||
|     else | ||||
|         return list->head.next; | ||||
| } | ||||
|  | ||||
| ListNode *ListTail(LinkedList *list) | ||||
| /**************************************************************************** | ||||
|  * Function: ListTail | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns the tail of the list. | ||||
|  *     | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The tail of the list. NULL if list is empty. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListTail( LinkedList * list ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| 	if (!list) | ||||
|     if( list == NULL ) | ||||
|         return NULL; | ||||
|  | ||||
| 	if (!list->size) | ||||
|     if( list->size == 0 ) | ||||
|         return NULL; | ||||
|     else | ||||
|         return list->tail.prev; | ||||
| } | ||||
|  | ||||
| ListNode *ListNext(LinkedList *list, ListNode *node) | ||||
| /**************************************************************************** | ||||
|  * Function: ListNext | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns the next item in the list. | ||||
|  *     | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The next item in the list. NULL if there are no more items in list. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListNext( LinkedList * list, | ||||
|           ListNode * node ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|     assert( node != NULL ); | ||||
|  | ||||
| 	if (!list || !node) | ||||
|     if( ( list == NULL ) || ( node == NULL ) ) | ||||
|         return NULL; | ||||
|  | ||||
|     if( node->next == &list->tail ) | ||||
|         return NULL; | ||||
|     else | ||||
|         return node->next; | ||||
| } | ||||
|  | ||||
| ListNode *ListPrev(LinkedList *list, ListNode *node) | ||||
| /**************************************************************************** | ||||
|  * Function: ListPrev | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Returns the previous item in the list. | ||||
|  *     | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *   | ||||
|  *  Returns: | ||||
|  *      The previous item in the list. NULL if there are no more items in list. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListPrev( LinkedList * list, | ||||
|           ListNode * node ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|     assert( node != NULL ); | ||||
|  | ||||
| 	if (!list || !node) | ||||
|     if( ( list == NULL ) || ( node == NULL ) ) | ||||
|         return NULL; | ||||
|  | ||||
|     if( node->prev == &list->head ) | ||||
| @@ -268,13 +459,35 @@ ListNode *ListPrev(LinkedList *list, ListNode *node) | ||||
|         return node->prev; | ||||
| } | ||||
|  | ||||
| ListNode *ListFind(LinkedList *list, ListNode *start, void *item) | ||||
| /**************************************************************************** | ||||
|  * Function: ListFind | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Finds the specified item in the list. | ||||
|  *      Uses the compare function specified in ListInit. If compare function | ||||
|  *      is NULL then compares items as pointers. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|  *      ListNode *start - the node to start from, NULL if to start from  | ||||
|  *                        beginning. | ||||
|  *      void * item - the item to search for. | ||||
|  *  Returns: | ||||
|  *      The node containing the item. NULL if no node contains the item. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| ListNode * | ||||
| ListFind( LinkedList * list, | ||||
|           ListNode * start, | ||||
|           void *item ) | ||||
| { | ||||
|  | ||||
|     ListNode *finger = NULL; | ||||
|  | ||||
| 	if (!list) | ||||
|     if( list == NULL ) | ||||
|         return NULL; | ||||
| 	if (!start) | ||||
|  | ||||
|     if( start == NULL ) | ||||
|         start = &list->head; | ||||
|  | ||||
|     assert( start ); | ||||
| @@ -295,13 +508,28 @@ ListNode *ListFind(LinkedList *list, ListNode *start, void *item) | ||||
|     } | ||||
|  | ||||
|     return NULL; | ||||
|  | ||||
| } | ||||
|  | ||||
| long ListSize(LinkedList *list) | ||||
| /**************************************************************************** | ||||
|  * Function: ListSize | ||||
|  * | ||||
|  *  Description: | ||||
|  *     Returns the size of the list. | ||||
|  *  Parameters: | ||||
|  *      LinkedList *list  - must be valid, non null, pointer to a linked list. | ||||
|   | ||||
|  *  Returns: | ||||
|  *      The number of items in the list. | ||||
|  *  Precondition: | ||||
|  *      The list has been initialized. | ||||
|  *****************************************************************************/ | ||||
| int | ||||
| ListSize( LinkedList * list ) | ||||
| { | ||||
|     assert( list != NULL ); | ||||
|  | ||||
| 	if (!list) | ||||
|     if( list == NULL ) | ||||
|         return EINVAL; | ||||
|  | ||||
|     return list->size; | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,127 +1,162 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "TimerThread.h" | ||||
|  | ||||
| #include <assert.h> | ||||
|  | ||||
| /*! | ||||
|  * \brief Deallocates a dynamically allocated TimerEvent. | ||||
|  */ | ||||
| static void FreeTimerEvent( | ||||
| 	/*! [in] Valid timer thread pointer. */ | ||||
| 	TimerThread *timer, | ||||
| 	/*! [in] Must be allocated with CreateTimerEvent*/ | ||||
| /**************************************************************************** | ||||
|  * Function: FreeTimerEvent | ||||
|  * | ||||
|  *  Description: | ||||
|  *      Deallocates a dynamically allocated TimerEvent. | ||||
|  *  Parameters: | ||||
|  *      TimerEvent *event - must be allocated with CreateTimerEvent | ||||
|  *****************************************************************************/ | ||||
| static void | ||||
| FreeTimerEvent( TimerThread * timer, | ||||
|                 TimerEvent * event ) | ||||
| { | ||||
|  | ||||
|     assert( timer != NULL ); | ||||
|  | ||||
|     FreeListFree( &timer->freeEvents, event ); | ||||
| } | ||||
|  | ||||
| /*! | ||||
|  * \brief Implements timer thread. | ||||
| /**************************************************************************** | ||||
|  * Function: TimerThreadWorker | ||||
|  * | ||||
|  * Waits for next event to occur and schedules associated job into threadpool. | ||||
|  */ | ||||
| static void *TimerThreadWorker( | ||||
| 	/*! [in] arg is cast to (TimerThread *). */ | ||||
| 	void *arg) | ||||
|  *  Description: | ||||
|  *      Implements timer thread. | ||||
|  *      Waits for next event to occur and schedules | ||||
|  *      associated job into threadpool. | ||||
|  *      Internal Only. | ||||
|  *  Parameters: | ||||
|  *      void * arg -> is cast to TimerThread * | ||||
|  *****************************************************************************/ | ||||
| static void * | ||||
| TimerThreadWorker( void *arg ) | ||||
| { | ||||
|     TimerThread *timer = ( TimerThread * ) arg; | ||||
|     ListNode *head = NULL; | ||||
|  | ||||
|     TimerEvent *nextEvent = NULL; | ||||
|  | ||||
|     time_t currentTime = 0; | ||||
|     time_t nextEventTime = 0; | ||||
|     struct timespec timeToWait; | ||||
|  | ||||
|     int tempId; | ||||
|  | ||||
|     assert( timer != NULL ); | ||||
|  | ||||
|     ithread_mutex_lock( &timer->mutex ); | ||||
|     while (1) { | ||||
|         /* mutex should always be locked at top of loop */ | ||||
| 	/* Check for shutdown. */ | ||||
|         if (timer->shutdown) { | ||||
|  | ||||
|     while( 1 ) | ||||
|     { | ||||
|  | ||||
|         //mutex should always be locked at top of loop | ||||
|  | ||||
|         //Check for shutdown | ||||
|  | ||||
|         if( timer->shutdown ) | ||||
|         { | ||||
|  | ||||
|             timer->shutdown = 0; | ||||
|             ithread_cond_signal( &timer->condition ); | ||||
|             ithread_mutex_unlock( &timer->mutex ); | ||||
|             return NULL; | ||||
|  | ||||
|         } | ||||
|  | ||||
|         nextEvent = NULL; | ||||
|         /* Get the next event if possible. */ | ||||
|         if (timer->eventQ.size > 0) { | ||||
|  | ||||
|         //Get the next event if possible | ||||
|         if( timer->eventQ.size > 0 ) | ||||
|         { | ||||
|             head = ListHead( &timer->eventQ ); | ||||
|  | ||||
|             nextEvent = ( TimerEvent * ) head->item; | ||||
|             nextEventTime = nextEvent->eventTime; | ||||
|         } | ||||
|  | ||||
|         currentTime = time( NULL ); | ||||
|         /* If time has elapsed, schedule job. */ | ||||
|         if (nextEvent && currentTime >= nextEventTime) { | ||||
|  | ||||
|         //If time has elapsed, schedule job | ||||
|  | ||||
|         if( ( nextEvent != NULL ) && ( currentTime >= nextEventTime ) ) | ||||
|         { | ||||
|  | ||||
|             if( nextEvent->persistent ) { | ||||
|  | ||||
|                 ThreadPoolAddPersistent( timer->tp, &nextEvent->job, | ||||
|                                          &tempId ); | ||||
|             } else { | ||||
|  | ||||
|                 ThreadPoolAdd( timer->tp, &nextEvent->job, &tempId ); | ||||
|             } | ||||
|  | ||||
|             ListDelNode( &timer->eventQ, head, 0 ); | ||||
|             FreeTimerEvent( timer, nextEvent ); | ||||
|  | ||||
|             continue; | ||||
|  | ||||
|         } | ||||
|         if (nextEvent) { | ||||
|  | ||||
|         if( nextEvent != NULL ) { | ||||
|             timeToWait.tv_nsec = 0; | ||||
|             timeToWait.tv_sec = nextEvent->eventTime; | ||||
|  | ||||
|             ithread_cond_timedwait( &timer->condition, &timer->mutex, | ||||
|                                     &timeToWait ); | ||||
|  | ||||
|         } else { | ||||
|             ithread_cond_wait( &timer->condition, &timer->mutex ); | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Calculates the appropriate timeout in absolute seconds | ||||
|  * since Jan 1, 1970. | ||||
| /**************************************************************************** | ||||
|  * Function: CalculateEventTime | ||||
|  * | ||||
|  * \return  | ||||
|  */ | ||||
| static int CalculateEventTime( | ||||
| 	/*! [in] Timeout. */ | ||||
| 	time_t *timeout, | ||||
| 	/*! [in] Timeout type. */ | ||||
|  *  Description: | ||||
|  *      Calculates the appropriate timeout in absolute seconds since | ||||
|  *      Jan 1, 1970 | ||||
|  *      Internal Only. | ||||
|  *  Parameters: | ||||
|  *      time_t *timeout - timeout | ||||
|  *       | ||||
|  *****************************************************************************/ | ||||
| static int | ||||
| CalculateEventTime( time_t * timeout, | ||||
|                     TimeoutType type ) | ||||
| { | ||||
|     time_t now; | ||||
| @@ -130,30 +165,38 @@ static int CalculateEventTime( | ||||
|  | ||||
|     if( type == ABS_SEC ) | ||||
|         return 0; | ||||
|     else /*if (type == REL_SEC) */{ | ||||
|     else if( type == REL_SEC ) { | ||||
|         time( &now ); | ||||
|         ( *timeout ) += now; | ||||
|         return 0; | ||||
|     } | ||||
|  | ||||
|     return -1; | ||||
|  | ||||
| } | ||||
|  | ||||
| /*! | ||||
|  * \brief Creates a Timer Event. (Dynamically allocated). | ||||
| /**************************************************************************** | ||||
|  * Function: CreateTimerEvent | ||||
|  * | ||||
|  * \return (TimerEvent *) on success, NULL on failure. | ||||
|  */ | ||||
| static TimerEvent *CreateTimerEvent( | ||||
| 	/*! [in] Valid timer thread pointer. */ | ||||
| 	TimerThread *timer, | ||||
| 	/*! [in] . */ | ||||
|  *  Description: | ||||
|  *      Creates a Timer Event. (Dynamically allocated) | ||||
|  *      Internal to timer thread. | ||||
|  *  Parameters: | ||||
|  *      func - thread function to run. | ||||
|  *      arg - argument to function. | ||||
|  *      priority - priority of job. | ||||
|  *      eventTime - the absoule time of the event | ||||
|  *                  in seconds from Jan, 1970 | ||||
|  *      id - id of job | ||||
|  *       | ||||
|  *  Returns: | ||||
|  *      TimerEvent * on success, NULL on failure. | ||||
|  ****************************************************************************/ | ||||
| static TimerEvent * | ||||
| CreateTimerEvent( TimerThread * timer, | ||||
|                   ThreadPoolJob * job, | ||||
| 	/*! [in] . */ | ||||
|                   Duration persistent, | ||||
| 	/*! [in] The absoule time of the event in seconds from Jan, 1970. */ | ||||
|                   time_t eventTime, | ||||
| 	/*! [in] Id of job. */ | ||||
|                   int id ) | ||||
| { | ||||
|     TimerEvent *temp = NULL; | ||||
| @@ -172,8 +215,25 @@ static TimerEvent *CreateTimerEvent( | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
|  | ||||
| int TimerThreadInit(TimerThread *timer, ThreadPool *tp) | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadInit | ||||
|  *  | ||||
|  *  Description: | ||||
|  *     Initializes and starts timer thread. | ||||
|  * | ||||
|  *  Parameters: | ||||
|  *             timer - valid timer thread pointer. | ||||
|  *             tp  - valid thread pool to use. Must be | ||||
|  *                   started. Must be valid for lifetime | ||||
|  *                   of timer.  Timer must be shutdown | ||||
|  *                   BEFORE thread pool. | ||||
|  *  Return: | ||||
|  *            0 on success, nonzero on failure | ||||
|  *            Returns error from ThreadPoolAddPersistent if failure. | ||||
|  ************************************************************************/ | ||||
| int | ||||
| TimerThreadInit( TimerThread * timer, | ||||
|                  ThreadPool * tp ) | ||||
| { | ||||
|  | ||||
|     int rc = 0; | ||||
| @@ -227,16 +287,42 @@ int TimerThreadInit(TimerThread *timer, ThreadPool *tp) | ||||
|     } | ||||
|  | ||||
|     return rc; | ||||
|  | ||||
| } | ||||
|  | ||||
| int TimerThreadSchedule( | ||||
| 	TimerThread *timer, | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadSchedule | ||||
|  *  | ||||
|  *  Description: | ||||
|  *     Schedules an event to run at a specified time. | ||||
|  * | ||||
|  *  Parameters: | ||||
|  *             timer - valid timer thread pointer. | ||||
|  *             time_t - time of event. | ||||
|  *                      either in absolute seconds, | ||||
|  *                      or relative seconds in the future. | ||||
|  *             timeoutType - either ABS_SEC, or REL_SEC. | ||||
|  *                           if REL_SEC, then the event | ||||
|  *                           will be scheduled at the | ||||
|  *                           current time + REL_SEC. | ||||
|  *              | ||||
|  *             func - function to schedule | ||||
|  *             arg - argument to function | ||||
|  *             priority - priority of job. | ||||
|  *             id - id of timer event. (out) | ||||
|  *  Return: | ||||
|  *            0 on success, nonzero on failure | ||||
|  *			  EOUTOFMEM if not enough memory to schedule job | ||||
|  ************************************************************************/ | ||||
| int | ||||
| TimerThreadSchedule( TimerThread * timer, | ||||
|                      time_t timeout, | ||||
|                      TimeoutType type, | ||||
|                      ThreadPoolJob * job, | ||||
|                      Duration duration, | ||||
|                      int *id ) | ||||
| { | ||||
|  | ||||
|     int rc = EOUTOFMEM; | ||||
|     int found = 0; | ||||
|     int tempId = 0; | ||||
| @@ -269,25 +355,35 @@ int TimerThreadSchedule( | ||||
|     } | ||||
|  | ||||
|     tempNode = ListHead( &timer->eventQ ); | ||||
|     /* add job to Q. Q is ordered by eventTime with the head of the Q being | ||||
|      * the next event. */ | ||||
|     //add job to Q | ||||
|     //Q is ordered by eventTime | ||||
|     //with the head of the Q being the next event | ||||
|  | ||||
|     while( tempNode != NULL ) { | ||||
|         temp = ( TimerEvent * ) tempNode->item; | ||||
|         if( temp->eventTime >= timeout ) { | ||||
|             if (ListAddBefore( &timer->eventQ, newEvent, tempNode)) | ||||
|         if( temp->eventTime >= timeout ) | ||||
|         { | ||||
|  | ||||
|             if( ListAddBefore( &timer->eventQ, newEvent, tempNode ) != | ||||
|                 NULL ) | ||||
|                 rc = 0; | ||||
|             found = 1; | ||||
|             break; | ||||
|  | ||||
|         } | ||||
|         tempNode = ListNext( &timer->eventQ, tempNode ); | ||||
|     } | ||||
|     /* add to the end of Q. */ | ||||
|  | ||||
|     //add to the end of Q | ||||
|     if( !found ) { | ||||
|  | ||||
|         if( ListAddTail( &timer->eventQ, newEvent ) != NULL ) | ||||
|             rc = 0; | ||||
|  | ||||
|     } | ||||
|     /* signal change in Q. */ | ||||
|     //signal change in Q | ||||
|     if( rc == 0 ) { | ||||
|  | ||||
|         ithread_cond_signal( &timer->condition ); | ||||
|     } else { | ||||
|         FreeTimerEvent( timer, newEvent ); | ||||
| @@ -298,8 +394,26 @@ int TimerThreadSchedule( | ||||
|     return rc; | ||||
| } | ||||
|  | ||||
| int TimerThreadRemove( | ||||
| 	TimerThread *timer, | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadRemove | ||||
|  *  | ||||
|  *  Description: | ||||
|  *     Removes an event from the timer Q. | ||||
|  *     Events can only be removed  | ||||
|  *     before they have been placed in the | ||||
|  *     thread pool. | ||||
|  * | ||||
|  *  Parameters: | ||||
|  *             timer - valid timer thread pointer. | ||||
|  *             id - id of event to remove. | ||||
|  *             out - space for returned job (Can be NULL) | ||||
|  *  Return: | ||||
|  *            0 on success. | ||||
|  *            INVALID_EVENT_ID on error. | ||||
|  * | ||||
|  ************************************************************************/ | ||||
| int | ||||
| TimerThreadRemove( TimerThread * timer, | ||||
|                    int id, | ||||
|                    ThreadPoolJob * out ) | ||||
| { | ||||
| @@ -336,7 +450,21 @@ int TimerThreadRemove( | ||||
|     return rc; | ||||
| } | ||||
|  | ||||
| int TimerThreadShutdown(TimerThread *timer) | ||||
| /************************************************************************ | ||||
|  * Function: TimerThreadShutdown | ||||
|  *  | ||||
|  *  Description: | ||||
|  *    Shutdown the timer thread | ||||
|  *    Events scheduled in the future will NOT be run. | ||||
|  *    Timer thread should be shutdown BEFORE it's associated | ||||
|  *    thread pool. | ||||
|  *  Returns: | ||||
|  *    returns 0 if succesfull, | ||||
|  *            nonzero otherwise. | ||||
|  *            Always returns 0. | ||||
|  ***********************************************************************/ | ||||
| int | ||||
| TimerThreadShutdown( TimerThread * timer ) | ||||
| { | ||||
|     ListNode *tempNode2 = NULL; | ||||
|     ListNode *tempNode = NULL; | ||||
| @@ -352,7 +480,9 @@ int TimerThreadShutdown(TimerThread *timer) | ||||
|     timer->shutdown = 1; | ||||
|     tempNode = ListHead( &timer->eventQ ); | ||||
|  | ||||
|     /* Delete nodes in Q. Call registered free function on argument. */ | ||||
|     //Delete nodes in Q | ||||
|     //call registered free function  | ||||
|     //on argument | ||||
|     while( tempNode != NULL ) { | ||||
|         TimerEvent *temp = ( TimerEvent * ) tempNode->item; | ||||
|  | ||||
| @@ -370,19 +500,20 @@ int TimerThreadShutdown(TimerThread *timer) | ||||
|  | ||||
|     ithread_cond_broadcast( &timer->condition ); | ||||
|  | ||||
|     while (timer->shutdown) { | ||||
| 	/* wait for timer thread to shutdown. */ | ||||
|     while( timer->shutdown )    //wait for timer thread to shutdown | ||||
|     { | ||||
|         ithread_cond_wait( &timer->condition, &timer->mutex ); | ||||
|     } | ||||
|  | ||||
|     ithread_mutex_unlock( &timer->mutex ); | ||||
|  | ||||
|     /* destroy condition. */ | ||||
|     //destroy condition | ||||
|     while( ithread_cond_destroy( &timer->condition ) != 0 ) { | ||||
|     } | ||||
|     /* destroy mutex. */ | ||||
|  | ||||
|     //destroy mutex | ||||
|     while( ithread_mutex_destroy( &timer->mutex ) != 0 ) { | ||||
|     } | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| # | ||||
| # "Makefile.am" for "libupnp/upnp" | ||||
| # | ||||
| # Copyright (C) 2005 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
| # Copyright (C) 2005 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
| # | ||||
|  | ||||
| SUBDIRS = doc . sample | ||||
| @@ -19,11 +19,8 @@ LDADD = \ | ||||
|  | ||||
| upnpincludedir = $(includedir)/upnp | ||||
| upnpinclude_HEADERS = \ | ||||
| 	inc/UpnpString.h \ | ||||
| 	inc/upnp.h \ | ||||
| 	inc/upnpdebug.h \ | ||||
| 	inc/UpnpGlobal.h \ | ||||
| 	inc/UpnpInet.h | ||||
| 	inc/upnpdebug.h | ||||
|  | ||||
| nodist_upnpinclude_HEADERS = inc/upnpconfig.h  | ||||
| if ENABLE_TOOLS | ||||
| @@ -49,6 +46,7 @@ libupnp_la_SOURCES = \ | ||||
| 	src/inc/gena_device.h \ | ||||
| 	src/inc/global.h \ | ||||
| 	src/inc/gmtdate.h \ | ||||
| 	src/inc/http_client.h \ | ||||
| 	src/inc/httpparser.h \ | ||||
| 	src/inc/httpreadwrite.h \ | ||||
| 	src/inc/md5.h \ | ||||
| @@ -67,12 +65,13 @@ libupnp_la_SOURCES = \ | ||||
| 	src/inc/sysdep.h \ | ||||
| 	src/inc/unixutil.h \ | ||||
| 	src/inc/upnpapi.h \ | ||||
| 	src/inc/upnpclosesocket.h \ | ||||
| 	src/inc/upnp_timeout.h \ | ||||
| 	src/inc/uri.h \ | ||||
| 	src/inc/urlconfig.h \ | ||||
| 	src/inc/upnputil.h \ | ||||
| 	src/inc/util.h \ | ||||
| 	src/inc/utilall.h \ | ||||
| 	src/inc/uuid.h \ | ||||
| 	src/inc/VirtualDir.h \ | ||||
| 	src/inc/webserver.h | ||||
|  | ||||
| # ssdp | ||||
| @@ -111,14 +110,10 @@ libupnp_la_SOURCES += \ | ||||
| 	src/gena/gena_callback2.c | ||||
|  | ||||
| # api | ||||
| libupnp_la_SOURCES += \ | ||||
| 	src/api/UpnpString.c \ | ||||
| 	src/api/upnpapi.c | ||||
|  | ||||
| libupnp_la_SOURCES += src/api/upnpapi.c | ||||
| if ENABLE_TOOLS | ||||
| libupnp_la_SOURCES += src/api/upnptools.c | ||||
| endif | ||||
|  | ||||
| if ENABLE_DEBUG | ||||
| libupnp_la_SOURCES += src/api/upnpdebug.c  | ||||
| endif | ||||
| @@ -135,12 +130,6 @@ libupnp_la_SOURCES += \ | ||||
| libupnp_la_SOURCES += src/urlconfig/urlconfig.c | ||||
|  | ||||
|  | ||||
| # inet_pton (needed on Win32, compiles to nothing elsewhere) | ||||
| libupnp_la_SOURCES += \ | ||||
| 	src/inet_pton.c \ | ||||
| 	src/inc/inet_pton.h | ||||
|  | ||||
|  | ||||
| # check / distcheck tests | ||||
| check_PROGRAMS = test_init | ||||
| TESTS = test_init | ||||
| @@ -149,7 +138,8 @@ test_init_SOURCES = test/test_init.c | ||||
|  | ||||
| EXTRA_DIST = \ | ||||
| 	LICENSE \ | ||||
| 	m4/libupnp.m4 \ | ||||
| 	src/inc/inet_pton.h \ | ||||
| 	src/inet_pton.c \ | ||||
| 	src/win_dll.c | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -1,124 +0,0 @@ | ||||
|  | ||||
|  | ||||
| #ifndef UPNPGLOBAL_H | ||||
| #define UPNPGLOBAL_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
|  * \brief Defines constants that for some reason are not defined on some systems. | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #if defined MYLIB_LARGEFILE_SENSITIVE && _FILE_OFFSET_BITS+0 != 64 | ||||
| 	#if defined __GNUC__ | ||||
| 		#warning libupnp requires largefile mode - use AC_SYS_LARGEFILE | ||||
| 	#else | ||||
| 		#error  libupnp requires largefile mode - use AC_SYS_LARGEFILE | ||||
| 	#endif | ||||
| #endif  | ||||
|  | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	/* | ||||
| 	 * EXPORT_SPEC | ||||
| 	 */ | ||||
| 	#ifdef UPNP_STATIC_LIB | ||||
| 		#define EXPORT_SPEC | ||||
| 	#else /* UPNP_STATIC_LIB */ | ||||
| 		#ifdef LIBUPNP_EXPORTS | ||||
| 			/*! set up declspec for dll export to make functions | ||||
| 			 * visible to library users */ | ||||
| 			#define EXPORT_SPEC __declspec(dllexport) | ||||
| 		#else /* LIBUPNP_EXPORTS */ | ||||
| 			#define EXPORT_SPEC __declspec(dllimport) | ||||
| 		#endif /* LIBUPNP_EXPORTS */ | ||||
| 	#endif /* UPNP_STATIC_LIB */ | ||||
|  | ||||
|  | ||||
| 	/* | ||||
| 	 * UPNP_INLINE | ||||
| 	 * PRId64 | ||||
| 	 * PRIzu | ||||
| 	 */ | ||||
| 	#ifdef UPNP_USE_MSVCPP | ||||
| 		/* define some things the M$ VC++ doesn't know */ | ||||
| 		#define UPNP_INLINE | ||||
| 		typedef __int64 int64_t; | ||||
| 		#define PRId64 "I64d" | ||||
| 		#define PRIzu "lu" | ||||
| 	#endif /* UPNP_USE_MSVCPP */ | ||||
|  | ||||
|  | ||||
| 	#ifdef UPNP_USE_BCBPP | ||||
| 		/* define some things Borland Builder doesn't know */ | ||||
| 		#define UPNP_INLINE inline | ||||
| 		typedef __int64 int64_t; | ||||
| 		#warning The Borland C compiler is probably broken on PRId64, | ||||
| 		#warning please someone provide a proper fix here | ||||
| 		#define PRId64 "I64d" | ||||
| 		#define PRIzu "zu" | ||||
| 	#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 /* __GNUC__ */ | ||||
| #else | ||||
| 	/*!  | ||||
| 	 * \brief Export functions on WIN32 DLLs. | ||||
| 	 * | ||||
| 	 * Every funtion that belongs to the library API must use this | ||||
| 	 * definition upon declaration or it will not be exported on WIN32 | ||||
| 	 * DLLs. | ||||
| 	 */ | ||||
| 	#define EXPORT_SPEC | ||||
|  | ||||
| 	/*! | ||||
| 	 * \brief Declares an inline function. | ||||
| 	 * | ||||
| 	 * Surprisingly, there are some compilers that do not understand the | ||||
| 	 * inline keyword. This definition makes the use of this keyword | ||||
| 	 * portable to these systems. | ||||
| 	 */ | ||||
| 	#ifdef __STRICT_ANSI__ | ||||
| 		#define UPNP_INLINE __inline__ | ||||
| 	#else | ||||
| 		#define UPNP_INLINE inline | ||||
| 	#endif | ||||
| 	 | ||||
| 	/*! | ||||
| 	 * \brief Supply the PRId64 printf() macro. | ||||
| 	 * | ||||
| 	 * MSVC still does not know about this. | ||||
| 	 */ | ||||
| 	/* #define PRId64 PRId64 */ | ||||
|  | ||||
| 	/*! | ||||
| 	 * \brief Supply the PRIzu printf() macro. | ||||
| 	 * | ||||
| 	 * This macro was invented so that we can live a little longer with | ||||
| 	 * MSVC lack of C99. "z" is the correct printf() size specifier for | ||||
| 	 * the size_t type. | ||||
| 	 */ | ||||
| 	#define PRIzu "zu" | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Defining this macro here gives some interesting information about unused | ||||
|  * functions in the code. Of course, this should never go uncommented on a | ||||
|  * release. | ||||
|  */ | ||||
| /*#define inline*/ | ||||
|  | ||||
|  | ||||
| #endif /* UPNPGLOBAL_H */ | ||||
|  | ||||
| @@ -1,40 +0,0 @@ | ||||
|  | ||||
| #ifndef UPNPINET_H | ||||
| #define UPNPINET_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
|  * \brief Provides a platform independent way to include TCP/IP types and functions. | ||||
|  */ | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	#include <iphlpapi.h> | ||||
| 	#include <winsock2.h> | ||||
| 	#include <Ws2tcpip.h> | ||||
|  | ||||
| 	#define UpnpCloseSocket closesocket | ||||
| #else | ||||
| 	#include <sys/param.h> | ||||
| 	#if (defined(BSD) && BSD >= 199306) || defined (__FreeBSD_kernel__) | ||||
| 		#include <ifaddrs.h> | ||||
| 		/* Do not move or remove the include below for "sys/socket"! | ||||
| 		 * Will break FreeBSD builds. */ | ||||
| 		#include <sys/socket.h> | ||||
| 	#endif | ||||
| 	#include <netinet/in.h> | ||||
|  | ||||
| 	/* include <unistd.h> for close(). | ||||
| 	 * Do not include this file in win32. */ | ||||
| 	#include <unistd.h> | ||||
| 	/* SOCKET is unsigned and is not a file descriptor on win32. */ | ||||
| 	#define SOCKET int | ||||
| 	/* INVALID_SOCKET is unsigned on win32. */ | ||||
| 	#define INVALID_SOCKET (-1) | ||||
| 	/* select() returns SOCKET_ERROR on win32. */ | ||||
| 	#define SOCKET_ERROR (-1) | ||||
| 	#define UpnpCloseSocket close | ||||
| #endif | ||||
|  | ||||
| #endif /* UPNPINET_H */ | ||||
|  | ||||
| @@ -1,171 +0,0 @@ | ||||
|  | ||||
|  | ||||
| #ifndef STRING_H | ||||
| #define STRING_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \defgroup UpnpString The UpnpString Class | ||||
|  * | ||||
|  * \brief Implements string operations in the UPnP library. | ||||
|  * | ||||
|  * \author Marcelo Roberto Jimenez | ||||
|  * | ||||
|  * \version 1.0 | ||||
|  * | ||||
|  * @{ | ||||
|  * | ||||
|  * \file | ||||
|  * | ||||
|  * \brief UpnpString object declaration. | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #include "UpnpGlobal.h" /* for EXPORT_SPEC */ | ||||
|  | ||||
|  | ||||
| #include <stdlib.h> /* for size_t */ | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Type of the string objects inside libupnp. | ||||
|  */ | ||||
| typedef struct s_UpnpString UpnpString; | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Constructor. | ||||
|  * | ||||
|  * \return A pointer to a new allocated object. | ||||
|  */ | ||||
| EXPORT_SPEC UpnpString *UpnpString_new(); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Destructor. | ||||
|  */ | ||||
| EXPORT_SPEC void UpnpString_delete( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	UpnpString *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Copy Constructor. | ||||
|  * | ||||
|  * \return A pointer to a new allocated copy of the original object. | ||||
|  */ | ||||
| EXPORT_SPEC UpnpString *UpnpString_dup( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	const UpnpString *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Assignment operator. | ||||
|  */ | ||||
| EXPORT_SPEC void UpnpString_assign( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	UpnpString *p, | ||||
| 	/*! [in] The \em \b that pointer. */ | ||||
| 	const UpnpString *q); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the length of the string. | ||||
|  * | ||||
|  * \return The length of the string. | ||||
|  * */ | ||||
| EXPORT_SPEC size_t UpnpString_get_Length( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	const UpnpString *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Truncates the string to the specified lenght, or does nothing | ||||
|  * if the current lenght is less than or equal to the requested length. | ||||
|  * */ | ||||
| EXPORT_SPEC void UpnpString_set_Length( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	UpnpString *p, | ||||
| 	/*! [in] The requested length. */ | ||||
| 	size_t n); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the pointer to char. | ||||
|  * | ||||
|  * \return The pointer to char. | ||||
|  */ | ||||
| EXPORT_SPEC const char *UpnpString_get_String( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	const UpnpString *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the string from a pointer to char. | ||||
|  */ | ||||
| EXPORT_SPEC int UpnpString_set_String( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	UpnpString *p, | ||||
| 	/*! [in] (char *) to copy from. */ | ||||
| 	const char *s); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Sets the string from a pointer to char using a maximum of N chars. | ||||
|  */ | ||||
| EXPORT_SPEC int UpnpString_set_StringN( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	UpnpString *p, | ||||
| 	/*! [in] (char *) to copy from. */ | ||||
| 	const char *s, | ||||
| 	/*! Maximum number of chars to copy.*/ | ||||
| 	size_t n); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Clears the string, sets its size to zero. | ||||
|  */ | ||||
| EXPORT_SPEC void UpnpString_clear( | ||||
| 	/*! [in] The \em \b this pointer. */ | ||||
| 	UpnpString *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Compares two strings for equality. Case matters. | ||||
|  * | ||||
|  * \return The result of strcmp(). | ||||
|  */ | ||||
| EXPORT_SPEC int UpnpString_cmp( | ||||
| 	/*! [in] The \em \b the first string. */ | ||||
| 	UpnpString *p, | ||||
| 	/*! [in] The \em \b the second string. */ | ||||
| 	UpnpString *q); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Compares two strings for equality. Case does not matter. | ||||
|  * | ||||
|  * \return The result of strcasecmp(). | ||||
|  */ | ||||
| EXPORT_SPEC int UpnpString_casecmp( | ||||
| 	/*! [in] The \em \b the first string. */ | ||||
| 	UpnpString *p, | ||||
| 	/*! [in] The \em \b the second string. */ | ||||
| 	UpnpString *q); | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
|  | ||||
| /* @} UpnpString The UpnpString API */ | ||||
|  | ||||
|  | ||||
| #endif /* STRING_H */ | ||||
|  | ||||
							
								
								
									
										3663
									
								
								upnp/inc/upnp.h
									
									
									
									
									
								
							
							
						
						
									
										3663
									
								
								upnp/inc/upnp.h
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,7 +1,7 @@ | ||||
| /* -*- C -*- */ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2006 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
|  * Copyright (c) 2006 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
| @@ -90,9 +90,6 @@ | ||||
|  *  (i.e. configure --enable-tools) : <upnp/upnptools.h> file is available */ | ||||
| #undef UPNP_HAVE_TOOLS | ||||
|  | ||||
| /** Defined to 1 if the library has been compiled with ipv6 support | ||||
|  *  (i.e. configure --enable-ipv6) */ | ||||
| #undef UPNP_ENABLE_IPV6 | ||||
|  | ||||
| #endif /* UPNP_CONFIG_H */ | ||||
|  | ||||
|   | ||||
| @@ -1,18 +1,18 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * Copyright (c) 2006 Rémi Turboult <r3mi@users.sourceforge.net> | ||||
|  * Copyright (c) 2006 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net> | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * 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.  | ||||
|  * - 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  | ||||
|  * 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  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
| @@ -33,13 +33,8 @@ | ||||
| #ifndef UPNP_DEBUG_H | ||||
| #define UPNP_DEBUG_H  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #include "ThreadPool.h" | ||||
| #include "upnp.h" | ||||
| #include "upnpconfig.h" | ||||
| #include "UpnpGlobal.h" /* for UPNP_INLINE */ | ||||
|  | ||||
| #include <stdio.h> | ||||
|  | ||||
| @@ -47,15 +42,16 @@ | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /*! \name Other debugging features | ||||
|  * | ||||
|  * The UPnP SDK contains other features to aid in debugging. | ||||
|  */ | ||||
| /*@{*/ | ||||
|  | ||||
| /*! \name Upnp_LogLevel | ||||
| /** @name Other debugging features | ||||
|           The UPnP SDK contains other features to aid in debugging. | ||||
|  */ | ||||
|  | ||||
| /*! @{ */ | ||||
|  | ||||
| /** @name Upnp_LogLevel | ||||
|  *  The user has the option to select 4 different types of debugging levels, | ||||
|  *  see \c UpnpSetLogLevel.  | ||||
|  *  see {\tt UpnpSetLogLevel}.  | ||||
|  *  The critical level will show only those messages  | ||||
|  *  which can halt the normal processing of the library, like memory  | ||||
|  *  allocation errors. The remaining three levels are just for debugging  | ||||
| @@ -64,11 +60,14 @@ extern "C" { | ||||
|  *  Info Level displays the other important operational information  | ||||
|  *  regarding the working of the library. If the user selects All,  | ||||
|  *  then the library displays all the debugging information that it has. | ||||
|  *    \li \c UPNP_CRITICAL [0] | ||||
|  *    \li \c UPNP_PACKET [1] | ||||
|  *    \li \c UPNP_INFO [2] | ||||
|  *    \li \c UPNP_ALL [3] | ||||
|  *  \begin{itemize} | ||||
|  *    \item {\tt UPNP_CRITICAL [0]} | ||||
|  *    \item {\tt UPNP_PACKET [1]} | ||||
|  *    \item {\tt UPNP_INFO [2]} | ||||
|  *    \item {\tt UPNP_ALL [3]} | ||||
|  *  \end{itemize} | ||||
|  */ | ||||
|  | ||||
| typedef enum Upnp_Module { | ||||
| 	SSDP, | ||||
| 	SOAP, | ||||
| @@ -80,145 +79,179 @@ typedef enum Upnp_Module { | ||||
| 	HTTP | ||||
| } Dbg_Module; | ||||
|  | ||||
| /*@{*/ | ||||
| /*! @{ */ | ||||
| typedef enum Upnp_LogLevel_e { | ||||
| 	UPNP_CRITICAL, | ||||
| 	UPNP_PACKET, | ||||
| 	UPNP_INFO, | ||||
| 	UPNP_ALL | ||||
| } Upnp_LogLevel; | ||||
| /*@}*/ | ||||
| /*! @} */ | ||||
|  | ||||
| /*! | ||||
|  * Default log level : see \c Upnp_LogLevel | ||||
|  | ||||
| /** | ||||
|  * Default log level : see {\tt Upnp_LogLevel} | ||||
|  */ | ||||
| #define UPNP_DEFAULT_LOG_LEVEL	UPNP_ALL | ||||
|  | ||||
| /*! | ||||
|  * \brief Initialize the log files. | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpInitLog | ||||
|  * | ||||
|  * \return -1 if fails or UPNP_E_SUCCESS if succeeds. | ||||
|  */ | ||||
|  * Parameters:	void | ||||
|  * | ||||
|  * Description: | ||||
|  *	This functions initializes the log files | ||||
|  * | ||||
|  * Returns: int | ||||
|  *	-1 : If fails | ||||
|  *	UPNP_E_SUCCESS : if success | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| int UpnpInitLog(void); | ||||
| int UpnpInitLog(); | ||||
| #else | ||||
| static UPNP_INLINE int UpnpInitLog(void) | ||||
| { | ||||
| 	return UPNP_E_SUCCESS; | ||||
| } | ||||
| static UPNP_INLINE int UpnpInitLog() { return UPNP_E_SUCCESS; } | ||||
| #endif | ||||
|  | ||||
| /*! | ||||
|  * \brief Set the log level (see \c Upnp_LogLevel). | ||||
|  */ | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpSetLogLevel | ||||
|  *				 | ||||
|  * Parameters: Upnp_LogLevel log_level | ||||
|  * | ||||
|  * Description:							 | ||||
|  *	This functions set the log level (see {\tt Upnp_LogLevel} | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void UpnpSetLogLevel( | ||||
| 	/*! [in] Log level. */ | ||||
| 	Upnp_LogLevel log_level); | ||||
| void UpnpSetLogLevel(Upnp_LogLevel log_level); | ||||
| #else | ||||
| static UPNP_INLINE void UpnpSetLogLevel(Upnp_LogLevel log_level) | ||||
| { | ||||
| 	return; | ||||
| 	log_level = log_level; | ||||
| } | ||||
| static UPNP_INLINE void UpnpSetLogLevel(Upnp_LogLevel log_level) {} | ||||
| #endif | ||||
|  | ||||
| /*! | ||||
|  * \brief Closes the log files. | ||||
|  */ | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpCloseLog						 | ||||
|  *								 | ||||
|  * Parameters:	void					 | ||||
|  *								 | ||||
|  * Description:							 | ||||
|  *	This functions closes the log files | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void UpnpCloseLog(void); | ||||
| void UpnpCloseLog(); | ||||
| #else | ||||
| static UPNP_INLINE void UpnpCloseLog(void) {} | ||||
| static UPNP_INLINE void UpnpCloseLog() {} | ||||
| #endif | ||||
|  | ||||
| /*! | ||||
|  * \brief Set the name for error and information files, respectively. | ||||
|  */ | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpSetLogFileNames		 | ||||
|  *							 | ||||
|  * Parameters:						 | ||||
|  *	IN const char* ErrFileName: name of the error file | ||||
|  *	IN const char *InfoFileName: name of the information file | ||||
|  *	IN int size: Size of the buffer | ||||
|  *	IN int starLength: This parameter provides the width of the banner | ||||
|  *								 | ||||
|  * Description:							 | ||||
|  *	This functions takes the buffer and writes the buffer in the file as  | ||||
|  *	per the requested banner	 | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void UpnpSetLogFileNames( | ||||
| 	/*! [in] Name of the error file. */ | ||||
| 	const char *ErrFileName, | ||||
| 	/*! [in] Name of the information file. */ | ||||
| 	const char *InfoFileName); | ||||
| #else | ||||
| static UPNP_INLINE void UpnpSetLogFileNames( | ||||
| 	const char *ErrFileName, | ||||
| 	const char *InfoFileName) | ||||
| { | ||||
| 	return; | ||||
| 	ErrFileName = ErrFileName; | ||||
| 	InfoFileName = InfoFileName; | ||||
| } | ||||
| 	const char *InfoFileName) {} | ||||
| #endif | ||||
|  | ||||
| /*! | ||||
|  * \brief Check if the module is turned on for debug and returns the file | ||||
|  * descriptor corresponding to the debug level | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpGetDebugFile		 | ||||
|  *						 | ||||
|  * \return NULL if the module is turn off for debug otheriwse returns the | ||||
|  *	right file descriptor. | ||||
|  */ | ||||
|  * Parameters:					 | ||||
|  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||
|  *		whether debug statement will go to standard output,  | ||||
|  *		or any of the log files. | ||||
|  *	IN Dbg_Module Module: debug will go in the name of this module | ||||
|  *								 | ||||
|  * Description: | ||||
|  *	This function checks if the module is turned on for debug  | ||||
|  *	and returns the file descriptor corresponding to the debug level | ||||
|  * Returns: FILE * | ||||
|  *	NULL : if the module is turn off for debug  | ||||
|  *	else returns the right file descriptor | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| FILE *UpnpGetDebugFile( | ||||
| 	/*! [in] The level of the debug logging. It will decide whether debug | ||||
| 	 * statement will go to standard output, or any of the log files. */ | ||||
| 	Upnp_LogLevel level, | ||||
| 	/*! [in] debug will go in the name of this module. */ | ||||
| 	Dbg_Module module); | ||||
| FILE *UpnpGetDebugFile(Upnp_LogLevel level, Dbg_Module module); | ||||
| #else | ||||
| static UPNP_INLINE FILE *UpnpGetDebugFile(Upnp_LogLevel level, Dbg_Module module) | ||||
| { | ||||
| 	return NULL; | ||||
| 	level = level; | ||||
| 	module = module; | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns true if debug output should be done in this module. | ||||
| /*************************************************************************** | ||||
|  * Function : DebugAtThisLevel					 | ||||
|  *									 | ||||
|  * \return Nonzero value if true, zero if false. | ||||
|  */ | ||||
|  * Parameters:			 | ||||
|  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||
|  *		whether debug statement will go to standard output,  | ||||
|  *		or any of the log files. | ||||
|  *	IN Dbg_Module Module: debug will go in the name of this module | ||||
|  *					 | ||||
|  * Description:					 | ||||
|  *	This functions returns true if debug output should be done in this | ||||
|  *	module. | ||||
|  * | ||||
|  * Returns: int | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| int DebugAtThisLevel( | ||||
| 	/*! [in] The level of the debug logging. It will decide whether debug | ||||
| 	 * statement will go to standard output, or any of the log files. */ | ||||
| 	Upnp_LogLevel DLevel, | ||||
| 	/*! [in] Debug will go in the name of this module. */ | ||||
| 	Dbg_Module Module); | ||||
| 	IN Upnp_LogLevel DLevel, | ||||
| 	IN Dbg_Module Module); | ||||
| #else | ||||
| static UPNP_INLINE int DebugAtThisLevel( | ||||
| 	Upnp_LogLevel DLevel, | ||||
| 	Dbg_Module Module) | ||||
| { | ||||
| 	return 0; | ||||
| 	DLevel = DLevel; | ||||
| 	Module = Module; | ||||
| } | ||||
| 	IN Upnp_LogLevel DLevel, | ||||
| 	IN Dbg_Module Module) { return 0; } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Prints the debug statement either on the standard output or log file | ||||
|  * along with the information from where this debug statement is coming. | ||||
|  */  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpPrintf				 | ||||
|  *									 | ||||
|  * Parameters:								 | ||||
|  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||
|  *		whether debug statement will go to standard output,  | ||||
|  *		or any of the log files. | ||||
|  *	IN Dbg_Module Module: debug will go in the name of this module | ||||
|  *	IN char *DbgFileName: Name of the file from where debug statement is | ||||
|  *							coming | ||||
|  *	IN int DbgLineNo : Line number of the file from where debug statement  | ||||
|  *				is coming | ||||
|  *	IN char * FmtStr, ...: Variable number of arguments that will go  | ||||
|  *				in the debug statement | ||||
|  *					 | ||||
|  * Description:							 | ||||
|  *	This functions prints the debug statement either on the startdard  | ||||
|  *	output or log file along with the information from where this  | ||||
|  *	debug statement is coming | ||||
|  * Returns: void | ||||
|  ***************************************************************************/  | ||||
| #ifdef DEBUG | ||||
| void UpnpPrintf( | ||||
| 	/*! [in] The level of the debug logging. It will decide whether debug | ||||
| 	 * statement will go to standard output, or any of the log files. */ | ||||
| 	Upnp_LogLevel DLevel, | ||||
| 	/*! [in] debug will go in the name of this module. */ | ||||
| 	Dbg_Module Module, | ||||
| 	/*! [in] Name of the file from where debug statement is coming. */ | ||||
| 	const char* DbgFileName, | ||||
| 	/*! [in] Line number of the file from where debug statement is coming. */ | ||||
| 	int DbgLineNo, | ||||
| 	/*! [in] Printf like format specification. */ | ||||
| 	const char* FmtStr, | ||||
| 	/*! [in] Printf like Variable number of arguments that will go in the debug | ||||
| 	 * statement. */ | ||||
| 	...) | ||||
| #if (__GNUC__ >= 3) | ||||
| 	/* This enables printf like format checking by the compiler */ | ||||
| @@ -232,102 +265,66 @@ static UPNP_INLINE void UpnpPrintf( | ||||
| 	const char* DbgFileName, | ||||
| 	int DbgLineNo, | ||||
| 	const char* FmtStr, | ||||
| 	...) | ||||
| { | ||||
| 	return; | ||||
| 	DLevel = DLevel; | ||||
| 	Module = Module; | ||||
| 	DbgFileName = DbgFileName; | ||||
| 	DbgLineNo = DbgLineNo; | ||||
| 	FmtStr = FmtStr; | ||||
| } | ||||
| 	...) {} | ||||
| #endif /* DEBUG */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Writes the file name and file number from where debug statement is | ||||
|  * coming to the log file. | ||||
|  */ | ||||
| #ifdef DEBUG | ||||
| void UpnpDisplayFileAndLine( | ||||
| 	/*! [in] File descriptor where line number and file name will be written. */ | ||||
| 	FILE *fd, | ||||
| 	/*! [in] Name of the file. */ | ||||
| 	const char *DbgFileName, | ||||
| 	/*! [in] Line number of the file. */ | ||||
| 	int DbgLineNo); | ||||
| #else | ||||
| static UPNP_INLINE void UpnpDisplayFileAndLine( | ||||
| 	FILE *fd, | ||||
| 	const char *DbgFileName, | ||||
| 	int DbgLineNo) | ||||
| { | ||||
| 	return; | ||||
| 	fd = fd; | ||||
| 	DbgFileName = DbgFileName; | ||||
| 	DbgLineNo = DbgLineNo; | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Writes the buffer in the file as per the requested banner | ||||
|  */ | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpDisplayBanner				 | ||||
|  *							 | ||||
|  * Parameters:							 | ||||
|  *	IN FILE *fd: file descriptor where the banner will be written | ||||
|  *	IN char **lines: The buffer that will be written | ||||
|  *	IN int size: Size of the buffer | ||||
|  *	IN int starLength: This parameter provides the width of the banner | ||||
|  *									 | ||||
|  * Description:							 | ||||
|  *	This functions takes the buffer and writes the buffer in the file as  | ||||
|  *	per the requested banner			 | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void UpnpDisplayBanner( | ||||
| 	/*! [in] file descriptor where the banner will be written. */ | ||||
| 	FILE *fd, | ||||
| 	/*! [in] The buffer that will be written. */ | ||||
| 	const char **lines, | ||||
| 	/*! [in] Size of the buffer. */ | ||||
| 	size_t size, | ||||
| 	/*! [in] This parameter provides the width of the banner. */ | ||||
| 	size_t starlength); | ||||
| 	int starlength); | ||||
| #else | ||||
| static UPNP_INLINE void UpnpDisplayBanner( | ||||
| 	FILE *fd, | ||||
| 	const char **lines, | ||||
| 	size_t size, | ||||
| 	int starlength) | ||||
| { | ||||
| 	return; | ||||
| 	fd = fd; | ||||
| 	lines = lines; | ||||
| 	size = size; | ||||
| 	starlength = starlength; | ||||
| } | ||||
| 	int starlength) {} | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Prints thread pool statistics. | ||||
|  */ | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpDisplayFileAndLine				 | ||||
|  *								 | ||||
|  * Parameters:							 | ||||
|  *	IN FILE *fd: File descriptor where line number and file name will be  | ||||
|  *			written  | ||||
|  *	IN char *DbgFileName: Name of the file   | ||||
|  *	IN int DbgLineNo : Line number of the file | ||||
|  *								 | ||||
|  * Description: | ||||
|  *	This function writes the file name and file number from where | ||||
|  *		debug statement is coming to the log file | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void PrintThreadPoolStats( | ||||
| 	/*! [in] The thread pool. */ | ||||
| 	ThreadPool *tp,  | ||||
| 	/*! [in] The file name that called this function, use the macro __FILE__. */ | ||||
| void UpnpDisplayFileAndLine( | ||||
| 	FILE *fd, | ||||
| 	const char *DbgFileName, | ||||
| 	/*! [in] The line number that the function was called, use the macro __LINE__. */ | ||||
| 	int DbgLineNo, | ||||
| 	/*! [in] The message. */ | ||||
| 	const char *msg); | ||||
| 	int DbgLineNo); | ||||
| #else | ||||
| static UPNP_INLINE void PrintThreadPoolStats( | ||||
| 	ThreadPool *tp,  | ||||
| static UPNP_INLINE void UpnpDisplayFileAndLine( | ||||
| 	FILE *fd, | ||||
| 	const char *DbgFileName, | ||||
| 	int DbgLineNo, | ||||
| 	const char *msg) | ||||
| { | ||||
| 	return; | ||||
| 	tp = tp; | ||||
| 	DbgFileName = DbgFileName; | ||||
| 	DbgLineNo = DbgLineNo; | ||||
| 	msg = msg; | ||||
| } | ||||
| 	int DbgLineNo) {} | ||||
| #endif | ||||
|  | ||||
| /*@}*/ | ||||
| /*! @} */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
|   | ||||
| @@ -29,261 +29,201 @@ | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| /** @name Optional Tool APIs | ||||
|  *  The Linux SDK for UPnP Devices contains some additional, optional  | ||||
|  *  utility APIs that can be helpful in writing applications using the  | ||||
|  *  SDK. These additional APIs can be compiled out in order to save code  | ||||
|  *  size in the SDK. Refer to the README for details. | ||||
|  */ | ||||
|  | ||||
| /*! @{ */ | ||||
|  | ||||
| #ifndef UPNP_TOOLS_H | ||||
| #define UPNP_TOOLS_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
|  * \defgroup UPnPTools Optional Tool API | ||||
|  * | ||||
|  * \brief Additional, optional utility API that can be helpful in writing | ||||
|  * applications. | ||||
|  * | ||||
|  * This additional API can be compiled out in order to save code size in the | ||||
|  * library. Refer to the file README for details. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #include "ixml.h" /* for IXML_Document */ | ||||
|  | ||||
| #include "upnp.h" | ||||
|  | ||||
| /* Function declarations only if tools compiled into the library */ | ||||
| #if UPNP_HAVE_TOOLS | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Converts an SDK error code into a string error message suitable for | ||||
|  * display. The memory returned from this function should NOT be freed. | ||||
| /** {\bf UpnpResolveURL} combines a base URL and a relative URL into | ||||
|  *  a single absolute URL.  The memory for {\bf AbsURL} needs to be | ||||
|  *  allocated by the caller and must be large enough to hold the | ||||
|  *  {\bf BaseURL} and {\bf RelURL} combined. | ||||
|  * | ||||
|  * \return An ASCII text string representation of the error message associated | ||||
|  * 	with the error code or the string "Unknown error code" | ||||
|  */ | ||||
| EXPORT_SPEC const char *UpnpGetErrorMessage( | ||||
| 	/*! [in] The SDK error code to convert. */ | ||||
| 	int errorcode); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Combines a base URL and a relative URL into a single absolute URL. | ||||
|  * | ||||
|  * The memory for \b AbsURL needs to be allocated by the caller and must | ||||
|  * be large enough to hold the \b BaseURL and \b RelURL combined. | ||||
|  * | ||||
|  * \return An integer representing one of the following: | ||||
|  *	\li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully. | ||||
|  *	\li <tt>UPNP_E_INVALID_PARAM</tt>: \b RelURL is <tt>NULL</tt>. | ||||
|  *	\li <tt>UPNP_E_INVALID_URL</tt>: The \b BaseURL / \b RelURL  | ||||
|  *  @return [int] An integer representing one of the following: | ||||
|  *    \begin{itemize} | ||||
|  *      \item {\tt UPNP_E_SUCCESS}: The operation completed successfully. | ||||
|  *      \item {\tt UPNP_E_INVALID_PARAM}: {\bf RelURL} is {\tt NULL}. | ||||
|  *      \item {\tt UPNP_E_INVALID_URL}: The {\bf BaseURL} / {\bf RelURL}  | ||||
|  *              combination does not form a valid URL. | ||||
|  *	\li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to  | ||||
|  *      \item {\tt UPNP_E_OUTOF_MEMORY}: Insufficient resources exist to  | ||||
|  *              complete this operation. | ||||
|  *    \end{itemize} | ||||
|  */ | ||||
|  | ||||
| EXPORT_SPEC int UpnpResolveURL( | ||||
| 	/*! [in] The base URL to combine. */ | ||||
| 	const char *BaseURL, | ||||
| 	/*! [in] The relative URL to \b BaseURL. */ | ||||
| 	const char *RelURL, | ||||
| 	/*! [out] A pointer to a buffer to store the absolute URL. */ | ||||
| 	char *AbsURL); | ||||
|     IN const char * BaseURL,  /** The base URL to combine. */ | ||||
|     IN const char * RelURL,   /** The relative URL to {\bf BaseURL}. */ | ||||
|     OUT char * AbsURL   /** A pointer to a buffer to store the  | ||||
|                             absolute URL. */ | ||||
|     ); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Combines a base URL and a relative URL into a single absolute URL. | ||||
| /** {\bf UpnpMakeAction} creates an action request packet based on its input  | ||||
|  *  parameters (status variable name and value pair). Any number of input  | ||||
|  *  parameters can be passed to this function but every input variable name  | ||||
|  *  should have a matching value argument.  | ||||
|  *    | ||||
|  * The memory for \b AbsURL becomes owned by the caller and should be freed | ||||
|  * later. | ||||
|  * | ||||
|  * \return An integer representing one of the following: | ||||
|  *	\li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully. | ||||
|  *	\li <tt>UPNP_E_INVALID_PARAM</tt>: \b RelURL is <tt>NULL</tt>. | ||||
|  *	\li <tt>UPNP_E_INVALID_URL</tt>: The \b BaseURL / \b RelURL  | ||||
|  *              combination does not form a valid URL. | ||||
|  *	\li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to  | ||||
|  *              complete this operation. | ||||
|  *  @return [IXML_Document*] The action node of {\bf Upnp_Document} type or  | ||||
|  *                      {\tt NULL} if the operation failed. | ||||
|  */ | ||||
| EXPORT_SPEC int UpnpResolveURL2( | ||||
| 	/*! [in] The base URL to combine. */ | ||||
| 	const char *BaseURL, | ||||
| 	/*! [in] The relative URL to \b BaseURL. */ | ||||
| 	const char *RelURL, | ||||
| 	/*! [out] A pointer to a pointer to a buffer to store the | ||||
| 	 * absolute URL. Must be freed later by the caller. */ | ||||
| 	char **AbsURL); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Creates an action request packet based on its input parameters | ||||
|  * (status variable name and value pair). | ||||
|  * | ||||
|  * Any number of input parameters can be passed to this function but every | ||||
|  * input variable name should have a matching value argument.  | ||||
|  * | ||||
|  * It is a wrapper function that calls makeAction() function to create the | ||||
|  * action request. | ||||
|  *  | ||||
|  * \return The action node of \b Upnp_Document type or <tt>NULL</tt> if the | ||||
|  * 	operation failed. | ||||
|  */ | ||||
| EXPORT_SPEC IXML_Document* UpnpMakeAction( | ||||
| 	/*! [in] Name of the action request or response. */ | ||||
| 	const char *ActionName, | ||||
| 	/*! [in] The service type. */ | ||||
| 	const char *ServType, | ||||
| 	/*! [in] Number of argument pairs to be passed. */ | ||||
| 	int NumArg, | ||||
| 	/*! [in] pointer to the first argument. */ | ||||
| 	const char *Arg, | ||||
| 	/*! [in] Argument list. */ | ||||
| 	...); | ||||
|     IN const char * ActionName, /** The action name. */ | ||||
|     IN const char * ServType,   /** The service type.  */ | ||||
|     IN int NumArg,              /** Number of argument pairs to be passed. */  | ||||
|     IN const char * Arg,        /** Status variable name and value pair. */ | ||||
|     IN ...                   /*  Other status variable name and value pairs. */ | ||||
|     ); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Ceates an action response packet based on its output parameters | ||||
|  * (status variable name and value pair). | ||||
| /** {\bf UpnpAddToAction} creates an action request packet based on its input  | ||||
|  *  parameters (status variable name and value pair). This API is specially  | ||||
|  *  suitable inside a loop to add any number input parameters into an existing | ||||
|  *  action. If no action document exists in the beginning then a  | ||||
|  *  {\bf Upnp_Document} variable initialized with {\tt NULL} should be passed  | ||||
|  *  as a parameter. | ||||
|  * | ||||
|  * Any number of input parameters can be passed to this function but every | ||||
|  * output variable name should have a matching value argument.  | ||||
|  *    | ||||
|  * It is a wrapper function that calls makeAction() function to create the | ||||
|  * action request. | ||||
|  *  | ||||
|  * \return The action node of \b Upnp_Document type or <tt>NULL</tt> if the | ||||
|  * 	operation failed. | ||||
|  */ | ||||
| EXPORT_SPEC IXML_Document *UpnpMakeActionResponse( | ||||
| 	/*! [in] The action name. */ | ||||
| 	const char *ActionName, | ||||
| 	/*! [in] The service type.. */ | ||||
| 	const char *ServType, | ||||
| 	/*! [in] The number of argument pairs passed. */ | ||||
| 	int NumArg, | ||||
| 	/*! [in] The status variable name and value pair. */ | ||||
| 	const char *Arg, | ||||
| 	/*! [in] Other status variable name and value pairs. */ | ||||
| 	...); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds the argument in the action request. | ||||
|  *  | ||||
|  * This API is specially suitable inside a loop to add any number input | ||||
|  * parameters into an existing action. If no action document exists in the | ||||
|  * beginning then a <b>Upnp_Document variable initialized with <tt>NULL</tt></b> | ||||
|  * should be passed as a parameter. | ||||
|  * | ||||
|  * It is a wrapper function that calls addToAction() function to add the | ||||
|  * argument in the action request. | ||||
|  *  | ||||
|  * \return An integer representing one of the following: | ||||
|  *	\li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully. | ||||
|  *	\li <tt>UPNP_E_INVALID_PARAM</tt>: One or more of the parameters are invalid. | ||||
|  *	\li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to | ||||
|  *  @return [int] An integer representing one of the following: | ||||
|  *    \begin{itemize} | ||||
|  *      \item {\tt UPNP_E_SUCCESS}: The operation completed successfully. | ||||
|  *      \item {\tt UPNP_E_INVALID_PARAM}: One or more of the parameters  | ||||
|  *                                        are invalid. | ||||
|  *      \item {\tt UPNP_E_OUTOF_MEMORY}: Insufficient resources exist to  | ||||
|  *              complete this operation. | ||||
|  *    \end{itemize} | ||||
|  */ | ||||
|  | ||||
| EXPORT_SPEC int UpnpAddToAction( | ||||
| 	/*! [in,out] A pointer to store the action document node. */ | ||||
| 	IXML_Document **ActionDoc, | ||||
| 	/*! [in] The action name. */ | ||||
| 	const char *ActionName, | ||||
| 	/*! [in] The service type. */ | ||||
| 	const char *ServType, | ||||
| 	/*! [in] The status variable name. */ | ||||
| 	const char *ArgName, | ||||
| 	/*! [in] The status variable value. */ | ||||
| 	const char *ArgVal); | ||||
|         IN OUT IXML_Document ** ActionDoc,  | ||||
| 	                              /** A pointer to store the action  | ||||
| 				          document node. */ | ||||
|         IN const char * ActionName,   /** The action name. */ | ||||
|         IN const char * ServType,     /** The service type.  */ | ||||
|         IN const char * ArgName,      /** The status variable name. */ | ||||
|         IN const char * ArgVal        /** The status variable value.  */ | ||||
|         ); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Creates an action response packet based on its output parameters | ||||
|  * (status variable name and value pair). | ||||
| /** {\bf UpnpMakeActionResponse} creates an action response packet based  | ||||
|  *  on its output parameters (status variable name and value pair). Any   | ||||
|  *  number of input parameters can be passed to this function but every output | ||||
|  *  variable name should have a matching value argument.  | ||||
|  *    | ||||
|  * This API is especially suitable inside a loop to add any number of input | ||||
|  * parameters into an existing action response. If no action document exists | ||||
|  * in the beginning, a \b Upnp_Document variable initialized with <tt>NULL</tt> | ||||
|  * should be passed as a parameter. | ||||
|  * | ||||
|  * It is a wrapper function that calls addToAction() function to add the | ||||
|  * argument in the action request. | ||||
|  *  | ||||
|  * \return An integer representing one of the following: | ||||
|  *	\li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully. | ||||
|  *	\li <tt>UPNP_E_INVALID_PARAM</tt>: One or more of the parameters are invalid. | ||||
|  *	\li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to | ||||
|  *		complete this operation. | ||||
|  *  @return [IXML_Document*] The action node of {\bf Upnp_Document} type or  | ||||
|  *                           {\tt NULL} if the operation failed. | ||||
|  */ | ||||
|  | ||||
| EXPORT_SPEC IXML_Document* UpnpMakeActionResponse( | ||||
|     IN const char * ActionName, /** The action name. */ | ||||
|     IN const char * ServType,   /** The service type.  */ | ||||
|     IN int NumArg,              /** The number of argument pairs passed. */   | ||||
|     IN const char * Arg,        /** The status variable name and value pair. */ | ||||
|     IN ...                   /*  Other status variable name and value pairs. */ | ||||
|     ); | ||||
|  | ||||
| /** {\bf UpnpAddToActionResponse} creates an action response | ||||
|  *  packet based on its output parameters (status variable name | ||||
|  *  and value pair). This API is especially suitable inside | ||||
|  *  a loop to add any number of input parameters into an existing action  | ||||
|  *  response. If no action document exists in the beginning, a  | ||||
|  *  {\bf Upnp_Document} variable initialized with {\tt NULL} should be passed  | ||||
|  *  as a parameter. | ||||
|  * | ||||
|  *  @return [int] An integer representing one of the following: | ||||
|  *    \begin{itemize} | ||||
|  *      \item {\tt UPNP_E_SUCCESS}: The operation completed successfully. | ||||
|  *      \item {\tt UPNP_E_INVALID_PARAM}: One or more of the parameters  | ||||
|  *                                        are invalid. | ||||
|  *      \item {\tt UPNP_E_OUTOF_MEMORY}: Insufficient resources exist to  | ||||
|  *              complete this operation. | ||||
|  *    \end{itemize} | ||||
|  */ | ||||
|  | ||||
| EXPORT_SPEC int UpnpAddToActionResponse( | ||||
| 	/*! [in,out] Pointer to a document to store the action document node. */ | ||||
|         IXML_Document **ActionResponse,  | ||||
| 	/*! [in] The action name. */ | ||||
|         const char *ActionName, | ||||
| 	/*! [in] The service type. */ | ||||
|         const char *ServType, | ||||
| 	/*! [in] The status variable name. */ | ||||
|         const char *ArgName, | ||||
| 	/*! [in] The status variable value. */ | ||||
|         const char *ArgVal); | ||||
|         IN OUT IXML_Document ** ActionResponse,  | ||||
| 	                                   /** Pointer to a document to  | ||||
| 					       store the action document  | ||||
| 					       node. */ | ||||
|         IN const char * ActionName,        /** The action name. */ | ||||
|         IN const char * ServType,          /** The service type.  */ | ||||
|         IN const char * ArgName,           /** The status variable name. */ | ||||
|         IN const char * ArgVal             /** The status variable value.  */ | ||||
|         ); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Creates a property set message packet. | ||||
| /** {\bf UpnpAddToPropertySet} can be used when an application needs to  | ||||
|  *  transfer the status of many variables at once. It can be used  | ||||
|  *  (inside a loop) to add some extra status variables into an existing | ||||
|  *  property set. If the application does not already have a property | ||||
|  *  set document, the application should create a variable initialized  | ||||
|  *  with {\tt NULL} and pass that as the first parameter. | ||||
|  *   | ||||
|  * Any number of input parameters can be passed to this function but every | ||||
|  * input variable name should have a matching value input argument. | ||||
|  *   | ||||
|  * \return <tt>NULL</tt> on failure, or the property-set document node. | ||||
|  */ | ||||
| EXPORT_SPEC IXML_Document *UpnpCreatePropertySet( | ||||
| 	/*! [in] The number of argument pairs passed. */ | ||||
| 	int NumArg, | ||||
| 	/*! [in] The status variable name and value pair. */ | ||||
| 	const char *Arg, | ||||
| 	/*! [in] Variable sized list with the rest of the parameters. */ | ||||
| 	...); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Can be used when an application needs to transfer the status of many | ||||
|  * variables at once. | ||||
|  * | ||||
|  * It can be used (inside a loop) to add some extra status variables into an | ||||
|  * existing property set. If the application does not already have a property | ||||
|  * set document, the application should create a variable initialized with | ||||
|  * <tt>NULL</tt> and pass that as the first parameter. | ||||
|  *   | ||||
|  * \return An integer representing one of the following: | ||||
|  *	\li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully. | ||||
|  *	\li <tt>UPNP_E_INVALID_PARAM</tt>: One or more of the parameters are invalid. | ||||
|  *	\li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to | ||||
|  *  @return [int] An integer representing one of the following: | ||||
|  *    \begin{itemize} | ||||
|  *      \item {\tt UPNP_E_SUCCESS}: The operation completed successfully. | ||||
|  *      \item {\tt UPNP_E_INVALID_PARAM}: One or more of the parameters  | ||||
|  *                                        are invalid. | ||||
|  *      \item {\tt UPNP_E_OUTOF_MEMORY}: Insufficient resources exist to  | ||||
|  *              complete this operation. | ||||
|  *    \end{itemize} | ||||
|  * | ||||
|  */ | ||||
| EXPORT_SPEC int UpnpAddToPropertySet( | ||||
| 	/*! [in,out] A pointer to the document containing the property set document node. */ | ||||
| 	IXML_Document **PropSet, | ||||
| 	/*! [in] The status variable name. */ | ||||
| 	const char *ArgName, | ||||
| 	/*! [in] The status variable value. */ | ||||
| 	const char *ArgVal); | ||||
|  | ||||
| EXPORT_SPEC int UpnpAddToPropertySet( | ||||
|     IN OUT IXML_Document **PropSet,     | ||||
|                                   /** A pointer to the document containing  | ||||
| 				      the property set document node. */ | ||||
|     IN const char * ArgName,      /** The status variable name. */   | ||||
|     IN const char * ArgVal        /** The status variable value.  */ | ||||
|     ); | ||||
|  | ||||
| /** {\bf UpnpCreatePropertySet} creates a property set   | ||||
|  *  message packet. Any number of input parameters can be passed   | ||||
|  *  to this function but every input variable name should have  | ||||
|  *  a matching value input argument. | ||||
|  *   | ||||
|  *  @return [IXML_Document*] {\tt NULL} on failure, or the property-set  | ||||
|  *                           document node. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| EXPORT_SPEC IXML_Document* UpnpCreatePropertySet( | ||||
|     IN int NumArg,        /** The number of argument pairs passed. */ | ||||
|     IN const char* Arg,   /** The status variable name and value pair. */ | ||||
|     IN ... | ||||
|     ); | ||||
|  | ||||
| /** {\bf UpnpGetErrorMessage} converts an SDK error code into a  | ||||
|  *  string error message suitable for display.  The memory returned | ||||
|  *  from this function should NOT be freed. | ||||
|  * | ||||
|  *  @return [char*] An ASCII text string representation of the error message  | ||||
|  *                  associated with the error code.  | ||||
|  */ | ||||
|  | ||||
| EXPORT_SPEC const char * UpnpGetErrorMessage( | ||||
|         int errorcode  /** The SDK error code to convert. */ | ||||
|         ); | ||||
|  | ||||
| /*! @} */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! @} */ | ||||
|  | ||||
|  | ||||
| #endif /* UPNP_HAVE_TOOLS */ | ||||
|  | ||||
|  | ||||
| #endif /* UPNP_TOOLS_H */ | ||||
|  | ||||
|   | ||||
| @@ -1,97 +0,0 @@ | ||||
| #							-*- Autoconf -*- | ||||
| # This file is part of the aMule project. | ||||
| # This file is part of the libupnp library project. | ||||
| # | ||||
| # Copyright (c) 2003-2008 aMule Team ( admin@amule.org / http://www.amule.org ) | ||||
| # | ||||
| # This program is free software; you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation; either version 2 of the License, or | ||||
| # (at your option) any later version. | ||||
| # | ||||
| # This program is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program; if not, write to the Free Software | ||||
| # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301, USA | ||||
| # | ||||
|  | ||||
| dnl -------------------------------------------------------------------------- | ||||
| dnl LIBUPNP_CHECK([VERSION = 1.6.6], [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) | ||||
| dnl | ||||
| dnl Check for the libupnp library | ||||
| dnl -------------------------------------------------------------------------- | ||||
| dnl | ||||
| dnl This macro sets these variables: | ||||
| dnl - LIBUPNP_VERSION | ||||
| dnl 	Something like "1.6.7" | ||||
| dnl - LIBUPNP_CPPFLAGS | ||||
| dnl 	Flags to be added to CPPFLAGS | ||||
| dnl - LIBUPNP_CFLAGS | ||||
| dnl 	Flags to be added to CFLAGS | ||||
| dnl - LIBUPNP_LDFLAGS | ||||
| dnl 	Flags to be added to LDFLAGS | ||||
| dnl - LIBUPNP_LIBS | ||||
| dnl 	Library to be added to LIBS | ||||
| dnl | ||||
| dnl The LIBUPNP_CPPFLAGS, LIBUPNP_CFLAGS, LIBUPNP_LDFLAGS and LIBUPNP_LIBS variables are also substituted. | ||||
| dnl | ||||
| AC_DEFUN([LIBUPNP_CHECK], | ||||
| [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl | ||||
| m4_define([MIN_LIBUPNP_VERSION], [m4_ifval([$1], [$1], [1.6.6])])dnl | ||||
|  | ||||
| dnl	Test for --with-libupnp-prefix | ||||
| 	AC_ARG_WITH( | ||||
| 		[libupnp-prefix], | ||||
| 		[AS_HELP_STRING( | ||||
| 			[--with-libupnp-prefix=PREFIX], | ||||
| 			[UPnP library location])], | ||||
| 		[export PKG_CONFIG_PATH=$withval/lib/pkgconfig]) | ||||
|  | ||||
| dnl	Check for libupnp >= MIN_LIBUPNP_VERSION | ||||
| 	AS_IF([test $cross_compiling = no], [ | ||||
| 		AC_MSG_CHECKING([for libupnp version >= MIN_LIBUPNP_VERSION]) | ||||
| 		AS_IF([test -n "$PKG_CONFIG"], [ | ||||
| 			AS_IF([$PKG_CONFIG libupnp --exists], [ | ||||
| 				LIBUPNP_VERSION=`$PKG_CONFIG libupnp --modversion` | ||||
| 				AS_IF([$PKG_CONFIG libupnp --atleast-version=MIN_LIBUPNP_VERSION], [ | ||||
| 					result=yes | ||||
| 					resultstr=" (version $LIBUPNP_VERSION)" | ||||
| 					LIBUPNP_CPPFLAGS=`$PKG_CONFIG libupnp --cflags-only-I` | ||||
| 					LIBUPNP_CFLAGS=`$PKG_CONFIG libupnp --cflags-only-other` | ||||
| 					LIBUPNP_LDFLAGS=`$PKG_CONFIG libupnp --libs-only-L` | ||||
| 					LIBUPNP_LIBS=`$PKG_CONFIG libupnp --libs-only-other` | ||||
| 					LIBUPNP_LIBS="$LIBUPNP_LIBS `$PKG_CONFIG libupnp --libs-only-l`" | ||||
| 				], [ | ||||
| 					result=no | ||||
| 					resultstr=" (version $LIBUPNP_VERSION is not new enough)" | ||||
| 				]) | ||||
| 			], [ | ||||
| 				result=no | ||||
| 				resultstr=" (try to use --with-libupnp-prefix=PREFIX)" | ||||
| 			]) | ||||
| 		], [ | ||||
| 			result=no | ||||
| 			resultstr=" (pkg-config not found)" | ||||
| 		]) | ||||
| 		AC_MSG_RESULT([$result$resultstr]) | ||||
| 		libupnp_error="libupnp >= MIN_LIBUPNP_VERSION not found$resultstr" | ||||
| 	], [ | ||||
| dnl Currently cross-compilation with libupnp is not supported. | ||||
| 		result=no | ||||
| 		libupnp_error="cross compiling" | ||||
| 	]) | ||||
|  | ||||
| dnl	Execute the right action. | ||||
| 	AS_IF([test ${result:-no} = yes], [$2], [$3]) | ||||
|  | ||||
| dnl Exported symbols | ||||
| AC_SUBST([LIBUPNP_CPPFLAGS])dnl | ||||
| AC_SUBST([LIBUPNP_CFLAGS])dnl | ||||
| AC_SUBST([LIBUPNP_LDFLAGS])dnl | ||||
| AC_SUBST([LIBUPNP_LIBS])dnl | ||||
| m4_undefine([MIN_LIBUPNP_VERSION])dnl | ||||
| ]) | ||||
| @@ -19,21 +19,21 @@ LDADD = \ | ||||
| noinst_PROGRAMS = | ||||
| if ENABLE_SAMPLES | ||||
| if ENABLE_CLIENT | ||||
| noinst_PROGRAMS += tv_ctrlpt | ||||
| tv_ctrlpt_CPPFLAGS = \ | ||||
| noinst_PROGRAMS += upnp_tv_ctrlpt | ||||
| upnp_tv_ctrlpt_CPPFLAGS = \ | ||||
| 	$(AM_CPPFLAGS) \ | ||||
| 	-I$(srcdir)/common/ \ | ||||
| 	-I$(srcdir)/tvctrlpt | ||||
| if ENABLE_DEVICE | ||||
| noinst_PROGRAMS += tv_combo | ||||
| tv_combo_CPPFLAGS = $(AM_CPPFLAGS) \ | ||||
| noinst_PROGRAMS += upnp_tv_combo | ||||
| upnp_tv_combo_CPPFLAGS = $(AM_CPPFLAGS) \ | ||||
| 	-I$(srcdir)/common/ \ | ||||
| 	-I$(srcdir)/tvcombo | ||||
| endif | ||||
| endif | ||||
| if ENABLE_DEVICE | ||||
| noinst_PROGRAMS += tv_device | ||||
| tv_device_CPPFLAGS = \ | ||||
| noinst_PROGRAMS += upnp_tv_device | ||||
| upnp_tv_device_CPPFLAGS = \ | ||||
| 	$(AM_CPPFLAGS) \ | ||||
| 	-I$(srcdir)/common/ \ | ||||
| 	-I$(srcdir)/tvdevice | ||||
| @@ -41,37 +41,36 @@ endif | ||||
| endif | ||||
|  | ||||
|  | ||||
| tv_device_SOURCES = \ | ||||
| upnp_tv_device_SOURCES = \ | ||||
| 	common/sample_util.c \ | ||||
| 	common/sample_util.h \ | ||||
| 	common/tv_device.c \ | ||||
| 	common/tv_device.h \ | ||||
| 	linux/tv_device_main.c | ||||
| 	tvdevice/upnp_tv_device.c \ | ||||
| 	tvdevice/upnp_tv_device.h \ | ||||
| 	tvdevice/linux/upnp_tv_device_main.c | ||||
|  | ||||
|  | ||||
| tv_ctrlpt_SOURCES = \ | ||||
| upnp_tv_ctrlpt_SOURCES = \ | ||||
| 	common/sample_util.c \ | ||||
| 	common/sample_util.h \ | ||||
| 	common/tv_ctrlpt.c \ | ||||
| 	common/tv_ctrlpt.h \ | ||||
| 	linux/tv_ctrlpt_main.c | ||||
| 	tvctrlpt/upnp_tv_ctrlpt.c \ | ||||
| 	tvctrlpt/upnp_tv_ctrlpt.h \ | ||||
| 	tvctrlpt/linux/upnp_tv_ctrlpt_main.c | ||||
|  | ||||
| tv_combo_SOURCES = \ | ||||
| upnp_tv_combo_SOURCES = \ | ||||
| 	common/sample_util.c \ | ||||
| 	common/sample_util.h \ | ||||
| 	common/tv_ctrlpt.c \ | ||||
| 	common/tv_ctrlpt.h \ | ||||
| 	common/tv_device.c \ | ||||
| 	common/tv_device.h \ | ||||
| 	linux/tv_combo_main.c | ||||
| 	tvcombo/upnp_tv_ctrlpt.c \ | ||||
| 	tvcombo/upnp_tv_ctrlpt.h \ | ||||
| 	tvcombo/upnp_tv_device.c \ | ||||
| 	tvcombo/upnp_tv_device.h \ | ||||
| 	tvcombo/linux/upnp_tv_combo_main.c | ||||
|  | ||||
|  | ||||
| if WITH_DOCUMENTATION | ||||
| examplesdir = $(docdir)/examples | ||||
| examples_DATA = \ | ||||
| 		$(sort \ | ||||
| 			$(tv_ctrlpt_SOURCES) \ | ||||
| 			$(tv_device_SOURCES)) | ||||
| 		$(upnp_tv_ctrlpt_SOURCES) \ | ||||
| 		$(upnp_tv_device_SOURCES) | ||||
| endif | ||||
|  | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,66 +1,54 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef SAMPLE_UTIL_H | ||||
| #define SAMPLE_UTIL_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
| #include "ithread.h" | ||||
| #include "ixml.h" /* for IXML_Document, IXML_Element */ | ||||
| #include "upnp.h" /* for Upnp_EventType */ | ||||
| #include "upnptools.h" | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #ifdef SAMPLE_UTIL_C | ||||
| 	/*! Service types for tv services. */ | ||||
| 	const char *TvServiceType[] = { | ||||
| 		"urn:schemas-upnp-org:service:tvcontrol:1", | ||||
| 		"urn:schemas-upnp-org:service:tvpicture:1" | ||||
| 	}; | ||||
| #else /* SAMPLE_UTIL_C */ | ||||
| 	extern const char *TvServiceType[]; | ||||
| #endif /* SAMPLE_UTIL_C */ | ||||
| #include "ithread.h" | ||||
| #include "ixml.h" | ||||
| #include "upnptools.h" | ||||
|  | ||||
| /* mutex to control displaying of events */ | ||||
|  | ||||
| // mutex to control displaying of events | ||||
| extern ithread_mutex_t display_mutex; | ||||
|  | ||||
|  | ||||
| typedef enum { | ||||
| 	STATE_UPDATE = 0, | ||||
| 	DEVICE_ADDED = 1, | ||||
| @@ -68,196 +56,233 @@ typedef enum { | ||||
| 	GET_VAR_COMPLETE = 3 | ||||
| } eventType; | ||||
|  | ||||
| /*! | ||||
|  * \brief Given a DOM node such as <Channel>11</Channel>, this routine | ||||
|  * extracts the value (e.g., 11) from the node and returns it as  | ||||
|  * a string. The string must be freed by the caller using free. | ||||
|  * | ||||
|  * \return The DOM node as a string. | ||||
|  */ | ||||
| char *SampleUtil_GetElementValue( | ||||
| 	/*! [in] The DOM node from which to extract the value. */ | ||||
| 	IXML_Element *element); | ||||
|  | ||||
| /*! | ||||
|  * \brief Given a DOM node representing a UPnP Device Description Document, | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_GetElementValue | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Given a DOM node such as <Channel>11</Channel>, this routine | ||||
|  *       extracts the value (e.g., 11) from the node and returns it as  | ||||
|  *       a string. The string must be freed by the caller using  | ||||
|  *       free. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   node -- The DOM node from which to extract the value | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| char *SampleUtil_GetElementValue(IN IXML_Element *element); | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_GetFirstServiceList | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Given a DOM node representing a UPnP Device Description Document, | ||||
|  *       this routine parses the document and finds the first service list | ||||
|  *       (i.e., the service list for the root device).  The service list | ||||
|  *       is returned as a DOM node list. The NodeList must be freed using | ||||
|  *       NodeList_free. | ||||
|  * | ||||
|  * \return The service list is returned as a DOM node list. | ||||
|  */ | ||||
| IXML_NodeList *SampleUtil_GetFirstServiceList( | ||||
| 	/*! [in] The DOM node from which to extract the service list. */ | ||||
| 	IXML_Document *doc);  | ||||
|  * Parameters: | ||||
|  *   node -- The DOM node from which to extract the service list | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
|  | ||||
| /*! | ||||
|  * \brief Given a document node, this routine searches for the first element | ||||
| IXML_NodeList *SampleUtil_GetFirstServiceList(IN IXML_Document *doc);  | ||||
|  | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_GetFirstDocumentItem | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Given a document node, this routine searches for the first element | ||||
|  *       named by the input string item, and returns its value as a string. | ||||
|  *       String must be freed by caller using free. | ||||
|  */ | ||||
| char *SampleUtil_GetFirstDocumentItem( | ||||
| 	/*! [in] The DOM document from which to extract the value. */ | ||||
| 	IXML_Document *doc, | ||||
| 	/*! [in] The item to search for. */ | ||||
| 	const char *item);  | ||||
|  * Parameters: | ||||
|  *   doc -- The DOM document from which to extract the value | ||||
|  *   item -- The item to search for | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| char *SampleUtil_GetFirstDocumentItem(IN IXML_Document *doc, IN const char *item);  | ||||
|  | ||||
| /*! | ||||
|  * \brief Given a DOM element, this routine searches for the first element | ||||
|  | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_GetFirstElementItem | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Given a DOM element, this routine searches for the first element | ||||
|  *       named by the input string item, and returns its value as a string. | ||||
|  *       The string must be freed using free. | ||||
|  */ | ||||
| char *SampleUtil_GetFirstElementItem( | ||||
| 	/*! [in] The DOM element from which to extract the value. */ | ||||
| 	IXML_Element *element, | ||||
| 	/*! [in] The item to search for. */ | ||||
| 	const char *item);  | ||||
|  * Parameters: | ||||
|  *   node -- The DOM element from which to extract the value | ||||
|  *   item -- The item to search for | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| char *SampleUtil_GetFirstElementItem(IN IXML_Element *element, IN const char *item);  | ||||
|  | ||||
| /*! | ||||
|  * \brief Prints a callback event type as a string. | ||||
|  */ | ||||
| void SampleUtil_PrintEventType( | ||||
| 	/*! [in] The callback event. */ | ||||
| 	Upnp_EventType S); | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_PrintEventType | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Prints a callback event type as a string. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   S -- The callback event | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| void SampleUtil_PrintEventType(IN Upnp_EventType S); | ||||
|  | ||||
| /*! | ||||
|  * \brief Prints callback event structure details. | ||||
|  */ | ||||
| int SampleUtil_PrintEvent( | ||||
| 	/*! [in] The type of callback event. */ | ||||
| 	Upnp_EventType EventType,  | ||||
| 	/*! [in] The callback event structure. */ | ||||
| 	void *Event); | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_PrintEvent | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Prints callback event structure details. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   EventType -- The type of callback event | ||||
|  *   Event -- The callback event structure | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| int SampleUtil_PrintEvent(IN Upnp_EventType EventType,  | ||||
| 			  IN void *Event); | ||||
|  | ||||
| /*! | ||||
|  * \brief This routine finds the first occurance of a service in a DOM | ||||
|  * representation of a description document and parses it.  Note that this | ||||
|  * function currently assumes that the eventURL and controlURL values in | ||||
|  * the service definitions are full URLs.  Relative URLs are not handled here. | ||||
|  */ | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_FindAndParseService | ||||
|  * | ||||
|  * Description:  | ||||
|  *       This routine finds the first occurance of a service in a DOM representation | ||||
|  *       of a description document and parses it.  Note that this function currently | ||||
|  *       assumes that the eventURL and controlURL values in the service definitions | ||||
|  *       are full URLs.  Relative URLs are not handled here. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   DescDoc -- The DOM description document | ||||
|  *   location -- The location of the description document | ||||
|  *   serviceSearchType -- The type of service to search for | ||||
|  *   serviceId -- OUT -- The service ID | ||||
|  *   eventURL -- OUT -- The event URL for the service | ||||
|  *   controlURL -- OUT -- The control URL for the service | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| int SampleUtil_FindAndParseService ( | ||||
| 	/*! [in] The DOM description document. */ | ||||
| 	IXML_Document *DescDoc, | ||||
| 	/*! [in] The location of the description document. */ | ||||
| 	const char *location,  | ||||
| 	/*! [in] The type of service to search for. */ | ||||
| 	const char *serviceType, | ||||
| 	/*! [out] The service ID. */ | ||||
| 	char **serviceId,  | ||||
| 	/*! [out] The event URL for the service. */ | ||||
| 	char **eventURL, | ||||
| 	/*! [out] The control URL for the service. */ | ||||
| 	char **controlURL); | ||||
| 	IN IXML_Document *DescDoc, | ||||
| 	IN char* location,  | ||||
| 	IN char *serviceType, | ||||
| 	OUT char **serviceId,  | ||||
| 	OUT char **eventURL, | ||||
| 	OUT char **controlURL); | ||||
|  | ||||
| /*! | ||||
|  * \brief Prototype for displaying strings. All printing done by the device, | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * print_string | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Prototype for displaying strings. All printing done by the device, | ||||
|  *       control point, and sample util, ultimately use this to display strings  | ||||
|  *       to the user. | ||||
|  */ | ||||
| typedef void (*print_string)( | ||||
| 	/*! [in] Format. */ | ||||
| 	const char *string, | ||||
| 	/*! [in] Arguments. */ | ||||
| 	...) | ||||
| #if (__GNUC__ >= 3) | ||||
| 	/* This enables printf like format checking by the compiler */ | ||||
| 	__attribute__((format (__printf__, 1, 2))) | ||||
| #endif | ||||
| ; | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   const char * string. | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| typedef void (*print_string)(const char *string); | ||||
|  | ||||
| /*! global print function used by sample util */ | ||||
| //global print function used by sample util | ||||
| extern print_string gPrintFun; | ||||
|  | ||||
| /*! | ||||
|  * \brief Prototype for passing back state changes. | ||||
|  */ | ||||
| /******************************************************************************** | ||||
|  * state_update | ||||
|  * | ||||
|  * Description:  | ||||
|  *     Prototype for passing back state changes | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   const char * varName | ||||
|  *   const char * varValue | ||||
|  *   const char * UDN | ||||
|  *   int          newDevice | ||||
|  ********************************************************************************/ | ||||
| typedef void (*state_update)( | ||||
| 	/*! [in] . */ | ||||
| 	const char *varName, | ||||
| 	/*! [in] . */ | ||||
| 	const char *varValue, | ||||
| 	/*! [in] . */ | ||||
| 	const char *UDN, | ||||
| 	/*! [in] . */ | ||||
| 	eventType type); | ||||
|  | ||||
| /*! global state update function used by smaple util */ | ||||
| //global state update function used by smaple util | ||||
| extern state_update gStateUpdateFun; | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes the sample util. Must be called before any sample util | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_Initialize | ||||
|  * | ||||
|  * Description:  | ||||
|  *     Initializes the sample util. Must be called before any sample util  | ||||
|  *     functions. May be called multiple times. | ||||
|  */ | ||||
| int SampleUtil_Initialize( | ||||
| 	/*! [in] Print function to use in SampleUtil_Print. */ | ||||
| 	print_string print_function); | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   print_function - print function to use in SampleUtil_Print | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| int SampleUtil_Initialize(print_string print_function); | ||||
|  | ||||
| /*! | ||||
|  * \brief Releases Resources held by sample util. | ||||
|  */ | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_Finish | ||||
|  * | ||||
|  * Description:  | ||||
|  *     Releases Resources held by sample util. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| int SampleUtil_Finish(); | ||||
|  | ||||
| /*! | ||||
|  * \brief Function emulating printf that ultimately calls the registered print | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_Print | ||||
|  * | ||||
|  * Description:  | ||||
|  *     Function emulating printf that ultimately calls the registered print  | ||||
|  *     function with the formatted string. | ||||
|  * | ||||
|  * Provides platform-specific print functionality.  This function should be | ||||
|  * called when you want to print content suitable for console output (i.e., | ||||
|  * in a large text box or on a screen).  If your device/operating system is  | ||||
|  * not supported here, you should add a port. | ||||
|  * Parameters: | ||||
|  *   fmt - format (see printf) | ||||
|  *   . . .  - variable number of args. (see printf) | ||||
|  * | ||||
|  * \return The same as printf. | ||||
|  */ | ||||
| int SampleUtil_Print( | ||||
| 	/*! [in] Format (see printf). */ | ||||
| 	const char *fmt, | ||||
| 	/*! [in] Format data. */ | ||||
| 	...) | ||||
| #if (__GNUC__ >= 3) | ||||
| 	/* This enables printf like format checking by the compiler */ | ||||
| 	__attribute__((format (__printf__, 1, 2))) | ||||
| #endif | ||||
| ; | ||||
|  ********************************************************************************/ | ||||
| int SampleUtil_Print(char *fmt, ...); | ||||
|  | ||||
| /*! | ||||
|  * \brief | ||||
|  */ | ||||
| int SampleUtil_RegisterUpdateFunction( | ||||
| 	/*! [in] . */ | ||||
| 	state_update update_function); | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_RegisterUpdateFunction | ||||
|  * | ||||
|  * Description:  | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| int SampleUtil_RegisterUpdateFunction(state_update update_function); | ||||
|  | ||||
| /*! | ||||
|  * \brief | ||||
|  */ | ||||
| /******************************************************************************** | ||||
|  * SampleUtil_StateUpdate | ||||
|  * | ||||
|  * Description:  | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| void SampleUtil_StateUpdate( | ||||
| 	/*! [in] . */ | ||||
| 	const char *varName, | ||||
| 	/*! [in] . */ | ||||
| 	const char *varValue, | ||||
| 	/*! [in] . */ | ||||
| 	const char *UDN, | ||||
| 	/*! [in] . */ | ||||
| 	eventType type); | ||||
|  | ||||
| /*! | ||||
|  * \brief Prints a string to standard out. | ||||
|  */ | ||||
| void linux_print(const char *format, ...) | ||||
| #if (__GNUC__ >= 3) | ||||
| 	/* This enables printf like format checking by the compiler */ | ||||
| 	__attribute__((format (__printf__, 1, 2))) | ||||
| #endif | ||||
| ; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| }; | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	#define snprintf	_snprintf | ||||
| 	#define strcasecmp	stricmp | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #endif /* SAMPLE_UTIL_H */ | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,222 +0,0 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
|  | ||||
| #ifndef UPNP_TV_CTRLPT_H | ||||
| #define UPNP_TV_CTRLPT_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include "sample_util.h" | ||||
|  | ||||
| #include "ithread.h" | ||||
| #include "upnp.h" | ||||
| #include "UpnpString.h" | ||||
| #include "upnptools.h" | ||||
|  | ||||
| #include <signal.h> | ||||
| #include <stdarg.h> | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	/* Do not #include <unistd.h> */ | ||||
| #else | ||||
| 	#include <unistd.h> | ||||
| #endif | ||||
|  | ||||
| #define TV_SERVICE_SERVCOUNT	2 | ||||
| #define TV_SERVICE_CONTROL	0 | ||||
| #define TV_SERVICE_PICTURE	1 | ||||
|  | ||||
| #define TV_CONTROL_VARCOUNT	3 | ||||
| #define TV_CONTROL_POWER	0 | ||||
| #define TV_CONTROL_CHANNEL	1 | ||||
| #define TV_CONTROL_VOLUME	2 | ||||
|  | ||||
| #define TV_PICTURE_VARCOUNT	4 | ||||
| #define TV_PICTURE_COLOR	0 | ||||
| #define TV_PICTURE_TINT		1 | ||||
| #define TV_PICTURE_CONTRAST	2 | ||||
| #define TV_PICTURE_BRIGHTNESS	3 | ||||
|  | ||||
| #define TV_MAX_VAL_LEN		5 | ||||
|  | ||||
| #define TV_SUCCESS		0 | ||||
| #define TV_ERROR		(-1) | ||||
| #define TV_WARNING		1 | ||||
|  | ||||
| /* This should be the maximum VARCOUNT from above */ | ||||
| #define TV_MAXVARS		TV_PICTURE_VARCOUNT | ||||
|  | ||||
| extern const char *TvServiceName[]; | ||||
| extern const char *TvVarName[TV_SERVICE_SERVCOUNT][TV_MAXVARS]; | ||||
| extern char TvVarCount[]; | ||||
|  | ||||
| struct tv_service { | ||||
|     char ServiceId[NAME_SIZE]; | ||||
|     char ServiceType[NAME_SIZE]; | ||||
|     char *VariableStrVal[TV_MAXVARS]; | ||||
|     char EventURL[NAME_SIZE]; | ||||
|     char ControlURL[NAME_SIZE]; | ||||
|     char SID[NAME_SIZE]; | ||||
| }; | ||||
|  | ||||
| extern struct TvDeviceNode *GlobalDeviceList; | ||||
|  | ||||
| struct TvDevice { | ||||
|     char UDN[250]; | ||||
|     char DescDocURL[250]; | ||||
|     char FriendlyName[250]; | ||||
|     char PresURL[250]; | ||||
|     int  AdvrTimeOut; | ||||
|     struct tv_service TvService[TV_SERVICE_SERVCOUNT]; | ||||
| }; | ||||
|  | ||||
| struct TvDeviceNode { | ||||
|     struct TvDevice device; | ||||
|     struct TvDeviceNode *next; | ||||
| }; | ||||
|  | ||||
| extern ithread_mutex_t DeviceListMutex; | ||||
|  | ||||
| extern UpnpClient_Handle ctrlpt_handle; | ||||
|  | ||||
| void	TvCtrlPointPrintHelp(void); | ||||
| int		TvCtrlPointDeleteNode(struct TvDeviceNode *); | ||||
| int		TvCtrlPointRemoveDevice(const char *); | ||||
| int		TvCtrlPointRemoveAll(void); | ||||
| int		TvCtrlPointRefresh(void); | ||||
|  | ||||
| int		TvCtrlPointSendAction(int, int, const char *, const char **, char **, int); | ||||
| int		TvCtrlPointSendActionNumericArg(int devnum, int service, const char *actionName, const char *paramName, int paramValue); | ||||
| int		TvCtrlPointSendPowerOn(int devnum); | ||||
| int		TvCtrlPointSendPowerOff(int devnum); | ||||
| int		TvCtrlPointSendSetChannel(int, int); | ||||
| int		TvCtrlPointSendSetVolume(int, int); | ||||
| int		TvCtrlPointSendSetColor(int, int); | ||||
| int		TvCtrlPointSendSetTint(int, int); | ||||
| int		TvCtrlPointSendSetContrast(int, int); | ||||
| int		TvCtrlPointSendSetBrightness(int, int); | ||||
|  | ||||
| int		TvCtrlPointGetVar(int, int, const char *); | ||||
| int		TvCtrlPointGetPower(int devnum); | ||||
| int		TvCtrlPointGetChannel(int); | ||||
| int		TvCtrlPointGetVolume(int); | ||||
| int		TvCtrlPointGetColor(int); | ||||
| int		TvCtrlPointGetTint(int); | ||||
| int		TvCtrlPointGetContrast(int); | ||||
| int		TvCtrlPointGetBrightness(int); | ||||
|  | ||||
| int		TvCtrlPointGetDevice(int, struct TvDeviceNode **); | ||||
| int		TvCtrlPointPrintList(void); | ||||
| int		TvCtrlPointPrintDevice(int); | ||||
| void	TvCtrlPointAddDevice(IXML_Document *, const char *, int);  | ||||
| void    TvCtrlPointHandleGetVar(const char *, const char *, const DOMString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Update a Tv state table. Called when an event is received. | ||||
|  * | ||||
|  * Note: this function is NOT thread save. It must be called from another | ||||
|  * function that has locked the global device list. | ||||
|  **/ | ||||
| void TvStateUpdate( | ||||
| 	/*! [in] The UDN of the parent device. */ | ||||
| 	char *UDN, | ||||
| 	/*! [in] The service state table to update. */ | ||||
| 	int Service, | ||||
| 	/*! [out] DOM document representing the XML received with the event. */ | ||||
| 	IXML_Document *ChangedVariables, | ||||
| 	/*! [out] pointer to the state table for the Tv  service to update. */ | ||||
| 	char **State); | ||||
|  | ||||
| void	TvCtrlPointHandleEvent(const char *, int, IXML_Document *);  | ||||
| void	TvCtrlPointHandleSubscribeUpdate(const char *, const Upnp_SID, int);  | ||||
| int		TvCtrlPointCallbackEventHandler(Upnp_EventType, void *, void *); | ||||
|  | ||||
| /*! | ||||
|  * \brief Checks the advertisement each device in the global device list. | ||||
|  * | ||||
|  * If an advertisement expires, the device is removed from the list. | ||||
|  * | ||||
|  * If an advertisement is about to expire, a search request is sent for that | ||||
|  * device. | ||||
|  */ | ||||
| void TvCtrlPointVerifyTimeouts( | ||||
| 	/*! [in] The increment to subtract from the timeouts each time the | ||||
| 	 * function is called. */ | ||||
| 	int incr); | ||||
|  | ||||
| void	TvCtrlPointPrintCommands(void); | ||||
| void*	TvCtrlPointCommandLoop(void *); | ||||
| int		TvCtrlPointStart(print_string printFunctionPtr, state_update updateFunctionPtr, int combo); | ||||
| int		TvCtrlPointStop(void); | ||||
| int		TvCtrlPointProcessCommand(char *cmdline); | ||||
|  | ||||
| /*! | ||||
|  * \brief Print help info for this application. | ||||
|  */ | ||||
| void TvCtrlPointPrintShortHelp(void); | ||||
|  | ||||
| /*! | ||||
|  * \brief Print long help info for this application. | ||||
|  */ | ||||
| void TvCtrlPointPrintLongHelp(void); | ||||
|  | ||||
| /*! | ||||
|  * \briefPrint the list of valid command line commands to the user | ||||
|  */ | ||||
| void TvCtrlPointPrintCommands(void); | ||||
|  | ||||
| /*! | ||||
|  * \brief Function that receives commands from the user at the command prompt | ||||
|  * during the lifetime of the device, and calls the appropriate | ||||
|  * functions for those commands. | ||||
|  */ | ||||
| void *TvCtrlPointCommandLoop(void *args); | ||||
|  | ||||
| /*! | ||||
|  * \brief | ||||
|  */ | ||||
| int TvCtrlPointProcessCommand(char *cmdline); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| #endif /* UPNP_TV_CTRLPT_H */ | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,566 +0,0 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
|  | ||||
| #ifndef UPNP_TV_DEVICE_H | ||||
| #define UPNP_TV_DEVICE_H | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <signal.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include "sample_util.h" | ||||
|  | ||||
| #include "ithread.h" | ||||
| #include "upnp.h" | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	/* Do not #include <unistd.h> */ | ||||
| #else | ||||
| 	#include <unistd.h> | ||||
| #endif | ||||
|  | ||||
| /*! Color constants */ | ||||
| #define MAX_COLOR 10 | ||||
| #define MIN_COLOR 1 | ||||
|  | ||||
| /*! Brightness constants */ | ||||
| #define MAX_BRIGHTNESS 10 | ||||
| #define MIN_BRIGHTNESS 1 | ||||
|  | ||||
| /*! Power constants */ | ||||
| #define POWER_ON 1 | ||||
| #define POWER_OFF 0 | ||||
|  | ||||
| /*! Tint constants */ | ||||
| #define MAX_TINT 10 | ||||
| #define MIN_TINT 1 | ||||
|  | ||||
| /*! Volume constants */ | ||||
| #define MAX_VOLUME 10 | ||||
| #define MIN_VOLUME 1 | ||||
|  | ||||
| /*! Contrast constants */ | ||||
| #define MAX_CONTRAST 10 | ||||
| #define MIN_CONTRAST 1 | ||||
|  | ||||
| /*! Channel constants */ | ||||
| #define MAX_CHANNEL 100 | ||||
| #define MIN_CHANNEL 1 | ||||
|  | ||||
| /*! Number of services. */ | ||||
| #define TV_SERVICE_SERVCOUNT  2 | ||||
|  | ||||
| /*! Index of control service */ | ||||
| #define TV_SERVICE_CONTROL    0 | ||||
|  | ||||
| /*! Index of picture service */ | ||||
| #define TV_SERVICE_PICTURE    1 | ||||
|  | ||||
| /*! Number of control variables */ | ||||
| #define TV_CONTROL_VARCOUNT   3 | ||||
|  | ||||
| /*! Index of power variable */ | ||||
| #define TV_CONTROL_POWER      0 | ||||
|  | ||||
| /*! Index of channel variable */ | ||||
| #define TV_CONTROL_CHANNEL    1 | ||||
|  | ||||
| /*! Index of volume variable */ | ||||
| #define TV_CONTROL_VOLUME     2 | ||||
|  | ||||
| /*! Number of picture variables */ | ||||
| #define TV_PICTURE_VARCOUNT   4 | ||||
|  | ||||
| /*! Index of color variable */ | ||||
| #define TV_PICTURE_COLOR      0 | ||||
|  | ||||
| /*! Index of tint variable */ | ||||
| #define TV_PICTURE_TINT       1 | ||||
|  | ||||
| /*! Index of contrast variable */ | ||||
| #define TV_PICTURE_CONTRAST   2 | ||||
|  | ||||
| /*! Index of brightness variable */ | ||||
| #define TV_PICTURE_BRIGHTNESS 3 | ||||
|  | ||||
| /*! Max value length */ | ||||
| #define TV_MAX_VAL_LEN 5 | ||||
|  | ||||
| /*! Max actions */ | ||||
| #define TV_MAXACTIONS 12 | ||||
|  | ||||
| /*! This should be the maximum VARCOUNT from above */ | ||||
| #define TV_MAXVARS TV_PICTURE_VARCOUNT | ||||
|  | ||||
| /*! | ||||
|  * \brief Prototype for all actions. For each action that a service  | ||||
|  * implements, there is a corresponding function with this prototype. | ||||
|  * | ||||
|  * Pointers to these functions, along with action names, are stored | ||||
|  * in the service table. When an action request comes in the action | ||||
|  * name is matched, and the appropriate function is called. | ||||
|  * Each function returns UPNP_E_SUCCESS, on success, and a nonzero  | ||||
|  * error code on failure. | ||||
|  */ | ||||
| typedef int (*upnp_action)( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *request, | ||||
| 	/*! [out] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] Error string in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! Structure for storing Tv Service identifiers and state table. */ | ||||
| struct TvService { | ||||
| 	/*! Universally Unique Device Name. */ | ||||
| 	char UDN[NAME_SIZE]; | ||||
| 	/*! . */ | ||||
| 	char ServiceId[NAME_SIZE]; | ||||
| 	/*! . */ | ||||
| 	char ServiceType[NAME_SIZE]; | ||||
| 	/*! . */ | ||||
| 	const char *VariableName[TV_MAXVARS];  | ||||
| 	/*! . */ | ||||
| 	char *VariableStrVal[TV_MAXVARS]; | ||||
| 	/*! . */ | ||||
| 	const char *ActionNames[TV_MAXACTIONS]; | ||||
| 	/*! . */ | ||||
| 	upnp_action actions[TV_MAXACTIONS]; | ||||
| 	/*! . */ | ||||
| 	int VariableCount; | ||||
| }; | ||||
|  | ||||
| /*! Array of service structures */ | ||||
| extern struct TvService tv_service_table[]; | ||||
|  | ||||
| /*! Device handle returned from sdk */ | ||||
| extern UpnpDevice_Handle device_handle; | ||||
|  | ||||
| /*! Mutex for protecting the global state table data | ||||
|  * in a multi-threaded, asynchronous environment. | ||||
|  * All functions should lock this mutex before reading | ||||
|  * or writing the state table data. */ | ||||
| extern ithread_mutex_t TVDevMutex; | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes the action table for the specified service. | ||||
|  * | ||||
|  * Note that knowledge of the service description is assumed. | ||||
|  * Action names are hardcoded. | ||||
|  */ | ||||
| int SetActionTable( | ||||
| 	/*! [in] one of TV_SERVICE_CONTROL or, TV_SERVICE_PICTURE. */ | ||||
| 	int serviceType, | ||||
| 	/*! [in,out] service containing action table to set. */ | ||||
| 	struct TvService *out); | ||||
|  | ||||
| /*! | ||||
|  * \brief Initialize the device state table for this TvDevice, pulling | ||||
|  * identifier info from the description Document. | ||||
|  * | ||||
|  * Note that knowledge of the service description is assumed. | ||||
|  * State table variables and default values are currently hardcoded in | ||||
|  * this file rather than being read from service description documents. | ||||
|  */ | ||||
| int TvDeviceStateTableInit( | ||||
| 	/*! [in] The description document URL. */ | ||||
| 	char *DescDocURL); | ||||
|  | ||||
| /*! | ||||
|  * \brief Called during a subscription request callback. | ||||
|  * | ||||
|  * If the subscription request is for this device and either its | ||||
|  * control service or picture service, then accept it. | ||||
|  */ | ||||
| int TvDeviceHandleSubscriptionRequest( | ||||
| 	/*! [in] The subscription request event structure. */ | ||||
| 	struct Upnp_Subscription_Request *sr_event); | ||||
|  | ||||
| /*! | ||||
|  * \brief Called during a get variable request callback. | ||||
|  * | ||||
|  * If the request is for this device and either its control service or | ||||
|  * picture service, then respond with the variable value. | ||||
|  */ | ||||
| int TvDeviceHandleGetVarRequest( | ||||
| 	/*! [in,out] The control get variable request event structure. */ | ||||
| 	struct Upnp_State_Var_Request *cgv_event); | ||||
|  | ||||
| /*! | ||||
|  * \brief Called during an action request callback. | ||||
|  * | ||||
|  * If the request is for this device and either its control service | ||||
|  * or picture service, then perform the action and respond. | ||||
|  */ | ||||
| int TvDeviceHandleActionRequest( | ||||
| 	/*! [in,out] The control action request event structure. */ | ||||
| 	struct Upnp_Action_Request *ca_event); | ||||
|  | ||||
| /*! | ||||
|  * \brief The callback handler registered with the SDK while registering | ||||
|  * root device. | ||||
|  * | ||||
|  * Dispatches the request to the appropriate procedure | ||||
|  * based on the value of EventType. The four requests handled by the  | ||||
|  * device are:  | ||||
|  *	\li 1) Event Subscription requests.   | ||||
|  *	\li 2) Get Variable requests.  | ||||
|  *	\li 3) Action requests. | ||||
|  */ | ||||
| int TvDeviceCallbackEventHandler( | ||||
| 	/*! [in] The type of callback event. */ | ||||
| 	Upnp_EventType, | ||||
| 	/*! [in] Data structure containing event data. */ | ||||
| 	void *Event, | ||||
| 	/*! [in] Optional data specified during callback registration. */ | ||||
| 	void *Cookie); | ||||
|  | ||||
| /*! | ||||
|  * \brief Update the TvDevice service state table, and notify all subscribed | ||||
|  * control points of the updated state. | ||||
|  * | ||||
|  * Note that since this function blocks on the mutex TVDevMutex, | ||||
|  * to avoid a hang this function should not be called within any other | ||||
|  * function that currently has this mutex locked. | ||||
|  */ | ||||
| int TvDeviceSetServiceTableVar( | ||||
| 	/*! [in] The service number (TV_SERVICE_CONTROL or TV_SERVICE_PICTURE). */ | ||||
| 	unsigned int service, | ||||
| 	/*! [in] The variable number (TV_CONTROL_POWER, TV_CONTROL_CHANNEL, | ||||
| 	 * TV_CONTROL_VOLUME, TV_PICTURE_COLOR, TV_PICTURE_TINT, | ||||
| 	 * TV_PICTURE_CONTRAST, or TV_PICTURE_BRIGHTNESS). */ | ||||
| 	int variable, | ||||
| 	/*! [in] The string representation of the new value. */ | ||||
| 	char *value); | ||||
|  | ||||
| /* Control Service Actions */ | ||||
|  | ||||
| /*! | ||||
|  * \brief Turn the power on. | ||||
|  */ | ||||
| int TvDevicePowerOn( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Turn the power off. | ||||
|  */ | ||||
| int TvDevicePowerOff( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Change the channel, update the TvDevice control service | ||||
|  * state table, and notify all subscribed control points of the | ||||
|  * updated state. | ||||
|  */ | ||||
| int TvDeviceSetChannel( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Increase the channel.   | ||||
|  */ | ||||
| int TvDeviceIncreaseChannel( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Decrease the channel.   | ||||
|  */ | ||||
| int TvDeviceDecreaseChannel( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Change the volume, update the TvDevice control service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  */ | ||||
| int TvDeviceSetVolume( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Increase the volume.  | ||||
|  */ | ||||
| int TvDeviceIncreaseVolume( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Decrease the volume. | ||||
|  */ | ||||
| int TvDeviceDecreaseVolume( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*Picture Service Actions */ | ||||
|  | ||||
| /*! | ||||
|  * \brief Change the color, update the TvDevice picture service | ||||
|  * state table, and notify all subscribed control points of the | ||||
|  * updated state. | ||||
|  */ | ||||
| int TvDeviceSetColor( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Increase the color. | ||||
|  */ | ||||
| int TvDeviceIncreaseColor( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Decrease the color.   | ||||
|  */ | ||||
| int TvDeviceDecreaseColor( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Change the tint, update the TvDevice picture service | ||||
|  * state table, and notify all subscribed control points of the | ||||
|  * updated state. | ||||
|  */ | ||||
| int TvDeviceSetTint( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Increase tint. | ||||
|  */ | ||||
| int TvDeviceIncreaseTint( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Decrease tint. | ||||
|  */ | ||||
| int TvDeviceDecreaseTint( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Change the contrast, update the TvDevice picture service | ||||
|  * state table, and notify all subscribed control points of the | ||||
|  * updated state. | ||||
|  */ | ||||
| int TvDeviceSetContrast( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Increase the contrast. | ||||
|  */ | ||||
| int TvDeviceIncreaseContrast( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Decrease the contrast. | ||||
|  */ | ||||
| int TvDeviceDecreaseContrast( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Change the brightness, update the TvDevice picture service | ||||
|  * state table, and notify all subscribed control points of the | ||||
|  * updated state. | ||||
|  */ | ||||
| int TvDeviceSetBrightness( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Increase brightnesss. | ||||
|  */ | ||||
| int TvDeviceIncreaseBrightness( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Decrease brightnesss. | ||||
|  */ | ||||
| int TvDeviceDecreaseBrightness( | ||||
| 	/*! [in] Document of action request. */ | ||||
| 	IXML_Document *in, | ||||
| 	/*! [in] Action result. */ | ||||
| 	IXML_Document **out, | ||||
| 	/*! [out] ErrorString in case action was unsuccessful. */ | ||||
| 	const char **errorString); | ||||
|  | ||||
| /*! | ||||
|  * \brief Initializes the UPnP Sdk, registers the device, and sends out | ||||
|  * advertisements. | ||||
|  */ | ||||
| int TvDeviceStart( | ||||
| 	/*! [in] ip address to initialize the sdk (may be NULL) | ||||
| 	 * if null, then the first non null loopback address is used. */ | ||||
| 	char *ip_address, | ||||
| 	/*! [in] port number to initialize the sdk (may be 0) | ||||
| 	 * if zero, then a random number is used. */ | ||||
| 	unsigned short port, | ||||
| 	/*! [in] name of description document. | ||||
| 	 * may be NULL. Default is tvdevicedesc.xml. */ | ||||
| 	const char *desc_doc_name, | ||||
| 	/*! [in] path of web directory. | ||||
| 	 * may be NULL. Default is ./web (for Linux) or ../tvdevice/web. */ | ||||
| 	const char *web_dir_path, | ||||
| 	/*! [in] print function to use. */ | ||||
| 	print_string pfun, | ||||
| 	/*! [in] Non-zero if called from the combo application. */ | ||||
| 	int combo); | ||||
|  | ||||
| /*! | ||||
|  * \brief Stops the device. Uninitializes the sdk. | ||||
|  */ | ||||
| int TvDeviceStop(void); | ||||
|  | ||||
| /*! | ||||
|  * \brief Function that receives commands from the user at the command prompt | ||||
|  * during the lifetime of the device, and calls the appropriate | ||||
|  * functions for those commands. Only one command, exit, is currently | ||||
|  * defined. | ||||
|  */ | ||||
| void *TvDeviceCommandLoop(void *args); | ||||
|  | ||||
| /*! | ||||
|  * \brief Main entry point for tv device application. | ||||
|  * | ||||
|  * Initializes and registers with the sdk. | ||||
|  * Initializes the state stables of the service. | ||||
|  * Starts the command loop. | ||||
|  * | ||||
|  * Accepts the following optional arguments: | ||||
|  *	\li \c -ip ipaddress | ||||
|  *	\li \c -port port | ||||
|  *	\li \c -desc desc_doc_name | ||||
|  *	\li \c -webdir web_dir_path | ||||
|  *	\li \c -help | ||||
|  */ | ||||
| int device_main(int argc, char *argv[]); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| @@ -1,72 +0,0 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| #include "sample_util.h" | ||||
| #include "tv_ctrlpt.h" | ||||
| #include "tv_device.h" | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
|  | ||||
| int main(int argc, char *argv[]) | ||||
| { | ||||
| 	int rc; | ||||
| 	ithread_t cmdloop_thread; | ||||
| #ifdef WIN32 | ||||
| #else | ||||
| 	int sig; | ||||
| 	sigset_t sigs_to_catch; | ||||
| #endif | ||||
| 	int code; | ||||
|  | ||||
| 	device_main(argc, argv); | ||||
| 	rc = TvCtrlPointStart(linux_print, NULL, 1); | ||||
| 	if (rc != TV_SUCCESS) { | ||||
| 		SampleUtil_Print("Error starting UPnP TV Control Point\n"); | ||||
| 		return rc; | ||||
| 	} | ||||
| 	/* start a command loop thread */ | ||||
| 	code = ithread_create(&cmdloop_thread, NULL, TvCtrlPointCommandLoop, NULL); | ||||
| #ifdef WIN32 | ||||
| 	ithread_join(cmdloop_thread, NULL); | ||||
| #else | ||||
| 	/* Catch Ctrl-C and properly shutdown */ | ||||
| 	sigemptyset(&sigs_to_catch); | ||||
| 	sigaddset(&sigs_to_catch, SIGINT); | ||||
| 	sigwait(&sigs_to_catch, &sig); | ||||
| 	SampleUtil_Print("Shutting down on signal %d...\n", sig); | ||||
| #endif | ||||
| 	TvDeviceStop(); | ||||
| 	rc = TvCtrlPointStop(); | ||||
|  | ||||
| 	return rc; | ||||
| } | ||||
|  | ||||
| @@ -1,72 +0,0 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| #include "sample_util.h" | ||||
| #include "tv_ctrlpt.h" | ||||
|  | ||||
| #include <stdarg.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
|  | ||||
| int main(int argc, char **argv) | ||||
| { | ||||
| 	int rc; | ||||
| 	ithread_t cmdloop_thread; | ||||
| #ifdef WIN32 | ||||
| #else | ||||
| 	int sig; | ||||
| 	sigset_t sigs_to_catch; | ||||
| #endif | ||||
| 	int code; | ||||
|  | ||||
| 	rc = TvCtrlPointStart(linux_print, NULL, 0); | ||||
| 	if (rc != TV_SUCCESS) { | ||||
| 		SampleUtil_Print("Error starting UPnP TV Control Point\n"); | ||||
| 		return rc; | ||||
| 	} | ||||
| 	/* start a command loop thread */ | ||||
| 	code = ithread_create(&cmdloop_thread, NULL, TvCtrlPointCommandLoop, NULL); | ||||
| #ifdef WIN32 | ||||
| 	ithread_join(cmdloop_thread, NULL); | ||||
| #else | ||||
| 	/* Catch Ctrl-C and properly shutdown */ | ||||
| 	sigemptyset(&sigs_to_catch); | ||||
| 	sigaddset(&sigs_to_catch, SIGINT); | ||||
| 	sigwait(&sigs_to_catch, &sig); | ||||
| 	SampleUtil_Print("Shutting down on signal %d...\n", sig); | ||||
| #endif | ||||
| 	rc = TvCtrlPointStop(); | ||||
|  | ||||
| 	return rc; | ||||
| 	argc = argc; | ||||
| 	argv = argv; | ||||
| } | ||||
|  | ||||
| @@ -1,65 +0,0 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| #include "sample_util.h" | ||||
| #include "tv_device.h" | ||||
|  | ||||
| #include <stdarg.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
| int main(int argc, char *argv[]) | ||||
| { | ||||
| 	int rc; | ||||
| 	ithread_t cmdloop_thread; | ||||
| #ifdef WIN32 | ||||
| #else | ||||
| 	int sig; | ||||
| 	sigset_t sigs_to_catch; | ||||
| #endif | ||||
| 	int code; | ||||
|  | ||||
| 	device_main(argc, argv); | ||||
| 	/* start a command loop thread */ | ||||
| 	code = ithread_create(&cmdloop_thread, NULL, TvDeviceCommandLoop, NULL); | ||||
| #ifdef WIN32 | ||||
| 	ithread_join(cmdloop_thread, NULL); | ||||
| #else | ||||
| 	/* Catch Ctrl-C and properly shutdown */ | ||||
| 	sigemptyset(&sigs_to_catch); | ||||
| 	sigaddset(&sigs_to_catch, SIGINT); | ||||
| 	sigwait(&sigs_to_catch, &sig); | ||||
| 	SampleUtil_Print("Shutting down on signal %d...\n", sig); | ||||
| #endif | ||||
| 	rc = TvDeviceStop(); | ||||
|  | ||||
| 	return rc; | ||||
| } | ||||
|  | ||||
							
								
								
									
										491
									
								
								upnp/sample/tvcombo/linux/upnp_tv_combo_main.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										491
									
								
								upnp/sample/tvcombo/linux/upnp_tv_combo_main.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,491 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
|  | ||||
| #include "sample_util.h" | ||||
| #include "upnp_tv_ctrlpt.h" | ||||
| #include "upnp_tv_device.h" | ||||
|  | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
|  | ||||
| /* | ||||
|    Tags for valid commands issued at the command prompt  | ||||
|  */ | ||||
| enum cmdloop_tvcmds { | ||||
|     PRTHELP = 0, PRTFULLHELP, POWON, POWOFF, | ||||
|     SETCHAN, SETVOL, SETCOL, SETTINT, SETCONT, SETBRT, | ||||
|     CTRLACTION, PICTACTION, CTRLGETVAR, PICTGETVAR, | ||||
|     PRTDEV, LSTDEV, REFRESH, EXITCMD | ||||
| }; | ||||
|  | ||||
| /* | ||||
|    Data structure for parsing commands from the command line  | ||||
|  */ | ||||
| struct cmdloop_commands { | ||||
|     char *str;                  // the string  | ||||
|     int cmdnum;                 // the command | ||||
|     int numargs;                // the number of arguments | ||||
|     char *args;                 // the args | ||||
| } cmdloop_commands; | ||||
|  | ||||
| /* | ||||
|    Mappings between command text names, command tag, | ||||
|    and required command arguments for command line | ||||
|    commands  | ||||
|  */ | ||||
| static struct cmdloop_commands cmdloop_cmdlist[] = { | ||||
|     {"Help", PRTHELP, 1, ""}, | ||||
|     {"HelpFull", PRTFULLHELP, 1, ""}, | ||||
|     {"ListDev", LSTDEV, 1, ""}, | ||||
|     {"Refresh", REFRESH, 1, ""}, | ||||
|     {"PrintDev", PRTDEV, 2, "<devnum>"}, | ||||
|     {"PowerOn", POWON, 2, "<devnum>"}, | ||||
|     {"PowerOff", POWOFF, 2, "<devnum>"}, | ||||
|     {"SetChannel", SETCHAN, 3, "<devnum> <channel (int)>"}, | ||||
|     {"SetVolume", SETVOL, 3, "<devnum> <volume (int)>"}, | ||||
|     {"SetColor", SETCOL, 3, "<devnum> <color (int)>"}, | ||||
|     {"SetTint", SETTINT, 3, "<devnum> <tint (int)>"}, | ||||
|     {"SetContrast", SETCONT, 3, "<devnum> <contrast (int)>"}, | ||||
|     {"SetBrightness", SETBRT, 3, "<devnum> <brightness (int)>"}, | ||||
|     {"CtrlAction", CTRLACTION, 2, "<devnum> <action (string)>"}, | ||||
|     {"PictAction", PICTACTION, 2, "<devnum> <action (string)>"}, | ||||
|     {"CtrlGetVar", CTRLGETVAR, 2, "<devnum> <varname (string)>"}, | ||||
|     {"PictGetVar", PICTGETVAR, 2, "<devnum> <varname (string)>"}, | ||||
|     {"Exit", EXITCMD, 1, ""} | ||||
| }; | ||||
|  | ||||
| void | ||||
| linux_print( const char *string ) | ||||
| { | ||||
|     puts( string ); | ||||
| } | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * TvCtrlPointPrintHelp | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Print help info for this application. | ||||
|  ********************************************************************************/ | ||||
| void | ||||
| TvCtrlPointPrintShortHelp( void ) | ||||
| { | ||||
|     SampleUtil_Print( "Commands:" ); | ||||
|     SampleUtil_Print( "  Help" ); | ||||
|     SampleUtil_Print( "  HelpFull" ); | ||||
|     SampleUtil_Print( "  ListDev" ); | ||||
|     SampleUtil_Print( "  Refresh" ); | ||||
|     SampleUtil_Print( "  PrintDev      <devnum>" ); | ||||
|     SampleUtil_Print( "  PowerOn       <devnum>" ); | ||||
|     SampleUtil_Print( "  PowerOff      <devnum>" ); | ||||
|     SampleUtil_Print( "  SetChannel    <devnum> <channel>" ); | ||||
|     SampleUtil_Print( "  SetVolume     <devnum> <volume>" ); | ||||
|     SampleUtil_Print( "  SetColor      <devnum> <color>" ); | ||||
|     SampleUtil_Print( "  SetTint       <devnum> <tint>" ); | ||||
|     SampleUtil_Print( "  SetContrast   <devnum> <contrast>" ); | ||||
|     SampleUtil_Print( "  SetBrightness <devnum> <brightness>" ); | ||||
|     SampleUtil_Print( "  CtrlAction    <devnum> <action>" ); | ||||
|     SampleUtil_Print( "  PictAction    <devnum> <action>" ); | ||||
|     SampleUtil_Print( "  CtrlGetVar    <devnum> <varname>" ); | ||||
|     SampleUtil_Print( "  PictGetVar    <devnum> <action>" ); | ||||
|     SampleUtil_Print( "  Exit" ); | ||||
| } | ||||
|  | ||||
| void | ||||
| TvCtrlPointPrintLongHelp( void ) | ||||
| { | ||||
|     SampleUtil_Print( "" ); | ||||
|     SampleUtil_Print( "******************************" ); | ||||
|     SampleUtil_Print( "* TV Control Point Help Info *" ); | ||||
|     SampleUtil_Print( "******************************" ); | ||||
|     SampleUtil_Print( "" ); | ||||
|     SampleUtil_Print( "This sample control point application automatically searches" ); | ||||
|     SampleUtil_Print( "for and subscribes to the services of television device emulator" ); | ||||
|     SampleUtil_Print( "devices. While registers a tv device itself." ); | ||||
|     SampleUtil_Print( "" ); | ||||
|     SampleUtil_Print( "Commands:" ); | ||||
|     SampleUtil_Print( "  Help" ); | ||||
|     SampleUtil_Print( "       Print this help info." ); | ||||
|     SampleUtil_Print( "  ListDev" ); | ||||
|     SampleUtil_Print( "       Print the current list of TV Device Emulators that this" ); | ||||
|     SampleUtil_Print( "         control point is aware of.  Each device is preceded by a" ); | ||||
|     SampleUtil_Print( "         device number which corresponds to the devnum argument of" ); | ||||
|     SampleUtil_Print( "         commands listed below." ); | ||||
|     SampleUtil_Print( "  Refresh" ); | ||||
|     SampleUtil_Print( "       Delete all of the devices from the device list and issue new" ); | ||||
|     SampleUtil_Print( "         search request to rebuild the list from scratch." ); | ||||
|     SampleUtil_Print( "  PrintDev       <devnum>" ); | ||||
|     SampleUtil_Print( "       Print the state table for the device <devnum>." ); | ||||
|     SampleUtil_Print( "         e.g., 'PrintDev 1' prints the state table for the first" ); | ||||
|     SampleUtil_Print( "         device in the device list." ); | ||||
|     SampleUtil_Print( "  PowerOn        <devnum>" ); | ||||
|     SampleUtil_Print( "       Sends the PowerOn action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>." ); | ||||
|     SampleUtil_Print( "  PowerOff       <devnum>" ); | ||||
|     SampleUtil_Print( "       Sends the PowerOff action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>." ); | ||||
|     SampleUtil_Print( "  SetChannel     <devnum> <channel>" ); | ||||
|     SampleUtil_Print( "       Sends the SetChannel action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the channel to be changed" ); | ||||
|     SampleUtil_Print( "         to <channel>." ); | ||||
|     SampleUtil_Print( "  SetVolume      <devnum> <volume>" ); | ||||
|     SampleUtil_Print( "       Sends the SetVolume action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the volume to be changed" ); | ||||
|     SampleUtil_Print( "         to <volume>." ); | ||||
|     SampleUtil_Print( "  SetColor       <devnum> <color>" ); | ||||
|     SampleUtil_Print( "       Sends the SetColor action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the color to be changed" ); | ||||
|     SampleUtil_Print( "         to <color>." ); | ||||
|     SampleUtil_Print( "  SetTint        <devnum> <tint>" ); | ||||
|     SampleUtil_Print( "       Sends the SetTint action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the tint to be changed" ); | ||||
|     SampleUtil_Print( "         to <tint>." ); | ||||
|     SampleUtil_Print( "  SetContrast    <devnum> <contrast>" ); | ||||
|     SampleUtil_Print( "       Sends the SetContrast action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the contrast to be changed" ); | ||||
|     SampleUtil_Print( "         to <contrast>." ); | ||||
|     SampleUtil_Print( "  SetBrightness  <devnum> <brightness>" ); | ||||
|     SampleUtil_Print( "       Sends the SetBrightness action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the brightness to be changed" ); | ||||
|     SampleUtil_Print( "         to <brightness>." ); | ||||
|     SampleUtil_Print( "  CtrlAction     <devnum> <action>" ); | ||||
|     SampleUtil_Print( "       Sends an action request specified by the string <action>" ); | ||||
|     SampleUtil_Print( "         to the Control Service of device <devnum>.  This command" ); | ||||
|     SampleUtil_Print( "         only works for actions that have no arguments." ); | ||||
|     SampleUtil_Print( "         (e.g., \"CtrlAction 1 IncreaseChannel\")" ); | ||||
|     SampleUtil_Print( "  PictAction     <devnum> <action>" ); | ||||
|     SampleUtil_Print( "       Sends an action request specified by the string <action>" ); | ||||
|     SampleUtil_Print( "         to the Picture Service of device <devnum>.  This command" ); | ||||
|     SampleUtil_Print( "         only works for actions that have no arguments." ); | ||||
|     SampleUtil_Print( "         (e.g., \"PictAction 1 DecreaseContrast\")" ); | ||||
|     SampleUtil_Print( "  CtrlGetVar     <devnum> <varname>" ); | ||||
|     SampleUtil_Print( "       Requests the value of a variable specified by the string <varname>" ); | ||||
|     SampleUtil_Print( "         from the Control Service of device <devnum>." ); | ||||
|     SampleUtil_Print( "         (e.g., \"CtrlGetVar 1 Volume\")" ); | ||||
|     SampleUtil_Print( "  PictGetVar     <devnum> <action>" ); | ||||
|     SampleUtil_Print( "       Requests the value of a variable specified by the string <varname>" ); | ||||
|     SampleUtil_Print( "         from the Picture Service of device <devnum>." ); | ||||
|     SampleUtil_Print( "         (e.g., \"PictGetVar 1 Tint\")" ); | ||||
|     SampleUtil_Print( "  Exit" ); | ||||
|     SampleUtil_Print( "       Exits the control point application." ); | ||||
| } | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * TvCtrlPointPrintCommands | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Print the list of valid command line commands to the user | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   None | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| void | ||||
| TvCtrlPointPrintCommands() | ||||
| { | ||||
|     int i; | ||||
|     int numofcmds = sizeof( cmdloop_cmdlist ) / sizeof( cmdloop_commands ); | ||||
|  | ||||
|     SampleUtil_Print( "Valid Commands:" ); | ||||
|     for( i = 0; i < numofcmds; i++ ) { | ||||
|         SampleUtil_Print( "  %-14s %s", cmdloop_cmdlist[i].str, | ||||
|                           cmdloop_cmdlist[i].args ); | ||||
|     } | ||||
|     SampleUtil_Print( "" ); | ||||
| } | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * TvCtrlPointCommandLoop | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Function that receives commands from the user at the command prompt | ||||
|  *       during the lifetime of the control point, and calls the appropriate | ||||
|  *       functions for those commands. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    None | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| void * | ||||
| TvCtrlPointCommandLoop( void *args ) | ||||
| { | ||||
|     char cmdline[100]; | ||||
|  | ||||
|     while( 1 ) { | ||||
|         SampleUtil_Print( "\n>> " ); | ||||
|         fgets( cmdline, 100, stdin ); | ||||
|         TvCtrlPointProcessCommand( cmdline ); | ||||
|     } | ||||
|  | ||||
|     return NULL; | ||||
| } | ||||
|  | ||||
| int | ||||
| TvCtrlPointProcessCommand( char *cmdline ) | ||||
| { | ||||
|     char cmd[100]; | ||||
|     char strarg[100]; | ||||
|     int arg_val_err = -99999; | ||||
|     int arg1 = arg_val_err; | ||||
|     int arg2 = arg_val_err; | ||||
|     int cmdnum = -1; | ||||
|     int numofcmds = sizeof( cmdloop_cmdlist ) / sizeof( cmdloop_commands ); | ||||
|     int cmdfound = 0; | ||||
|     int i, | ||||
|       rc; | ||||
|     int invalidargs = 0; | ||||
|     int validargs; | ||||
|  | ||||
|     validargs = sscanf( cmdline, "%s %d %d", cmd, &arg1, &arg2 ); | ||||
|  | ||||
|     for( i = 0; i < numofcmds; i++ ) { | ||||
|         if( strcasecmp( cmd, cmdloop_cmdlist[i].str ) == 0 ) { | ||||
|             cmdnum = cmdloop_cmdlist[i].cmdnum; | ||||
|             cmdfound++; | ||||
|             if( validargs != cmdloop_cmdlist[i].numargs ) | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if( !cmdfound ) { | ||||
|         SampleUtil_Print( "Command not found; try 'Help'" ); | ||||
|         return TV_SUCCESS; | ||||
|     } | ||||
|  | ||||
|     if( invalidargs ) { | ||||
|         SampleUtil_Print( "Invalid arguments; try 'Help'" ); | ||||
|         return TV_SUCCESS; | ||||
|     } | ||||
|  | ||||
|     switch ( cmdnum ) { | ||||
|         case PRTHELP: | ||||
|             TvCtrlPointPrintShortHelp(); | ||||
|             break; | ||||
|  | ||||
|         case PRTFULLHELP: | ||||
|             TvCtrlPointPrintLongHelp(); | ||||
|             break; | ||||
|  | ||||
|         case POWON: | ||||
|             TvCtrlPointSendPowerOn( arg1 ); | ||||
|             break; | ||||
|  | ||||
|         case POWOFF: | ||||
|             TvCtrlPointSendPowerOff( arg1 ); | ||||
|             break; | ||||
|  | ||||
|         case SETCHAN: | ||||
|             TvCtrlPointSendSetChannel( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETVOL: | ||||
|             TvCtrlPointSendSetVolume( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETCOL: | ||||
|             TvCtrlPointSendSetColor( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETTINT: | ||||
|             TvCtrlPointSendSetTint( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETCONT: | ||||
|             TvCtrlPointSendSetContrast( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETBRT: | ||||
|             TvCtrlPointSendSetBrightness( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case CTRLACTION: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointSendAction( TV_SERVICE_CONTROL, arg1, strarg, | ||||
|                                        NULL, NULL, 0 ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case PICTACTION: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointSendAction( TV_SERVICE_PICTURE, arg1, strarg, | ||||
|                                        NULL, NULL, 0 ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case CTRLGETVAR: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointGetVar( TV_SERVICE_CONTROL, arg1, strarg ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case PICTGETVAR: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointGetVar( TV_SERVICE_PICTURE, arg1, strarg ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case PRTDEV: | ||||
|             TvCtrlPointPrintDevice( arg1 ); | ||||
|             break; | ||||
|  | ||||
|         case LSTDEV: | ||||
|             TvCtrlPointPrintList(); | ||||
|             break; | ||||
|  | ||||
|         case REFRESH: | ||||
|             TvCtrlPointRefresh(); | ||||
|             break; | ||||
|  | ||||
|         case EXITCMD: | ||||
|             rc = TvCtrlPointStop(); | ||||
|             exit( rc ); | ||||
|             break; | ||||
|  | ||||
|         default: | ||||
|             SampleUtil_Print( "Command not implemented; see 'Help'" ); | ||||
|             break; | ||||
|     } | ||||
|  | ||||
|     if( invalidargs ) | ||||
|         SampleUtil_Print( "Invalid args in command; see 'Help'" ); | ||||
|  | ||||
|     return TV_SUCCESS; | ||||
| } | ||||
|  | ||||
| int | ||||
| device_main( int argc, char **argv ) | ||||
| { | ||||
|  | ||||
|     unsigned int portTemp = 0; | ||||
|     char *ip_address = NULL, | ||||
|      *desc_doc_name = NULL, | ||||
|      *web_dir_path = NULL; | ||||
|     unsigned int port = 0; | ||||
|  | ||||
|     int i = 0; | ||||
|  | ||||
|     SampleUtil_Initialize( linux_print ); | ||||
|  | ||||
|     // Parse options | ||||
|     for( i = 1; i < argc; i++ ) { | ||||
|         if( strcmp( argv[i], "-ip" ) == 0 ) { | ||||
|             ip_address = argv[++i]; | ||||
|         } else if( strcmp( argv[i], "-port" ) == 0 ) { | ||||
|             sscanf( argv[++i], "%u", &portTemp ); | ||||
|         } else if( strcmp( argv[i], "-desc" ) == 0 ) { | ||||
|             desc_doc_name = argv[++i]; | ||||
|         } else if( strcmp( argv[i], "-webdir" ) == 0 ) { | ||||
|             web_dir_path = argv[++i]; | ||||
|         } else if( strcmp( argv[i], "-help" ) == 0 ) { | ||||
|             SampleUtil_Print( "Usage: %s -ip ipaddress -port port" | ||||
|                               " -desc desc_doc_name -webdir web_dir_path" | ||||
|                               " -help (this message)\n", argv[0] ); | ||||
|             SampleUtil_Print( "\tipaddress:     IP address of the device" | ||||
|                               " (must match desc. doc)\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: 192.168.0.4\n" ); | ||||
|             SampleUtil_Print( "\tport:          Port number to use for " | ||||
|                               "receiving UPnP messages (must match desc. doc)\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: 5431\n" ); | ||||
|             SampleUtil_Print | ||||
|                 ( "\tdesc_doc_name: name of device description document\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: tvcombodesc.xml\n" ); | ||||
|             SampleUtil_Print | ||||
|                 ( "\tweb_dir_path: Filesystem path where web files " | ||||
|                   "related to the device are stored\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: /upnp/sample/web\n" ); | ||||
|             return 1; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     port = ( unsigned short )portTemp; | ||||
|  | ||||
|     return TvDeviceStart( ip_address, port, desc_doc_name, web_dir_path, linux_print ); | ||||
| } | ||||
|  | ||||
| int main( int argc, char **argv ) | ||||
| { | ||||
|     int rc; | ||||
|     ithread_t cmdloop_thread; | ||||
| #ifndef WIN32 | ||||
|     int sig; | ||||
|     sigset_t sigs_to_catch; | ||||
| #endif | ||||
|     int code; | ||||
|  | ||||
|     device_main(argc, argv); | ||||
|     rc = TvCtrlPointStart( linux_print, NULL ); | ||||
|     if( rc != TV_SUCCESS ) { | ||||
|         SampleUtil_Print( "Error starting UPnP TV Control Point" ); | ||||
|         return rc; | ||||
|     } | ||||
|     /* start a command loop thread */ | ||||
|     code = ithread_create( &cmdloop_thread, NULL, TvCtrlPointCommandLoop, NULL ); | ||||
|  | ||||
| #ifndef WIN32 | ||||
|     /* | ||||
|        Catch Ctrl-C and properly shutdown  | ||||
|      */ | ||||
|     sigemptyset( &sigs_to_catch ); | ||||
|     sigaddset( &sigs_to_catch, SIGINT ); | ||||
|     sigwait( &sigs_to_catch, &sig ); | ||||
|  | ||||
|     SampleUtil_Print( "Shutting down on signal %d...\n", sig ); | ||||
| #else | ||||
| 	ithread_join(cmdloop_thread, NULL); | ||||
| #endif | ||||
|     TvDeviceStop(); | ||||
|     rc = TvCtrlPointStop(); | ||||
|      | ||||
|     return rc; | ||||
| } | ||||
|  | ||||
							
								
								
									
										1417
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1417
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										160
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										160
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,160 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef UPNP_TV_CTRLPT_H | ||||
| #define UPNP_TV_CTRLPT_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
|  | ||||
| #include "ithread.h" | ||||
| #ifndef WIN32 | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #include <stdarg.h> | ||||
| #include <stdlib.h> | ||||
| #include <signal.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #include "upnp.h" | ||||
| #include "upnptools.h" | ||||
| #include "sample_util.h" | ||||
|  | ||||
| #define TV_SERVICE_SERVCOUNT	2 | ||||
| #define TV_SERVICE_CONTROL		0 | ||||
| #define TV_SERVICE_PICTURE		1 | ||||
|  | ||||
| #define TV_CONTROL_VARCOUNT		3 | ||||
| #define TV_CONTROL_POWER		0 | ||||
| #define TV_CONTROL_CHANNEL		1 | ||||
| #define TV_CONTROL_VOLUME		2 | ||||
|  | ||||
| #define TV_PICTURE_VARCOUNT		4 | ||||
| #define TV_PICTURE_COLOR		0 | ||||
| #define TV_PICTURE_TINT			1 | ||||
| #define TV_PICTURE_CONTRAST		2 | ||||
| #define TV_PICTURE_BRIGHTNESS	3 | ||||
|  | ||||
| #define TV_MAX_VAL_LEN			5 | ||||
|  | ||||
| #define TV_SUCCESS				0 | ||||
| #define TV_ERROR				(-1) | ||||
| #define TV_WARNING				1 | ||||
|  | ||||
| /* This should be the maximum VARCOUNT from above */ | ||||
| #define TV_MAXVARS				TV_PICTURE_VARCOUNT | ||||
|  | ||||
| extern char TvDeviceType[]; | ||||
| extern char *TvServiceType[]; | ||||
| extern char *TvServiceName[]; | ||||
| extern char *TvVarName[TV_SERVICE_SERVCOUNT][TV_MAXVARS]; | ||||
| extern char TvVarCount[]; | ||||
|  | ||||
| struct tv_service { | ||||
|     char ServiceId[NAME_SIZE]; | ||||
|     char ServiceType[NAME_SIZE]; | ||||
|     char *VariableStrVal[TV_MAXVARS]; | ||||
|     char EventURL[NAME_SIZE]; | ||||
|     char ControlURL[NAME_SIZE]; | ||||
|     char SID[NAME_SIZE]; | ||||
| }; | ||||
|  | ||||
| extern struct TvDeviceNode *GlobalDeviceList; | ||||
|  | ||||
| struct TvDevice { | ||||
|     char UDN[250]; | ||||
|     char DescDocURL[250]; | ||||
|     char FriendlyName[250]; | ||||
|     char PresURL[250]; | ||||
|     int  AdvrTimeOut; | ||||
|     struct tv_service TvService[TV_SERVICE_SERVCOUNT]; | ||||
| }; | ||||
|  | ||||
| struct TvDeviceNode { | ||||
|     struct TvDevice device; | ||||
|     struct TvDeviceNode *next; | ||||
| }; | ||||
|  | ||||
| extern ithread_mutex_t DeviceListMutex; | ||||
|  | ||||
| extern UpnpClient_Handle ctrlpt_handle; | ||||
|  | ||||
| void	TvCtrlPointPrintHelp( void ); | ||||
| int		TvCtrlPointDeleteNode(struct TvDeviceNode*); | ||||
| int		TvCtrlPointRemoveDevice(char*); | ||||
| int		TvCtrlPointRemoveAll( void ); | ||||
| int		TvCtrlPointRefresh( void ); | ||||
|  | ||||
|  | ||||
| int		TvCtrlPointSendAction(int, int, char *, char **, char **, int); | ||||
| int		TvCtrlPointSendActionNumericArg(int devnum, int service, char *actionName, char *paramName, int paramValue); | ||||
| int		TvCtrlPointSendPowerOn(int devnum); | ||||
| int		TvCtrlPointSendPowerOff(int devnum); | ||||
| int		TvCtrlPointSendSetChannel(int, int); | ||||
| int		TvCtrlPointSendSetVolume(int, int); | ||||
| int		TvCtrlPointSendSetColor(int, int); | ||||
| int		TvCtrlPointSendSetTint(int, int); | ||||
| int		TvCtrlPointSendSetContrast(int, int); | ||||
| int		TvCtrlPointSendSetBrightness(int, int); | ||||
|  | ||||
| int		TvCtrlPointGetVar(int, int, char*); | ||||
| int		TvCtrlPointGetPower(int devnum); | ||||
| int		TvCtrlPointGetChannel(int); | ||||
| int		TvCtrlPointGetVolume(int); | ||||
| int		TvCtrlPointGetColor(int); | ||||
| int		TvCtrlPointGetTint(int); | ||||
| int		TvCtrlPointGetContrast(int); | ||||
| int		TvCtrlPointGetBrightness(int); | ||||
|  | ||||
| int		TvCtrlPointGetDevice(int, struct TvDeviceNode **); | ||||
| int		TvCtrlPointPrintList( void ); | ||||
| int		TvCtrlPointPrintDevice(int); | ||||
| void	TvCtrlPointAddDevice (IXML_Document *, char *, int);  | ||||
| void    TvCtrlPointHandleGetVar(char *,char *,DOMString); | ||||
| void	TvStateUpdate(char*,int, IXML_Document * , char **); | ||||
| void	TvCtrlPointHandleEvent(Upnp_SID, int, IXML_Document *);  | ||||
| void	TvCtrlPointHandleSubscribeUpdate(char *, Upnp_SID, int);  | ||||
| int		TvCtrlPointCallbackEventHandler(Upnp_EventType, void *, void *); | ||||
| void	TvCtrlPointVerifyTimeouts(int); | ||||
| void	TvCtrlPointPrintCommands( void ); | ||||
| void*	TvCtrlPointCommandLoop( void* ); | ||||
| int		TvCtrlPointStart( print_string printFunctionPtr, state_update updateFunctionPtr ); | ||||
| int		TvCtrlPointStop( void ); | ||||
| int		TvCtrlPointProcessCommand( char *cmdline ); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| #endif //UPNP_TV_CTRLPT_H | ||||
							
								
								
									
										2038
									
								
								upnp/sample/tvcombo/upnp_tv_device.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2038
									
								
								upnp/sample/tvcombo/upnp_tv_device.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										640
									
								
								upnp/sample/tvcombo/upnp_tv_device.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										640
									
								
								upnp/sample/tvcombo/upnp_tv_device.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,640 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef UPNP_TV_DEVICE_H | ||||
| #define UPNP_TV_DEVICE_H | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <signal.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include "ithread.h" | ||||
| #include <stdlib.h> | ||||
| #ifndef WIN32 | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #include <string.h> | ||||
| #include "upnp.h" | ||||
| #include "sample_util.h" | ||||
|  | ||||
| //Color constants | ||||
| #define MAX_COLOR 10 | ||||
| #define MIN_COLOR 1 | ||||
|  | ||||
| //Brightness constants | ||||
| #define MAX_BRIGHTNESS 10 | ||||
| #define MIN_BRIGHTNESS 1 | ||||
|  | ||||
| //Power constants | ||||
| #define POWER_ON 1 | ||||
| #define POWER_OFF 0 | ||||
|  | ||||
| //Tint constants | ||||
| #define MAX_TINT 10 | ||||
| #define MIN_TINT 1 | ||||
|  | ||||
| //Volume constants | ||||
| #define MAX_VOLUME 10 | ||||
| #define MIN_VOLUME 1 | ||||
|  | ||||
| //Contrast constants | ||||
| #define MAX_CONTRAST 10 | ||||
| #define MIN_CONTRAST 1 | ||||
|  | ||||
| //Channel constants | ||||
| #define MAX_CHANNEL 100 | ||||
| #define MIN_CHANNEL 1 | ||||
|  | ||||
| //Number of services. | ||||
| #define TV_SERVICE_SERVCOUNT  2 | ||||
|  | ||||
| //Index of control service | ||||
| #define TV_SERVICE_CONTROL    0 | ||||
|  | ||||
| //Index of picture service | ||||
| #define TV_SERVICE_PICTURE    1 | ||||
|  | ||||
| //Number of control variables | ||||
| #define TV_CONTROL_VARCOUNT   3 | ||||
|  | ||||
| //Index of power variable | ||||
| #define TV_CONTROL_POWER      0 | ||||
|  | ||||
| //Index of channel variable | ||||
| #define TV_CONTROL_CHANNEL    1 | ||||
|  | ||||
| //Index of volume variable | ||||
| #define TV_CONTROL_VOLUME     2 | ||||
|  | ||||
| //Number of picture variables | ||||
| #define TV_PICTURE_VARCOUNT   4 | ||||
|  | ||||
| //Index of color variable | ||||
| #define TV_PICTURE_COLOR      0 | ||||
|  | ||||
| //Index of tint variable | ||||
| #define TV_PICTURE_TINT       1 | ||||
|  | ||||
| //Index of contrast variable | ||||
| #define TV_PICTURE_CONTRAST   2 | ||||
|  | ||||
| //Index of brightness variable | ||||
| #define TV_PICTURE_BRIGHTNESS 3 | ||||
|  | ||||
| //Max value length | ||||
| #define TV_MAX_VAL_LEN 5 | ||||
|  | ||||
| //Max actions | ||||
| #define TV_MAXACTIONS 12 | ||||
|  | ||||
| /* This should be the maximum VARCOUNT from above */ | ||||
| #define TV_MAXVARS TV_PICTURE_VARCOUNT | ||||
|  | ||||
|  | ||||
| extern char TvDeviceType[]; | ||||
|  | ||||
| extern char *TvServiceType[]; | ||||
|  | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * upnp_action | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Prototype for all actions. For each action that a service  | ||||
|  *       implements, there is a corresponding function with this prototype. | ||||
|  *       Pointers to these functions, along with action names, are stored | ||||
|  *       in the service table. When an action request comes in the action | ||||
|  *       name is matched, and the appropriate function is called. | ||||
|  *       Each function returns UPNP_E_SUCCESS, on success, and a nonzero  | ||||
|  *       error code on failure. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * request - document of action request | ||||
|  *    IXML_Document **out - action result | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
|  | ||||
| typedef int (*upnp_action) (IXML_Document *request, IXML_Document **out,  | ||||
| 			    char **errorString); | ||||
|  | ||||
| /* Structure for storing Tv Service | ||||
|    identifiers and state table */ | ||||
| struct TvService { | ||||
|    | ||||
|   char UDN[NAME_SIZE]; /* Universally Unique Device Name */ | ||||
|   char ServiceId[NAME_SIZE]; | ||||
|   char ServiceType[NAME_SIZE]; | ||||
|   char *VariableName[TV_MAXVARS];  | ||||
|   char *VariableStrVal[TV_MAXVARS]; | ||||
|   char *ActionNames[TV_MAXACTIONS]; | ||||
|   upnp_action actions[TV_MAXACTIONS]; | ||||
|   unsigned int  VariableCount; | ||||
| }; | ||||
|  | ||||
| //Array of service structures | ||||
| extern struct TvService tv_service_table[]; | ||||
|  | ||||
| //Device handle returned from sdk | ||||
| extern UpnpDevice_Handle device_handle; | ||||
|  | ||||
|  | ||||
| /* Mutex for protecting the global state table data | ||||
|    in a multi-threaded, asynchronous environment. | ||||
|    All functions should lock this mutex before reading | ||||
|    or writing the state table data. */ | ||||
| extern ithread_mutex_t TVDevMutex; | ||||
|  | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * SetActionTable | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Initializes the action table for the specified service. | ||||
|  *       Note that  | ||||
|  *       knowledge of the service description is | ||||
|  *       assumed.  Action names are hardcoded. | ||||
|  * Parameters: | ||||
|  *   int serviceType - one of TV_SERVICE_CONTROL or, TV_SERVICE_PICTURE | ||||
|  *   struct TvService *out - service containing action table to set. | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int SetActionTable(int serviceType, struct TvService * out); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceStateTableInit | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Initialize the device state table for  | ||||
|  * 	 this TvDevice, pulling identifier info | ||||
|  *       from the description Document.  Note that  | ||||
|  *       knowledge of the service description is | ||||
|  *       assumed.  State table variables and default | ||||
|  *       values are currently hardcoded in this file | ||||
|  *       rather than being read from service description | ||||
|  *       documents. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   DescDocURL -- The description document URL | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceStateTableInit(char*); | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceHandleSubscriptionRequest | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Called during a subscription request callback.  If the | ||||
|  *       subscription request is for this device and either its | ||||
|  *       control service or picture service, then accept it. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   sr_event -- The subscription request event structure | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceHandleSubscriptionRequest(struct Upnp_Subscription_Request *); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceHandleGetVarRequest | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Called during a get variable request callback.  If the | ||||
|  *       request is for this device and either its control service | ||||
|  *       or picture service, then respond with the variable value. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   cgv_event -- The control get variable request event structure | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceHandleGetVarRequest(struct Upnp_State_Var_Request *); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceHandleActionRequest | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Called during an action request callback.  If the | ||||
|  *       request is for this device and either its control service | ||||
|  *       or picture service, then perform the action and respond. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   ca_event -- The control action request event structure | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceHandleActionRequest(struct Upnp_Action_Request *); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceCallbackEventHandler | ||||
|  * | ||||
|  * Description:  | ||||
|  *       The callback handler registered with the SDK while registering | ||||
|  *       root device.  Dispatches the request to the appropriate procedure | ||||
|  *       based on the value of EventType. The four requests handled by the  | ||||
|  *       device are:  | ||||
|  *                   1) Event Subscription requests.   | ||||
|  *                   2) Get Variable requests.  | ||||
|  *                   3) Action requests. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *   EventType -- The type of callback event | ||||
|  *   Event -- Data structure containing event data | ||||
|  *   Cookie -- Optional data specified during callback registration | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceCallbackEventHandler(Upnp_EventType, void*, void*); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetServiceTableVar | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Update the TvDevice service state table, and notify all subscribed  | ||||
|  *       control points of the updated state.  Note that since this function | ||||
|  *       blocks on the mutex TVDevMutex, to avoid a hang this function should  | ||||
|  *       not be called within any other function that currently has this mutex  | ||||
|  *       locked. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   service -- The service number (TV_SERVICE_CONTROL or TV_SERVICE_PICTURE) | ||||
|  *   variable -- The variable number (TV_CONTROL_POWER, TV_CONTROL_CHANNEL, | ||||
|  *                   TV_CONTROL_VOLUME, TV_PICTURE_COLOR, TV_PICTURE_TINT, | ||||
|  *                   TV_PICTURE_CONTRAST, or TV_PICTURE_BRIGHTNESS) | ||||
|  *   value -- The string representation of the new value | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetServiceTableVar(unsigned int, unsigned int, char*); | ||||
|  | ||||
| //Control Service Actions | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDevicePowerOn | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Turn the power on. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in - document of action request | ||||
|  *    IXML_Document **out - action result | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDevicePowerOn(IN IXML_Document * in, OUT IXML_Document **out,  | ||||
| 		    OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDevicePowerOff | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Turn the power off. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *     | ||||
|  *    IXML_Document * in - document of action request | ||||
|  *    IXML_Document **out - action result | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDevicePowerOff(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		     OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetChannel | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the channel, update the TvDevice control service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *     | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		       OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseChannel | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase the channel.   | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			    OUT char **errorString); | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseChannel | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease the channel.   | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			    OUT char **errorString); | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetVolume | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the volume, update the TvDevice control service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetVolume(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		      OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseVolume | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase the volume.  | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseVolume(IN IXML_Document *in, OUT IXML_Document**out,  | ||||
| 			   OUT char **errorString); | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseVolume | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease the volume. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseVolume(IN IXML_Document *in, OUT IXML_Document**out,  | ||||
| 			   OUT char **errorString); | ||||
|  | ||||
|  | ||||
| //Picture Service Actions | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetColor | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the color, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetColor(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		     OUT char **errorString); | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseColor | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase the color. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseColor(IN IXML_Document * in, OUT IXML_Document **out,  | ||||
| 			  OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseColor | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease the color.   | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseColor(IN IXML_Document * in, OUT IXML_Document **out,  | ||||
| 			  OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetTint | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the tint, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		    OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseTint | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase tint. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			 OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseTint | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease tint. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			 OUT char **errorString); | ||||
|  | ||||
| /***************************************************************************** | ||||
|  * TvDeviceSetContrast | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the contrast, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  ****************************************************************************/ | ||||
| int TvDeviceSetContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseContrast | ||||
|  * | ||||
|  * Description:  | ||||
|  * | ||||
|  *      Increase the contrast. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *        | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			     OUT char **errorString); | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseContrast | ||||
|  * | ||||
|  * Description:  | ||||
|  *      Decrease the contrast. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *           | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			     OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetBrightness | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the brightness, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   brightness -- The brightness value to change to. | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			  OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseBrightness | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase brightness. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			       OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseBrightness | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease brightnesss. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			       OUT char **errorString); | ||||
|  | ||||
| int TvDeviceStart(char * ip_address, unsigned short port,char * desc_doc_name, | ||||
| 				  char *web_dir_path, print_string pfun); | ||||
| int TvDeviceStop(); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										441
									
								
								upnp/sample/tvctrlpt/linux/upnp_tv_ctrlpt_main.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										441
									
								
								upnp/sample/tvctrlpt/linux/upnp_tv_ctrlpt_main.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,441 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
|  | ||||
| #include "sample_util.h" | ||||
| #include "upnp_tv_ctrlpt.h" | ||||
|  | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
|  | ||||
| /* | ||||
|    Tags for valid commands issued at the command prompt  | ||||
|  */ | ||||
| enum cmdloop_tvcmds { | ||||
|     PRTHELP = 0, PRTFULLHELP, POWON, POWOFF, | ||||
|     SETCHAN, SETVOL, SETCOL, SETTINT, SETCONT, SETBRT, | ||||
|     CTRLACTION, PICTACTION, CTRLGETVAR, PICTGETVAR, | ||||
|     PRTDEV, LSTDEV, REFRESH, EXITCMD | ||||
| }; | ||||
|  | ||||
| /* | ||||
|    Data structure for parsing commands from the command line  | ||||
|  */ | ||||
| struct cmdloop_commands { | ||||
|     char *str;                  // the string  | ||||
|     int cmdnum;                 // the command | ||||
|     int numargs;                // the number of arguments | ||||
|     char *args;                 // the args | ||||
| } cmdloop_commands; | ||||
|  | ||||
| /* | ||||
|    Mappings between command text names, command tag, | ||||
|    and required command arguments for command line | ||||
|    commands  | ||||
|  */ | ||||
| static struct cmdloop_commands cmdloop_cmdlist[] = { | ||||
|     {"Help", PRTHELP, 1, ""}, | ||||
|     {"HelpFull", PRTFULLHELP, 1, ""}, | ||||
|     {"ListDev", LSTDEV, 1, ""}, | ||||
|     {"Refresh", REFRESH, 1, ""}, | ||||
|     {"PrintDev", PRTDEV, 2, "<devnum>"}, | ||||
|     {"PowerOn", POWON, 2, "<devnum>"}, | ||||
|     {"PowerOff", POWOFF, 2, "<devnum>"}, | ||||
|     {"SetChannel", SETCHAN, 3, "<devnum> <channel (int)>"}, | ||||
|     {"SetVolume", SETVOL, 3, "<devnum> <volume (int)>"}, | ||||
|     {"SetColor", SETCOL, 3, "<devnum> <color (int)>"}, | ||||
|     {"SetTint", SETTINT, 3, "<devnum> <tint (int)>"}, | ||||
|     {"SetContrast", SETCONT, 3, "<devnum> <contrast (int)>"}, | ||||
|     {"SetBrightness", SETBRT, 3, "<devnum> <brightness (int)>"}, | ||||
|     {"CtrlAction", CTRLACTION, 2, "<devnum> <action (string)>"}, | ||||
|     {"PictAction", PICTACTION, 2, "<devnum> <action (string)>"}, | ||||
|     {"CtrlGetVar", CTRLGETVAR, 2, "<devnum> <varname (string)>"}, | ||||
|     {"PictGetVar", PICTGETVAR, 2, "<devnum> <varname (string)>"}, | ||||
|     {"Exit", EXITCMD, 1, ""} | ||||
| }; | ||||
|  | ||||
| void | ||||
| linux_print( const char *string ) | ||||
| { | ||||
|     puts( string ); | ||||
| } | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * TvCtrlPointPrintHelp | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Print help info for this application. | ||||
|  ********************************************************************************/ | ||||
| void | ||||
| TvCtrlPointPrintShortHelp( void ) | ||||
| { | ||||
|     SampleUtil_Print( "Commands:" ); | ||||
|     SampleUtil_Print( "  Help" ); | ||||
|     SampleUtil_Print( "  HelpFull" ); | ||||
|     SampleUtil_Print( "  ListDev" ); | ||||
|     SampleUtil_Print( "  Refresh" ); | ||||
|     SampleUtil_Print( "  PrintDev      <devnum>" ); | ||||
|     SampleUtil_Print( "  PowerOn       <devnum>" ); | ||||
|     SampleUtil_Print( "  PowerOff      <devnum>" ); | ||||
|     SampleUtil_Print( "  SetChannel    <devnum> <channel>" ); | ||||
|     SampleUtil_Print( "  SetVolume     <devnum> <volume>" ); | ||||
|     SampleUtil_Print( "  SetColor      <devnum> <color>" ); | ||||
|     SampleUtil_Print( "  SetTint       <devnum> <tint>" ); | ||||
|     SampleUtil_Print( "  SetContrast   <devnum> <contrast>" ); | ||||
|     SampleUtil_Print( "  SetBrightness <devnum> <brightness>" ); | ||||
|     SampleUtil_Print( "  CtrlAction    <devnum> <action>" ); | ||||
|     SampleUtil_Print( "  PictAction    <devnum> <action>" ); | ||||
|     SampleUtil_Print( "  CtrlGetVar    <devnum> <varname>" ); | ||||
|     SampleUtil_Print( "  PictGetVar    <devnum> <action>" ); | ||||
|     SampleUtil_Print( "  Exit" ); | ||||
| } | ||||
|  | ||||
| void | ||||
| TvCtrlPointPrintLongHelp( void ) | ||||
| { | ||||
|     SampleUtil_Print( "" ); | ||||
|     SampleUtil_Print( "******************************" ); | ||||
|     SampleUtil_Print( "* TV Control Point Help Info *" ); | ||||
|     SampleUtil_Print( "******************************" ); | ||||
|     SampleUtil_Print( "" ); | ||||
|     SampleUtil_Print( "This sample control point application automatically searches" ); | ||||
|     SampleUtil_Print( "for and subscribes to the services of television device emulator" ); | ||||
|     SampleUtil_Print( "devices, described in the tvdevicedesc.xml description document." ); | ||||
|     SampleUtil_Print( "" ); | ||||
|     SampleUtil_Print( "Commands:" ); | ||||
|     SampleUtil_Print( "  Help" ); | ||||
|     SampleUtil_Print( "       Print this help info." ); | ||||
|     SampleUtil_Print( "  ListDev" ); | ||||
|     SampleUtil_Print( "       Print the current list of TV Device Emulators that this" ); | ||||
|     SampleUtil_Print( "         control point is aware of.  Each device is preceded by a" ); | ||||
|     SampleUtil_Print( "         device number which corresponds to the devnum argument of" ); | ||||
|     SampleUtil_Print( "         commands listed below." ); | ||||
|     SampleUtil_Print( "  Refresh" ); | ||||
|     SampleUtil_Print( "       Delete all of the devices from the device list and issue new" ); | ||||
|     SampleUtil_Print( "         search request to rebuild the list from scratch." ); | ||||
|     SampleUtil_Print( "  PrintDev       <devnum>" ); | ||||
|     SampleUtil_Print( "       Print the state table for the device <devnum>." ); | ||||
|     SampleUtil_Print( "         e.g., 'PrintDev 1' prints the state table for the first" ); | ||||
|     SampleUtil_Print( "         device in the device list." ); | ||||
|     SampleUtil_Print( "  PowerOn        <devnum>" ); | ||||
|     SampleUtil_Print( "       Sends the PowerOn action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>." ); | ||||
|     SampleUtil_Print( "  PowerOff       <devnum>" ); | ||||
|     SampleUtil_Print( "       Sends the PowerOff action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>." ); | ||||
|     SampleUtil_Print( "  SetChannel     <devnum> <channel>" ); | ||||
|     SampleUtil_Print( "       Sends the SetChannel action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the channel to be changed" ); | ||||
|     SampleUtil_Print( "         to <channel>." ); | ||||
|     SampleUtil_Print( "  SetVolume      <devnum> <volume>" ); | ||||
|     SampleUtil_Print( "       Sends the SetVolume action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the volume to be changed" ); | ||||
|     SampleUtil_Print( "         to <volume>." ); | ||||
|     SampleUtil_Print( "  SetColor       <devnum> <color>" ); | ||||
|     SampleUtil_Print( "       Sends the SetColor action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the color to be changed" ); | ||||
|     SampleUtil_Print( "         to <color>." ); | ||||
|     SampleUtil_Print( "  SetTint        <devnum> <tint>" ); | ||||
|     SampleUtil_Print( "       Sends the SetTint action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the tint to be changed" ); | ||||
|     SampleUtil_Print( "         to <tint>." ); | ||||
|     SampleUtil_Print( "  SetContrast    <devnum> <contrast>" ); | ||||
|     SampleUtil_Print( "       Sends the SetContrast action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the contrast to be changed" ); | ||||
|     SampleUtil_Print( "         to <contrast>." ); | ||||
|     SampleUtil_Print( "  SetBrightness  <devnum> <brightness>" ); | ||||
|     SampleUtil_Print( "       Sends the SetBrightness action to the Control Service of" ); | ||||
|     SampleUtil_Print( "         device <devnum>, requesting the brightness to be changed" ); | ||||
|     SampleUtil_Print( "         to <brightness>." ); | ||||
|     SampleUtil_Print( "  CtrlAction     <devnum> <action>" ); | ||||
|     SampleUtil_Print( "       Sends an action request specified by the string <action>" ); | ||||
|     SampleUtil_Print( "         to the Control Service of device <devnum>.  This command" ); | ||||
|     SampleUtil_Print( "         only works for actions that have no arguments." ); | ||||
|     SampleUtil_Print( "         (e.g., \"CtrlAction 1 IncreaseChannel\")" ); | ||||
|     SampleUtil_Print( "  PictAction     <devnum> <action>" ); | ||||
|     SampleUtil_Print( "       Sends an action request specified by the string <action>" ); | ||||
|     SampleUtil_Print( "         to the Picture Service of device <devnum>.  This command" ); | ||||
|     SampleUtil_Print( "         only works for actions that have no arguments." ); | ||||
|     SampleUtil_Print( "         (e.g., \"PictAction 1 DecreaseContrast\")" ); | ||||
|     SampleUtil_Print( "  CtrlGetVar     <devnum> <varname>" ); | ||||
|     SampleUtil_Print( "       Requests the value of a variable specified by the string <varname>" ); | ||||
|     SampleUtil_Print( "         from the Control Service of device <devnum>." ); | ||||
|     SampleUtil_Print( "         (e.g., \"CtrlGetVar 1 Volume\")" ); | ||||
|     SampleUtil_Print( "  PictGetVar     <devnum> <action>" ); | ||||
|     SampleUtil_Print( "       Requests the value of a variable specified by the string <varname>" ); | ||||
|     SampleUtil_Print( "         from the Picture Service of device <devnum>." ); | ||||
|     SampleUtil_Print( "         (e.g., \"PictGetVar 1 Tint\")" ); | ||||
|     SampleUtil_Print( "  Exit" ); | ||||
|     SampleUtil_Print( "       Exits the control point application." ); | ||||
| } | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * TvCtrlPointPrintCommands | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Print the list of valid command line commands to the user | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   None | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| void | ||||
| TvCtrlPointPrintCommands() | ||||
| { | ||||
|     int i; | ||||
|     int numofcmds = sizeof( cmdloop_cmdlist ) / sizeof( cmdloop_commands ); | ||||
|  | ||||
|     SampleUtil_Print( "Valid Commands:" ); | ||||
|     for( i = 0; i < numofcmds; i++ ) { | ||||
|         SampleUtil_Print( "  %-14s %s", cmdloop_cmdlist[i].str, | ||||
|                           cmdloop_cmdlist[i].args ); | ||||
|     } | ||||
|     SampleUtil_Print( "" ); | ||||
| } | ||||
|  | ||||
| /******************************************************************************** | ||||
|  * TvCtrlPointCommandLoop | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Function that receives commands from the user at the command prompt | ||||
|  *       during the lifetime of the control point, and calls the appropriate | ||||
|  *       functions for those commands. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    None | ||||
|  * | ||||
|  ********************************************************************************/ | ||||
| void * | ||||
| TvCtrlPointCommandLoop( void *args ) | ||||
| { | ||||
|     char cmdline[100]; | ||||
|  | ||||
|     while( 1 ) { | ||||
|         SampleUtil_Print( "\n>> " ); | ||||
|         fgets( cmdline, 100, stdin ); | ||||
|         TvCtrlPointProcessCommand( cmdline ); | ||||
|     } | ||||
|  | ||||
|     return NULL; | ||||
| } | ||||
|  | ||||
| int | ||||
| TvCtrlPointProcessCommand( char *cmdline ) | ||||
| { | ||||
|     char cmd[100]; | ||||
|     char strarg[100]; | ||||
|     int arg_val_err = -99999; | ||||
|     int arg1 = arg_val_err; | ||||
|     int arg2 = arg_val_err; | ||||
|     int cmdnum = -1; | ||||
|     int numofcmds = sizeof( cmdloop_cmdlist ) / sizeof( cmdloop_commands ); | ||||
|     int cmdfound = 0; | ||||
|     int i, | ||||
|       rc; | ||||
|     int invalidargs = 0; | ||||
|     int validargs; | ||||
|  | ||||
|     validargs = sscanf( cmdline, "%s %d %d", cmd, &arg1, &arg2 ); | ||||
|  | ||||
|     for( i = 0; i < numofcmds; i++ ) { | ||||
|         if( strcasecmp( cmd, cmdloop_cmdlist[i].str ) == 0 ) { | ||||
|             cmdnum = cmdloop_cmdlist[i].cmdnum; | ||||
|             cmdfound++; | ||||
|             if( validargs != cmdloop_cmdlist[i].numargs ) | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if( !cmdfound ) { | ||||
|         SampleUtil_Print( "Command not found; try 'Help'" ); | ||||
|         return TV_SUCCESS; | ||||
|     } | ||||
|  | ||||
|     if( invalidargs ) { | ||||
|         SampleUtil_Print( "Invalid arguments; try 'Help'" ); | ||||
|         return TV_SUCCESS; | ||||
|     } | ||||
|  | ||||
|     switch ( cmdnum ) { | ||||
|         case PRTHELP: | ||||
|             TvCtrlPointPrintShortHelp(); | ||||
|             break; | ||||
|  | ||||
|         case PRTFULLHELP: | ||||
|             TvCtrlPointPrintLongHelp(); | ||||
|             break; | ||||
|  | ||||
|         case POWON: | ||||
|             TvCtrlPointSendPowerOn( arg1 ); | ||||
|             break; | ||||
|  | ||||
|         case POWOFF: | ||||
|             TvCtrlPointSendPowerOff( arg1 ); | ||||
|             break; | ||||
|  | ||||
|         case SETCHAN: | ||||
|             TvCtrlPointSendSetChannel( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETVOL: | ||||
|             TvCtrlPointSendSetVolume( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETCOL: | ||||
|             TvCtrlPointSendSetColor( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETTINT: | ||||
|             TvCtrlPointSendSetTint( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETCONT: | ||||
|             TvCtrlPointSendSetContrast( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case SETBRT: | ||||
|             TvCtrlPointSendSetBrightness( arg1, arg2 ); | ||||
|             break; | ||||
|  | ||||
|         case CTRLACTION: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointSendAction( TV_SERVICE_CONTROL, arg1, strarg, | ||||
|                                        NULL, NULL, 0 ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case PICTACTION: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointSendAction( TV_SERVICE_PICTURE, arg1, strarg, | ||||
|                                        NULL, NULL, 0 ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case CTRLGETVAR: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointGetVar( TV_SERVICE_CONTROL, arg1, strarg ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case PICTGETVAR: | ||||
|             /* | ||||
|                re-parse commandline since second arg is string  | ||||
|              */ | ||||
|             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||
|             if( 3 == validargs ) | ||||
|                 TvCtrlPointGetVar( TV_SERVICE_PICTURE, arg1, strarg ); | ||||
|             else | ||||
|                 invalidargs++; | ||||
|             break; | ||||
|  | ||||
|         case PRTDEV: | ||||
|             TvCtrlPointPrintDevice( arg1 ); | ||||
|             break; | ||||
|  | ||||
|         case LSTDEV: | ||||
|             TvCtrlPointPrintList(); | ||||
|             break; | ||||
|  | ||||
|         case REFRESH: | ||||
|             TvCtrlPointRefresh(); | ||||
|             break; | ||||
|  | ||||
|         case EXITCMD: | ||||
|             rc = TvCtrlPointStop(); | ||||
|             exit( rc ); | ||||
|             break; | ||||
|  | ||||
|         default: | ||||
|             SampleUtil_Print( "Command not implemented; see 'Help'" ); | ||||
|             break; | ||||
|     } | ||||
|  | ||||
|     if( invalidargs ) | ||||
|         SampleUtil_Print( "Invalid args in command; see 'Help'" ); | ||||
|  | ||||
|     return TV_SUCCESS; | ||||
| } | ||||
|  | ||||
| int | ||||
| main( int argc, | ||||
|       char **argv ) | ||||
| { | ||||
|     int rc; | ||||
|     ithread_t cmdloop_thread; | ||||
| #ifndef WIN32 | ||||
|     int sig; | ||||
|     sigset_t sigs_to_catch; | ||||
| #endif | ||||
|     int code; | ||||
|  | ||||
|     rc = TvCtrlPointStart( linux_print, NULL ); | ||||
|     if( rc != TV_SUCCESS ) { | ||||
|         SampleUtil_Print( "Error starting UPnP TV Control Point" ); | ||||
|         return rc; | ||||
|     } | ||||
|     // start a command loop thread | ||||
|     code = | ||||
|         ithread_create( &cmdloop_thread, NULL, TvCtrlPointCommandLoop, | ||||
|                         NULL ); | ||||
|  | ||||
| #ifndef WIN32 | ||||
|     /* | ||||
|        Catch Ctrl-C and properly shutdown  | ||||
|      */ | ||||
|     sigemptyset( &sigs_to_catch ); | ||||
|     sigaddset( &sigs_to_catch, SIGINT ); | ||||
|     sigwait( &sigs_to_catch, &sig ); | ||||
|  | ||||
|     SampleUtil_Print( "Shutting down on signal %d...", sig ); | ||||
| #else | ||||
| 	ithread_join(cmdloop_thread, NULL); | ||||
| #endif | ||||
|  | ||||
|     rc = TvCtrlPointStop(); | ||||
|     return rc; | ||||
| } | ||||
							
								
								
									
										1417
									
								
								upnp/sample/tvctrlpt/upnp_tv_ctrlpt.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1417
									
								
								upnp/sample/tvctrlpt/upnp_tv_ctrlpt.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										160
									
								
								upnp/sample/tvctrlpt/upnp_tv_ctrlpt.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										160
									
								
								upnp/sample/tvctrlpt/upnp_tv_ctrlpt.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,160 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef UPNP_TV_CTRLPT_H | ||||
| #define UPNP_TV_CTRLPT_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
|  | ||||
| #include "ithread.h" | ||||
| #ifndef WIN32 | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #include <stdarg.h> | ||||
| #include <stdlib.h> | ||||
| #include <signal.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #include "upnp.h" | ||||
| #include "upnptools.h" | ||||
| #include "sample_util.h" | ||||
|  | ||||
| #define TV_SERVICE_SERVCOUNT	2 | ||||
| #define TV_SERVICE_CONTROL		0 | ||||
| #define TV_SERVICE_PICTURE		1 | ||||
|  | ||||
| #define TV_CONTROL_VARCOUNT		3 | ||||
| #define TV_CONTROL_POWER		0 | ||||
| #define TV_CONTROL_CHANNEL		1 | ||||
| #define TV_CONTROL_VOLUME		2 | ||||
|  | ||||
| #define TV_PICTURE_VARCOUNT		4 | ||||
| #define TV_PICTURE_COLOR		0 | ||||
| #define TV_PICTURE_TINT			1 | ||||
| #define TV_PICTURE_CONTRAST		2 | ||||
| #define TV_PICTURE_BRIGHTNESS	3 | ||||
|  | ||||
| #define TV_MAX_VAL_LEN			5 | ||||
|  | ||||
| #define TV_SUCCESS				0 | ||||
| #define TV_ERROR				(-1) | ||||
| #define TV_WARNING				1 | ||||
|  | ||||
| /* This should be the maximum VARCOUNT from above */ | ||||
| #define TV_MAXVARS				TV_PICTURE_VARCOUNT | ||||
|  | ||||
| extern char TvDeviceType[]; | ||||
| extern char *TvServiceType[]; | ||||
| extern char *TvServiceName[]; | ||||
| extern char *TvVarName[TV_SERVICE_SERVCOUNT][TV_MAXVARS]; | ||||
| extern char TvVarCount[]; | ||||
|  | ||||
| struct tv_service { | ||||
|     char ServiceId[NAME_SIZE]; | ||||
|     char ServiceType[NAME_SIZE]; | ||||
|     char *VariableStrVal[TV_MAXVARS]; | ||||
|     char EventURL[NAME_SIZE]; | ||||
|     char ControlURL[NAME_SIZE]; | ||||
|     char SID[NAME_SIZE]; | ||||
| }; | ||||
|  | ||||
| extern struct TvDeviceNode *GlobalDeviceList; | ||||
|  | ||||
| struct TvDevice { | ||||
|     char UDN[250]; | ||||
|     char DescDocURL[250]; | ||||
|     char FriendlyName[250]; | ||||
|     char PresURL[250]; | ||||
|     int  AdvrTimeOut; | ||||
|     struct tv_service TvService[TV_SERVICE_SERVCOUNT]; | ||||
| }; | ||||
|  | ||||
| struct TvDeviceNode { | ||||
|     struct TvDevice device; | ||||
|     struct TvDeviceNode *next; | ||||
| }; | ||||
|  | ||||
| extern ithread_mutex_t DeviceListMutex; | ||||
|  | ||||
| extern UpnpClient_Handle ctrlpt_handle; | ||||
|  | ||||
| void	TvCtrlPointPrintHelp( void ); | ||||
| int		TvCtrlPointDeleteNode(struct TvDeviceNode*); | ||||
| int		TvCtrlPointRemoveDevice(char*); | ||||
| int		TvCtrlPointRemoveAll( void ); | ||||
| int		TvCtrlPointRefresh( void ); | ||||
|  | ||||
|  | ||||
| int		TvCtrlPointSendAction(int, int, char *, char **, char **, int); | ||||
| int		TvCtrlPointSendActionNumericArg(int devnum, int service, char *actionName, char *paramName, int paramValue); | ||||
| int		TvCtrlPointSendPowerOn(int devnum); | ||||
| int		TvCtrlPointSendPowerOff(int devnum); | ||||
| int		TvCtrlPointSendSetChannel(int, int); | ||||
| int		TvCtrlPointSendSetVolume(int, int); | ||||
| int		TvCtrlPointSendSetColor(int, int); | ||||
| int		TvCtrlPointSendSetTint(int, int); | ||||
| int		TvCtrlPointSendSetContrast(int, int); | ||||
| int		TvCtrlPointSendSetBrightness(int, int); | ||||
|  | ||||
| int		TvCtrlPointGetVar(int, int, char*); | ||||
| int		TvCtrlPointGetPower(int devnum); | ||||
| int		TvCtrlPointGetChannel(int); | ||||
| int		TvCtrlPointGetVolume(int); | ||||
| int		TvCtrlPointGetColor(int); | ||||
| int		TvCtrlPointGetTint(int); | ||||
| int		TvCtrlPointGetContrast(int); | ||||
| int		TvCtrlPointGetBrightness(int); | ||||
|  | ||||
| int		TvCtrlPointGetDevice(int, struct TvDeviceNode **); | ||||
| int		TvCtrlPointPrintList( void ); | ||||
| int		TvCtrlPointPrintDevice(int); | ||||
| void	TvCtrlPointAddDevice (IXML_Document *, char *, int);  | ||||
| void    TvCtrlPointHandleGetVar(char *,char *,DOMString); | ||||
| void	TvStateUpdate(char*,int, IXML_Document * , char **); | ||||
| void	TvCtrlPointHandleEvent(Upnp_SID, int, IXML_Document *);  | ||||
| void	TvCtrlPointHandleSubscribeUpdate(char *, Upnp_SID, int);  | ||||
| int		TvCtrlPointCallbackEventHandler(Upnp_EventType, void *, void *); | ||||
| void	TvCtrlPointVerifyTimeouts(int); | ||||
| void	TvCtrlPointPrintCommands( void ); | ||||
| void*	TvCtrlPointCommandLoop( void* ); | ||||
| int		TvCtrlPointStart( print_string printFunctionPtr, state_update updateFunctionPtr ); | ||||
| int		TvCtrlPointStop( void ); | ||||
| int		TvCtrlPointProcessCommand( char *cmdline ); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| #endif //UPNP_TV_CTRLPT_H | ||||
							
								
								
									
										197
									
								
								upnp/sample/tvdevice/linux/upnp_tv_device_main.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										197
									
								
								upnp/sample/tvdevice/linux/upnp_tv_device_main.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,197 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
|  | ||||
| #include "sample_util.h" | ||||
| #include "upnp_tv_device.h" | ||||
|  | ||||
|  | ||||
| #include <stdio.h> | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * linux_print | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Prints a string to standard out. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    None | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| void | ||||
| linux_print( const char *string ) | ||||
| { | ||||
|     printf( "%s", string ); | ||||
| } | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceCommandLoop | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Function that receives commands from the user at the command prompt | ||||
|  *       during the lifetime of the device, and calls the appropriate | ||||
|  *       functions for those commands. Only one command, exit, is currently | ||||
|  *       defined. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    None | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| void * | ||||
| TvDeviceCommandLoop( void *args ) | ||||
| { | ||||
|     int stoploop = 0; | ||||
|     char cmdline[100]; | ||||
|     char cmd[100]; | ||||
|  | ||||
|     while( !stoploop ) { | ||||
|         sprintf( cmdline, " " ); | ||||
|         sprintf( cmd, " " ); | ||||
|  | ||||
|         SampleUtil_Print( "\n>> " ); | ||||
|  | ||||
|         // Get a command line | ||||
|         fgets( cmdline, 100, stdin ); | ||||
|  | ||||
|         sscanf( cmdline, "%s", cmd ); | ||||
|  | ||||
|         if( strcasecmp( cmd, "exit" ) == 0 ) { | ||||
|             SampleUtil_Print( "Shutting down...\n" ); | ||||
|             TvDeviceStop(); | ||||
|             exit( 0 ); | ||||
|         } else { | ||||
|             SampleUtil_Print( "\n   Unknown command: %s\n\n", cmd ); | ||||
|             SampleUtil_Print( "   Valid Commands:\n" ); | ||||
|             SampleUtil_Print( "     Exit\n\n" ); | ||||
|         } | ||||
|  | ||||
|     } | ||||
|  | ||||
|     return NULL; | ||||
| } | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * main | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Main entry point for tv device application. | ||||
|  *       Initializes and registers with the sdk. | ||||
|  *       Initializes the state stables of the service. | ||||
|  *       Starts the command loop. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    int argc  - count of arguments | ||||
|  *    char ** argv -arguments. The application  | ||||
|  *                  accepts the following optional arguments: | ||||
|  * | ||||
|  *                  -ip ipaddress  | ||||
|  *                  -port port | ||||
|  *		    -desc desc_doc_name  | ||||
|  *	            -webdir web_dir_path" | ||||
|  *		    -help  | ||||
|  *                  | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int main( IN int argc, IN char **argv ) | ||||
| { | ||||
|  | ||||
|     unsigned int portTemp = 0; | ||||
|     char *ip_address = NULL, | ||||
|      *desc_doc_name = NULL, | ||||
|      *web_dir_path = NULL; | ||||
|     int rc; | ||||
|     ithread_t cmdloop_thread; | ||||
| #ifndef WIN32 | ||||
|     int sig; | ||||
|     sigset_t sigs_to_catch; | ||||
| #endif | ||||
|     int code; | ||||
|     unsigned int port = 0; | ||||
|     int i = 0; | ||||
|  | ||||
|     SampleUtil_Initialize( linux_print ); | ||||
|  | ||||
|     // Parse options | ||||
|     for( i = 1; i < argc; i++ ) { | ||||
|         if( strcmp( argv[i], "-ip" ) == 0 ) { | ||||
|             ip_address = argv[++i]; | ||||
|         } else if( strcmp( argv[i], "-port" ) == 0 ) { | ||||
|             sscanf( argv[++i], "%u", &portTemp ); | ||||
|         } else if( strcmp( argv[i], "-desc" ) == 0 ) { | ||||
|             desc_doc_name = argv[++i]; | ||||
|         } else if( strcmp( argv[i], "-webdir" ) == 0 ) { | ||||
|             web_dir_path = argv[++i]; | ||||
|         } else if( strcmp( argv[i], "-help" ) == 0 ) { | ||||
|             SampleUtil_Print( "Usage: %s -ip ipaddress -port port" | ||||
|                               " -desc desc_doc_name -webdir web_dir_path" | ||||
|                               " -help (this message)\n", argv[0] ); | ||||
|             SampleUtil_Print( "\tipaddress:     IP address of the device" | ||||
|                               " (must match desc. doc)\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: 192.168.0.4\n" ); | ||||
|             SampleUtil_Print( "\tport:          Port number to use for " | ||||
|                               "receiving UPnP messages (must match desc. doc)\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: 5431\n" ); | ||||
|             SampleUtil_Print | ||||
|                 ( "\tdesc_doc_name: name of device description document\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: tvdevicedesc.xml\n" ); | ||||
|             SampleUtil_Print | ||||
|                 ( "\tweb_dir_path: Filesystem path where web files " | ||||
|                   "related to the device are stored\n" ); | ||||
|             SampleUtil_Print( "\t\te.g.: /upnp/sample/tvdevice/web\n" ); | ||||
|             return 1; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     port = ( unsigned short )portTemp; | ||||
|  | ||||
|     TvDeviceStart( ip_address, port, desc_doc_name, web_dir_path, linux_print ); | ||||
|  | ||||
|     /* start a command loop thread */ | ||||
|     code = ithread_create( &cmdloop_thread, NULL, TvDeviceCommandLoop, NULL ); | ||||
|  | ||||
| #ifndef WIN32 | ||||
|     /* | ||||
|        Catch Ctrl-C and properly shutdown  | ||||
|      */ | ||||
|     sigemptyset( &sigs_to_catch ); | ||||
|     sigaddset( &sigs_to_catch, SIGINT ); | ||||
|     sigwait( &sigs_to_catch, &sig ); | ||||
|  | ||||
|     SampleUtil_Print( "Shutting down on signal %d...\n", sig ); | ||||
| #else | ||||
| 	ithread_join(cmdloop_thread, NULL); | ||||
| #endif | ||||
|     rc = TvDeviceStop(); | ||||
|      | ||||
|     return rc; | ||||
| } | ||||
|  | ||||
							
								
								
									
										2038
									
								
								upnp/sample/tvdevice/upnp_tv_device.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2038
									
								
								upnp/sample/tvdevice/upnp_tv_device.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										640
									
								
								upnp/sample/tvdevice/upnp_tv_device.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										640
									
								
								upnp/sample/tvdevice/upnp_tv_device.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,640 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef UPNP_TV_DEVICE_H | ||||
| #define UPNP_TV_DEVICE_H | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <signal.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include "ithread.h" | ||||
| #include <stdlib.h> | ||||
| #ifndef WIN32 | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #include <string.h> | ||||
| #include "upnp.h" | ||||
| #include "sample_util.h" | ||||
|  | ||||
| //Color constants | ||||
| #define MAX_COLOR 10 | ||||
| #define MIN_COLOR 1 | ||||
|  | ||||
| //Brightness constants | ||||
| #define MAX_BRIGHTNESS 10 | ||||
| #define MIN_BRIGHTNESS 1 | ||||
|  | ||||
| //Power constants | ||||
| #define POWER_ON 1 | ||||
| #define POWER_OFF 0 | ||||
|  | ||||
| //Tint constants | ||||
| #define MAX_TINT 10 | ||||
| #define MIN_TINT 1 | ||||
|  | ||||
| //Volume constants | ||||
| #define MAX_VOLUME 10 | ||||
| #define MIN_VOLUME 1 | ||||
|  | ||||
| //Contrast constants | ||||
| #define MAX_CONTRAST 10 | ||||
| #define MIN_CONTRAST 1 | ||||
|  | ||||
| //Channel constants | ||||
| #define MAX_CHANNEL 100 | ||||
| #define MIN_CHANNEL 1 | ||||
|  | ||||
| //Number of services. | ||||
| #define TV_SERVICE_SERVCOUNT  2 | ||||
|  | ||||
| //Index of control service | ||||
| #define TV_SERVICE_CONTROL    0 | ||||
|  | ||||
| //Index of picture service | ||||
| #define TV_SERVICE_PICTURE    1 | ||||
|  | ||||
| //Number of control variables | ||||
| #define TV_CONTROL_VARCOUNT   3 | ||||
|  | ||||
| //Index of power variable | ||||
| #define TV_CONTROL_POWER      0 | ||||
|  | ||||
| //Index of channel variable | ||||
| #define TV_CONTROL_CHANNEL    1 | ||||
|  | ||||
| //Index of volume variable | ||||
| #define TV_CONTROL_VOLUME     2 | ||||
|  | ||||
| //Number of picture variables | ||||
| #define TV_PICTURE_VARCOUNT   4 | ||||
|  | ||||
| //Index of color variable | ||||
| #define TV_PICTURE_COLOR      0 | ||||
|  | ||||
| //Index of tint variable | ||||
| #define TV_PICTURE_TINT       1 | ||||
|  | ||||
| //Index of contrast variable | ||||
| #define TV_PICTURE_CONTRAST   2 | ||||
|  | ||||
| //Index of brightness variable | ||||
| #define TV_PICTURE_BRIGHTNESS 3 | ||||
|  | ||||
| //Max value length | ||||
| #define TV_MAX_VAL_LEN 5 | ||||
|  | ||||
| //Max actions | ||||
| #define TV_MAXACTIONS 12 | ||||
|  | ||||
| /* This should be the maximum VARCOUNT from above */ | ||||
| #define TV_MAXVARS TV_PICTURE_VARCOUNT | ||||
|  | ||||
|  | ||||
| extern char TvDeviceType[]; | ||||
|  | ||||
| extern char *TvServiceType[]; | ||||
|  | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * upnp_action | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Prototype for all actions. For each action that a service  | ||||
|  *       implements, there is a corresponding function with this prototype. | ||||
|  *       Pointers to these functions, along with action names, are stored | ||||
|  *       in the service table. When an action request comes in the action | ||||
|  *       name is matched, and the appropriate function is called. | ||||
|  *       Each function returns UPNP_E_SUCCESS, on success, and a nonzero  | ||||
|  *       error code on failure. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * request - document of action request | ||||
|  *    IXML_Document **out - action result | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
|  | ||||
| typedef int (*upnp_action) (IXML_Document *request, IXML_Document **out,  | ||||
| 			    char **errorString); | ||||
|  | ||||
| /* Structure for storing Tv Service | ||||
|    identifiers and state table */ | ||||
| struct TvService { | ||||
|    | ||||
|   char UDN[NAME_SIZE]; /* Universally Unique Device Name */ | ||||
|   char ServiceId[NAME_SIZE]; | ||||
|   char ServiceType[NAME_SIZE]; | ||||
|   char *VariableName[TV_MAXVARS];  | ||||
|   char *VariableStrVal[TV_MAXVARS]; | ||||
|   char *ActionNames[TV_MAXACTIONS]; | ||||
|   upnp_action actions[TV_MAXACTIONS]; | ||||
|   unsigned int  VariableCount; | ||||
| }; | ||||
|  | ||||
| //Array of service structures | ||||
| extern struct TvService tv_service_table[]; | ||||
|  | ||||
| //Device handle returned from sdk | ||||
| extern UpnpDevice_Handle device_handle; | ||||
|  | ||||
|  | ||||
| /* Mutex for protecting the global state table data | ||||
|    in a multi-threaded, asynchronous environment. | ||||
|    All functions should lock this mutex before reading | ||||
|    or writing the state table data. */ | ||||
| extern ithread_mutex_t TVDevMutex; | ||||
|  | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * SetActionTable | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Initializes the action table for the specified service. | ||||
|  *       Note that  | ||||
|  *       knowledge of the service description is | ||||
|  *       assumed.  Action names are hardcoded. | ||||
|  * Parameters: | ||||
|  *   int serviceType - one of TV_SERVICE_CONTROL or, TV_SERVICE_PICTURE | ||||
|  *   struct TvService *out - service containing action table to set. | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int SetActionTable(int serviceType, struct TvService * out); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceStateTableInit | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Initialize the device state table for  | ||||
|  * 	 this TvDevice, pulling identifier info | ||||
|  *       from the description Document.  Note that  | ||||
|  *       knowledge of the service description is | ||||
|  *       assumed.  State table variables and default | ||||
|  *       values are currently hardcoded in this file | ||||
|  *       rather than being read from service description | ||||
|  *       documents. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   DescDocURL -- The description document URL | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceStateTableInit(char*); | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceHandleSubscriptionRequest | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Called during a subscription request callback.  If the | ||||
|  *       subscription request is for this device and either its | ||||
|  *       control service or picture service, then accept it. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   sr_event -- The subscription request event structure | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceHandleSubscriptionRequest(struct Upnp_Subscription_Request *); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceHandleGetVarRequest | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Called during a get variable request callback.  If the | ||||
|  *       request is for this device and either its control service | ||||
|  *       or picture service, then respond with the variable value. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   cgv_event -- The control get variable request event structure | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceHandleGetVarRequest(struct Upnp_State_Var_Request *); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceHandleActionRequest | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Called during an action request callback.  If the | ||||
|  *       request is for this device and either its control service | ||||
|  *       or picture service, then perform the action and respond. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   ca_event -- The control action request event structure | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceHandleActionRequest(struct Upnp_Action_Request *); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceCallbackEventHandler | ||||
|  * | ||||
|  * Description:  | ||||
|  *       The callback handler registered with the SDK while registering | ||||
|  *       root device.  Dispatches the request to the appropriate procedure | ||||
|  *       based on the value of EventType. The four requests handled by the  | ||||
|  *       device are:  | ||||
|  *                   1) Event Subscription requests.   | ||||
|  *                   2) Get Variable requests.  | ||||
|  *                   3) Action requests. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *   EventType -- The type of callback event | ||||
|  *   Event -- Data structure containing event data | ||||
|  *   Cookie -- Optional data specified during callback registration | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceCallbackEventHandler(Upnp_EventType, void*, void*); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetServiceTableVar | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Update the TvDevice service state table, and notify all subscribed  | ||||
|  *       control points of the updated state.  Note that since this function | ||||
|  *       blocks on the mutex TVDevMutex, to avoid a hang this function should  | ||||
|  *       not be called within any other function that currently has this mutex  | ||||
|  *       locked. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   service -- The service number (TV_SERVICE_CONTROL or TV_SERVICE_PICTURE) | ||||
|  *   variable -- The variable number (TV_CONTROL_POWER, TV_CONTROL_CHANNEL, | ||||
|  *                   TV_CONTROL_VOLUME, TV_PICTURE_COLOR, TV_PICTURE_TINT, | ||||
|  *                   TV_PICTURE_CONTRAST, or TV_PICTURE_BRIGHTNESS) | ||||
|  *   value -- The string representation of the new value | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetServiceTableVar(unsigned int, unsigned int, char*); | ||||
|  | ||||
| //Control Service Actions | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDevicePowerOn | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Turn the power on. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in - document of action request | ||||
|  *    IXML_Document **out - action result | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDevicePowerOn(IN IXML_Document * in, OUT IXML_Document **out,  | ||||
| 		    OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDevicePowerOff | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Turn the power off. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *     | ||||
|  *    IXML_Document * in - document of action request | ||||
|  *    IXML_Document **out - action result | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDevicePowerOff(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		     OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetChannel | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the channel, update the TvDevice control service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *     | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		       OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseChannel | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase the channel.   | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			    OUT char **errorString); | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseChannel | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease the channel.   | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			    OUT char **errorString); | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetVolume | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the volume, update the TvDevice control service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetVolume(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		      OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseVolume | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase the volume.  | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseVolume(IN IXML_Document *in, OUT IXML_Document**out,  | ||||
| 			   OUT char **errorString); | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseVolume | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease the volume. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseVolume(IN IXML_Document *in, OUT IXML_Document**out,  | ||||
| 			   OUT char **errorString); | ||||
|  | ||||
|  | ||||
| //Picture Service Actions | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetColor | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the color, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetColor(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		     OUT char **errorString); | ||||
|  | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseColor | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase the color. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseColor(IN IXML_Document * in, OUT IXML_Document **out,  | ||||
| 			  OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseColor | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease the color.   | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseColor(IN IXML_Document * in, OUT IXML_Document **out,  | ||||
| 			  OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetTint | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the tint, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 		    OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseTint | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase tint. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			 OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseTint | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease tint. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			 OUT char **errorString); | ||||
|  | ||||
| /***************************************************************************** | ||||
|  * TvDeviceSetContrast | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the contrast, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  ****************************************************************************/ | ||||
| int TvDeviceSetContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseContrast | ||||
|  * | ||||
|  * Description:  | ||||
|  * | ||||
|  *      Increase the contrast. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *        | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			     OUT char **errorString); | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseContrast | ||||
|  * | ||||
|  * Description:  | ||||
|  *      Decrease the contrast. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *           | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			     OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceSetBrightness | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Change the brightness, update the TvDevice picture service | ||||
|  *       state table, and notify all subscribed control points of the | ||||
|  *       updated state. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *   brightness -- The brightness value to change to. | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceSetBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			  OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceIncreaseBrightness | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Increase brightness. | ||||
|  * | ||||
|  * Parameters: | ||||
|  * | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceIncreaseBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			       OUT char **errorString); | ||||
|  | ||||
| /****************************************************************************** | ||||
|  * TvDeviceDecreaseBrightness | ||||
|  * | ||||
|  * Description:  | ||||
|  *       Decrease brightnesss. | ||||
|  * | ||||
|  * Parameters: | ||||
|  *    IXML_Document * in -  action request document | ||||
|  *    IXML_Document **out - action result document | ||||
|  *    char **errorString - errorString (in case action was unsuccessful) | ||||
|  * | ||||
|  *****************************************************************************/ | ||||
| int TvDeviceDecreaseBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||
| 			       OUT char **errorString); | ||||
|  | ||||
| int TvDeviceStart(char * ip_address, unsigned short port,char * desc_doc_name, | ||||
| 				  char *web_dir_path, print_string pfun); | ||||
| int TvDeviceStop(); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
| @@ -1,213 +0,0 @@ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \addtogroup UpnpString | ||||
|  * | ||||
|  * Due to its heavy use, this class is coded for efficiency, not for beauty. | ||||
|  * Do not use this as example to other classes. Please take a look at any | ||||
|  * other one. | ||||
|  * | ||||
|  * \todo Always alloc a minimum size like 64 bytes or so and when shrinking | ||||
|  * do not perform a new memory allocation. | ||||
|  * | ||||
|  * @{ | ||||
|  * | ||||
|  * \file | ||||
|  * | ||||
|  * \brief UpnpString object implementation. | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
|  | ||||
| #include "UpnpString.h" | ||||
|  | ||||
|  | ||||
| #include <stdlib.h> /* for calloc(), free() */ | ||||
| #include <string.h> /* for strlen(), strdup() */ | ||||
|  | ||||
|  | ||||
| #ifdef WIN32 | ||||
| 	#define strcasecmp stricmp | ||||
| #else | ||||
| 	/* Other systems have strncasecmp */ | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* strndup() is a GNU extension. Other systems must fix it with elif's. */ | ||||
| #ifdef __GNUC__ | ||||
| 	extern char *strndup(__const char *__string, size_t __n); | ||||
| #elif defined(WIN32) | ||||
| 	static char *strndup(const char *__string, size_t __n) | ||||
| 	{ | ||||
| 		size_t strsize = strnlen(__string,__n); | ||||
| 		char *newstr = (char *) malloc(strsize + 1); | ||||
| 		strncpy(newstr,__string,__n); | ||||
| 		return(newstr); | ||||
| 	} | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Internal implementation of the class UpnpString. | ||||
|  * | ||||
|  * \internal | ||||
|  */ | ||||
| struct SUpnpString | ||||
| { | ||||
| 	/*! \brief Length of the string. */ | ||||
| 	size_t m_length; | ||||
| 	/*! \brief Pointer to a dynamically allocated area that holds the NULL | ||||
| 	 * terminated string. */ | ||||
| 	char *m_string; | ||||
| }; | ||||
|  | ||||
|  | ||||
| UpnpString *UpnpString_new() | ||||
| { | ||||
| 	/* All bytes are zero, and so is the length of the string. */ | ||||
| 	struct SUpnpString *p = calloc(1, sizeof (struct SUpnpString)); | ||||
| 	if (p == NULL) { | ||||
| 		goto error_handler1; | ||||
| 	} | ||||
| #if 0 | ||||
| 	p->m_length = 0; | ||||
| #endif | ||||
|  | ||||
| 	/* This byte is zero, calloc does initialize it. */ | ||||
| 	p->m_string = calloc(1, 1); | ||||
| 	if (p->m_string == NULL) { | ||||
| 		goto error_handler2; | ||||
| 	} | ||||
|  | ||||
| 	return (UpnpString *)p; | ||||
|  | ||||
| 	/*free(p->m_string); */ | ||||
| error_handler2: | ||||
| 	free(p); | ||||
| error_handler1: | ||||
| 	return NULL; | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpString_delete(UpnpString *p) | ||||
| { | ||||
| 	struct SUpnpString *q = (struct SUpnpString *)p; | ||||
| 		 | ||||
| 	if (!q) return; | ||||
|  | ||||
| 	q->m_length = 0; | ||||
|  | ||||
| 	free(q->m_string); | ||||
| 	q->m_string = NULL; | ||||
|  | ||||
| 	free(p); | ||||
| } | ||||
|  | ||||
|  | ||||
| UpnpString *UpnpString_dup(const UpnpString *p) | ||||
| { | ||||
| 	struct SUpnpString *q = calloc(1, sizeof (struct SUpnpString)); | ||||
| 	if (q == NULL) { | ||||
| 		goto error_handler1; | ||||
| 	} | ||||
| 	q->m_length = ((struct SUpnpString *)p)->m_length; | ||||
| 	q->m_string = strdup(((struct SUpnpString *)p)->m_string); | ||||
| 	if (q->m_string == NULL) { | ||||
| 		goto error_handler2; | ||||
| 	} | ||||
|  | ||||
| 	return (UpnpString *)q; | ||||
|  | ||||
| 	/*free(q->m_string); */ | ||||
| error_handler2: | ||||
| 	free(q); | ||||
| error_handler1: | ||||
| 	return NULL; | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpString_assign(UpnpString *p, const UpnpString *q) | ||||
| { | ||||
| 	if (p != q) { | ||||
| 		UpnpString_set_String(p, UpnpString_get_String(q)); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
| size_t UpnpString_get_Length(const UpnpString *p) | ||||
| { | ||||
| 	return ((struct SUpnpString *)p)->m_length; | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpString_set_Length(UpnpString *p, size_t n) | ||||
| { | ||||
| 	if (((struct SUpnpString *)p)->m_length > n) { | ||||
| 		((struct SUpnpString *)p)->m_length = n; | ||||
| 		/* No need to realloc now, will do later when needed. */ | ||||
| 		((struct SUpnpString *)p)->m_string[n] = 0; | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
| const char *UpnpString_get_String(const UpnpString *p) | ||||
| { | ||||
| 	return ((struct SUpnpString *)p)->m_string; | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpString_set_String(UpnpString *p, const char *s) | ||||
| { | ||||
| 	char *q = strdup(s); | ||||
| 	if (!q) goto error_handler1; | ||||
| 	free(((struct SUpnpString *)p)->m_string); | ||||
| 	((struct SUpnpString *)p)->m_length = strlen(q); | ||||
| 	((struct SUpnpString *)p)->m_string = q; | ||||
|  | ||||
| error_handler1: | ||||
| 	return q != NULL; | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpString_set_StringN(UpnpString *p, const char *s, size_t n) | ||||
| { | ||||
| 	char *q = strndup(s, n); | ||||
| 	if (!q) goto error_handler1; | ||||
| 	free(((struct SUpnpString *)p)->m_string); | ||||
| 	((struct SUpnpString *)p)->m_length = strlen(q); | ||||
| 	((struct SUpnpString *)p)->m_string = q; | ||||
|  | ||||
| error_handler1: | ||||
| 	return q != NULL; | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpString_clear(UpnpString *p) | ||||
| { | ||||
| 	((struct SUpnpString *)p)->m_length = 0; | ||||
| 	/* No need to realloc now, will do later when needed. */ | ||||
| 	((struct SUpnpString *)p)->m_string[0] = 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpString_cmp(UpnpString *p, UpnpString *q) | ||||
| { | ||||
| 	const char *cp = UpnpString_get_String(p); | ||||
| 	const char *cq = UpnpString_get_String(q); | ||||
|  | ||||
| 	return strcmp(cp, cq); | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpString_casecmp(UpnpString *p, UpnpString *q) | ||||
| { | ||||
| 	const char *cp = UpnpString_get_String(p); | ||||
| 	const char *cq = UpnpString_get_String(q); | ||||
|  | ||||
| 	return strcasecmp(cp, cq); | ||||
| } | ||||
|  | ||||
| /* @} UpnpString */ | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,108 +1,82 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
|  | ||||
| #include "ithread.h" | ||||
| #include "ixml.h" | ||||
| #include "upnp.h" | ||||
| #include "upnpdebug.h" | ||||
|  | ||||
|  | ||||
| #include <stdarg.h> | ||||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| #include "ithread.h" | ||||
| #include "upnp.h" | ||||
| #include <stdarg.h> | ||||
| #include <string.h> | ||||
|  | ||||
|  | ||||
|  | ||||
| /*! Mutex to synchronize all the log file opeartions in the debug mode */ | ||||
| //Mutex to synchronize all the log file opeartions in the debug mode | ||||
| static ithread_mutex_t GlobalDebugMutex; | ||||
|  | ||||
| /*! Global log level */ | ||||
| // Global log level | ||||
| static Upnp_LogLevel g_log_level = UPNP_DEFAULT_LOG_LEVEL; | ||||
|  | ||||
| /*! File handle for the error log file */ | ||||
| //File handle for the error log file | ||||
| static FILE *ErrFileHnd = NULL; | ||||
|  | ||||
| /*! File handle for the information log file */ | ||||
| //File handle for the information log file | ||||
| static FILE *InfoFileHnd = NULL; | ||||
|  | ||||
| /*! Name of the error file */ | ||||
| //Name of the error file | ||||
| static const char *errFileName = "IUpnpErrFile.txt"; | ||||
|  | ||||
| /*! Name of the info file */ | ||||
| //Name of the info file | ||||
| static const char *infoFileName = "IUpnpInfoFile.txt"; | ||||
|  | ||||
|  | ||||
| #ifdef DEBUG | ||||
|  | ||||
|  | ||||
| int UpnpInitLog(void) | ||||
| { | ||||
| 	ithread_mutex_init(&GlobalDebugMutex, NULL); | ||||
| 	if(DEBUG_TARGET == 1) { | ||||
| 		if((ErrFileHnd = fopen( errFileName, "a")) == NULL) { | ||||
| 			return -1; | ||||
| 		} | ||||
| 		if((InfoFileHnd = fopen( infoFileName, "a")) == NULL) { | ||||
| 			return -1; | ||||
| 		} | ||||
| 	} | ||||
| 	return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpSetLogLevel(Upnp_LogLevel log_level) | ||||
| { | ||||
| 	g_log_level = log_level; | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpCloseLog(void) | ||||
| { | ||||
| 	if (DEBUG_TARGET == 1) { | ||||
| 		fflush(ErrFileHnd); | ||||
| 		fflush(InfoFileHnd); | ||||
| 		fclose(ErrFileHnd); | ||||
| 		fclose(InfoFileHnd); | ||||
| 	} | ||||
| 	ithread_mutex_destroy(&GlobalDebugMutex); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpSetLogFileNames( | ||||
| 	const char *ErrFileName, | ||||
| 	const char *InfoFileName) | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpSetLogFileNames					 | ||||
|  *								 | ||||
|  * Parameters:							 | ||||
|  *	IN const char* ErrFileName: name of the error file | ||||
|  *	IN const char *InfoFileName: name of the information file | ||||
|  *	IN int size: Size of the buffer | ||||
|  *	IN int starLength: This parameter provides the width of the banner | ||||
|  *									 | ||||
|  * Description:							 | ||||
|  *	This functions takes the buffer and writes the buffer in the file as  | ||||
|  *	per the requested banner					 | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| void | ||||
| UpnpSetLogFileNames ( IN const char *ErrFileName, | ||||
| 		      IN const char *InfoFileName ) | ||||
| { | ||||
|     if( ErrFileName ) { | ||||
|         errFileName = ErrFileName; | ||||
| @@ -113,9 +87,91 @@ void UpnpSetLogFileNames( | ||||
| } | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpInitLog | ||||
|  * | ||||
|  * Parameters:	void | ||||
|  * | ||||
|  * Description: | ||||
|  *	This functions initializes the log files | ||||
|  * | ||||
|  * Returns: int | ||||
|  *	-1 : If fails | ||||
|  *	UPNP_E_SUCCESS : if success | ||||
|  ***************************************************************************/ | ||||
| int | ||||
| UpnpInitLog() | ||||
| { | ||||
|     ithread_mutex_init( &GlobalDebugMutex, NULL ); | ||||
|  | ||||
|     if( DEBUG_TARGET == 1 ) { | ||||
|         if( ( ErrFileHnd = fopen( errFileName, "a" ) ) == NULL ) | ||||
|             return -1; | ||||
|         if( ( InfoFileHnd = fopen( infoFileName, "a" ) ) == NULL ) | ||||
|             return -1; | ||||
|     } | ||||
|     return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpSetLogLevel | ||||
|  *				 | ||||
|  * Parameters:	Upnp_LogLevel log_level | ||||
|  * | ||||
|  * Description:							 | ||||
|  *	This functions set the log level (see {\tt Upnp_LogLevel} | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| void  | ||||
| UpnpSetLogLevel (Upnp_LogLevel log_level) | ||||
| { | ||||
| 	g_log_level = log_level; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpCloseLog					 | ||||
|  *								 | ||||
|  * Parameters:	void					 | ||||
|  *								 | ||||
|  * Description:						 | ||||
|  *	This functions closes the log files | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| void | ||||
| UpnpCloseLog() | ||||
| { | ||||
|     if( DEBUG_TARGET == 1 ) { | ||||
|         fflush( ErrFileHnd ); | ||||
|         fflush( InfoFileHnd ); | ||||
|         fclose( ErrFileHnd ); | ||||
|         fclose( InfoFileHnd ); | ||||
|     } | ||||
|     ithread_mutex_destroy( &GlobalDebugMutex ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : DebugAtThisLevel					 | ||||
|  *									 | ||||
|  * Parameters:			 | ||||
|  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||
|  *		whether debug statement will go to standard output,  | ||||
|  *		or any of the log files. | ||||
|  *	IN Dbg_Module Module: debug will go in the name of this module | ||||
|  *					 | ||||
|  * Description:					 | ||||
|  *	This functions returns true if debug output should be done in this | ||||
|  *	module. | ||||
|  * | ||||
|  * Returns: int | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| int DebugAtThisLevel( | ||||
| 	Upnp_LogLevel DLevel, | ||||
| 	Dbg_Module Module) | ||||
| 	IN Upnp_LogLevel DLevel, | ||||
| 	IN Dbg_Module Module) | ||||
| { | ||||
| 	int ret = DLevel <= g_log_level; | ||||
| 	ret &= | ||||
| @@ -130,14 +186,37 @@ int DebugAtThisLevel( | ||||
| 	 | ||||
| 	return ret; | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpPrintf					 | ||||
|  *									 | ||||
|  * Parameters:			 | ||||
|  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||
|  *		whether debug statement will go to standard output,  | ||||
|  *		or any of the log files. | ||||
|  *	IN Dbg_Module Module: debug will go in the name of this module | ||||
|  *	IN char *DbgFileName: Name of the file from where debug statement is | ||||
|  *							coming | ||||
|  *	IN int DbgLineNo : Line number of the file from where debug statement  | ||||
|  *				is coming | ||||
|  *	IN char * FmtStr, ...: Variable number of arguments that will go  | ||||
|  *				in the debug statement | ||||
|  *					 | ||||
|  * Description:					 | ||||
|  *	This functions prints the debug statement either on the startdard  | ||||
|  *	output or log file along with the information from where this debug  | ||||
|  *	statement is coming | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void UpnpPrintf( | ||||
| 	Upnp_LogLevel DLevel, | ||||
| 	Dbg_Module Module, | ||||
| 	const char *DbgFileName, | ||||
| 	int DbgLineNo, | ||||
| 	const char *FmtStr, | ||||
| 	IN Upnp_LogLevel DLevel, | ||||
| 	IN Dbg_Module Module, | ||||
| 	IN const char *DbgFileName, | ||||
| 	IN int DbgLineNo, | ||||
| 	IN const char *FmtStr, | ||||
| 	... ) | ||||
| { | ||||
| 	va_list ArgList; | ||||
| @@ -170,8 +249,26 @@ void UpnpPrintf( | ||||
| 	va_end(ArgList); | ||||
| 	ithread_mutex_unlock(&GlobalDebugMutex); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpGetDebugFile					 | ||||
|  *				 | ||||
|  * Parameters:			 | ||||
|  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||
|  *		whether debug statement will go to standard output,  | ||||
|  *		or any of the log files. | ||||
|  *	IN Dbg_Module Module: debug will go in the name of this module | ||||
|  *								 | ||||
|  * Description: | ||||
|  *	This function checks if the module is turned on for debug  | ||||
|  *	and returns the file descriptor corresponding to the debug level | ||||
|  * Returns: FILE * | ||||
|  *	NULL : if the module is turn off for debug  | ||||
|  *	else returns the right file descriptor | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| FILE *GetDebugFile( Upnp_LogLevel DLevel, Dbg_Module Module ) | ||||
| { | ||||
| 	FILE *ret; | ||||
| @@ -190,12 +287,28 @@ FILE *GetDebugFile(Upnp_LogLevel DLevel, Dbg_Module Module) | ||||
|  | ||||
| 	return ret; | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpDisplayFileAndLine				 | ||||
|  *	 | ||||
|  * Parameters:	 | ||||
|  *	IN FILE *fd: File descriptor where line number and file name will be  | ||||
|  *			written  | ||||
|  *	IN char *DbgFileName: Name of the file   | ||||
|  *	IN int DbgLineNo : Line number of the file | ||||
|  *		 | ||||
|  * Description: | ||||
|  *	This function writes the file name and file number from where | ||||
|  *		debug statement is coming to the log file | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void UpnpDisplayFileAndLine( | ||||
| 	FILE *fd, | ||||
| 	const char *DbgFileName, | ||||
| 	int DbgLineNo) | ||||
| 	IN FILE * fd, | ||||
| 	IN const char *DbgFileName, | ||||
| 	IN int DbgLineNo) | ||||
| { | ||||
| #define NLINES 2 | ||||
| #define MAX_LINE_SIZE 512 | ||||
| @@ -211,12 +324,7 @@ void UpnpDisplayFileAndLine( | ||||
|  | ||||
| 	/* Put the debug lines in the buffer */ | ||||
| 	sprintf(buf[0], "DEBUG - THREAD ID: 0x%lX", | ||||
| #ifdef WIN32 | ||||
| 		(unsigned long int)ithread_self().p | ||||
| #else | ||||
| 		(unsigned long int)ithread_self() | ||||
| #endif | ||||
| 	); | ||||
| 		(unsigned long int)ithread_self()); | ||||
| 	if (DbgFileName) { | ||||
| 		sprintf(buf[1], | ||||
| 			"FILE: %s, LINE: %d", | ||||
| @@ -228,23 +336,40 @@ void UpnpDisplayFileAndLine( | ||||
| 	UpnpDisplayBanner(fd, lines, NLINES, NUMBER_OF_STARS); | ||||
| 	fflush(fd); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Function : UpnpDisplayBanner	 | ||||
|  * | ||||
|  * Parameters:			 | ||||
|  *	IN FILE *fd: file descriptor where the banner will be written | ||||
|  *	IN char **lines: The buffer that will be written | ||||
|  *	IN int size: Size of the buffer | ||||
|  *	IN int starLength: This parameter provides the width of the banner | ||||
|  *	 | ||||
|  * Description:			 | ||||
|  *	This functions takes the buffer and writes the buffer in the file as  | ||||
|  *	per the requested banner | ||||
|  * Returns: void | ||||
|  ***************************************************************************/ | ||||
| #ifdef DEBUG | ||||
| void UpnpDisplayBanner( | ||||
| 	FILE * fd, | ||||
| 	const char **lines, | ||||
| 	size_t size, | ||||
| 	size_t starLength) | ||||
| 	IN FILE * fd, | ||||
| 	IN const char **lines, | ||||
| 	IN size_t size, | ||||
| 	IN int starLength) | ||||
| { | ||||
| 	size_t leftMarginLength = starLength / 2 + 1; | ||||
| 	size_t rightMarginLength = starLength / 2 + 1; | ||||
| 	size_t i = 0; | ||||
| 	size_t LineSize = 0; | ||||
| 	size_t starLengthMinus2 = starLength - 2; | ||||
| 	int leftMarginLength = starLength / 2 + 1; | ||||
| 	int rightMarginLength = starLength / 2 + 1; | ||||
| 	int i = 0; | ||||
| 	int LineSize = 0; | ||||
| 	int starLengthMinus2 = starLength - 2; | ||||
|  | ||||
| 	char *leftMargin = malloc(leftMarginLength); | ||||
| 	char *rightMargin = malloc(rightMarginLength); | ||||
| 	char *stars = malloc(starLength + 1); | ||||
| 	char *currentLine = malloc(starLength + 1); | ||||
| 	char *leftMargin = ( char * )malloc( leftMarginLength ); | ||||
| 	char *rightMargin = ( char * )malloc( rightMarginLength ); | ||||
| 	char *stars = ( char * )malloc( starLength + 1 ); | ||||
| 	char *currentLine = ( char * )malloc( starLength + 1 ); | ||||
| 	const char *line = NULL; | ||||
|  | ||||
| 	memset( stars, '*', starLength ); | ||||
| @@ -281,46 +406,5 @@ void UpnpDisplayBanner( | ||||
| 	free( rightMargin ); | ||||
| 	free( leftMargin ); | ||||
| } | ||||
|  | ||||
| void PrintThreadPoolStats( | ||||
| 	ThreadPool *tp,  | ||||
| 	const char *DbgFileName, | ||||
| 	int DbgLineNo, | ||||
| 	const char *msg) | ||||
| { | ||||
| 	ThreadPoolStats stats; | ||||
| 	ThreadPoolGetStats(tp, &stats); | ||||
| 	UpnpPrintf(UPNP_INFO, API, DbgFileName, DbgLineNo,  | ||||
| 		"%s\n" | ||||
| 		"High Jobs pending: %d\n" | ||||
| 		"Med Jobs Pending: %d\n" | ||||
| 		"Low Jobs Pending: %d\n" | ||||
| 		"Average wait in High Q in milliseconds: %lf\n" | ||||
| 		"Average wait in Med Q in milliseconds: %lf\n" | ||||
| 		"Average wait in Low Q in milliseconds: %lf\n" | ||||
| 		"Max Threads Used: %d\n" | ||||
| 		"Worker Threads: %d\n" | ||||
| 		"Persistent Threads: %d\n" | ||||
| 		"Idle Threads: %d\n" | ||||
| 		"Total Threads: %d\n" | ||||
| 		"Total Work Time: %lf\n" | ||||
| 		"Total Idle Time: %lf\n", | ||||
| 		msg, | ||||
| 		stats.currentJobsHQ, | ||||
| 		stats.currentJobsMQ, | ||||
| 		stats.currentJobsLQ, | ||||
| 		stats.avgWaitHQ, | ||||
| 		stats.avgWaitMQ, | ||||
| 		stats.avgWaitLQ, | ||||
| 		stats.maxThreads, | ||||
| 		stats.workerThreads, | ||||
| 		stats.persistentThreads, | ||||
| 		stats.idleThreads, | ||||
| 		stats.totalThreads, | ||||
| 		stats.totalWorkTime, | ||||
| 		stats.totalIdleTime); | ||||
| } | ||||
|  | ||||
|  | ||||
| #endif /* DEBUG */ | ||||
| #endif | ||||
|   | ||||
|   | ||||
| @@ -1,83 +1,56 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #if EXCLUDE_DOM == 0 | ||||
|  | ||||
|  | ||||
| #include "upnp.h" | ||||
| #include "upnptools.h" | ||||
|  | ||||
|  | ||||
| #include "uri.h" | ||||
|  | ||||
|  | ||||
| #include <stdarg.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
|  | ||||
| /*! Maximum action header buffer length. */ | ||||
| #include "upnptools.h" | ||||
| #include "uri.h" | ||||
| #define HEADER_LENGTH 2000 | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Structure to maintain a error code and string associated with the | ||||
|  * error code. | ||||
|  */ | ||||
| // Structure to maintain a error code and string associated with the  | ||||
| // error code | ||||
| struct ErrorString { | ||||
| 	/*! Error code. */ | ||||
| 	int rc; | ||||
| 	/*! Error description. */ | ||||
| 	const char *rcError; | ||||
|     int rc;                     /* error code */ | ||||
|     const char *rcError;        /* error description */ | ||||
|  | ||||
| }; | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Array of error structures. | ||||
|  */ | ||||
| struct ErrorString ErrorMessages[] = { | ||||
| 	{UPNP_E_SUCCESS, "UPNP_E_SUCCESS"}, | ||||
| // Initializing the array of error structures.  | ||||
| struct ErrorString ErrorMessages[] = { {UPNP_E_SUCCESS, "UPNP_E_SUCCESS"}, | ||||
| {UPNP_E_INVALID_HANDLE, "UPNP_E_INVALID_HANDLE"}, | ||||
| {UPNP_E_INVALID_PARAM, "UPNP_E_INVALID_PARAM"}, | ||||
| {UPNP_E_OUTOF_HANDLE, "UPNP_E_OUTOF_HANDLE"}, | ||||
| {UPNP_E_OUTOF_CONTEXT, "UPNP_E_OUTOF_CONTEXT"}, | ||||
| 	{UPNP_E_OUTOF_MEMORY, "UPNP_E_OUTOF_MEMORY"}, | ||||
| {UPNP_E_OUTOF_MEMORY, "UPNP_E_OUTOF_MEMOR"}, | ||||
| {UPNP_E_INIT, "UPNP_E_INIT"}, | ||||
| {UPNP_E_BUFFER_TOO_SMALL, "UPNP_E_BUFFER_TOO_SMALL"}, | ||||
| {UPNP_E_INVALID_DESC, "UPNP_E_INVALID_DESC"}, | ||||
| @@ -90,10 +63,7 @@ struct ErrorString ErrorMessages[] = { | ||||
| {UPNP_E_INVALID_ACTION, "UPNP_E_INVALID_ACTION"}, | ||||
| {UPNP_E_FINISH, "UPNP_E_FINISH"}, | ||||
| {UPNP_E_INIT_FAILED, "UPNP_E_INIT_FAILED"}, | ||||
| 	{UPNP_E_URL_TOO_BIG, "UPNP_E_URL_TOO_BIG"}, | ||||
| {UPNP_E_BAD_HTTPMSG, "UPNP_E_BAD_HTTPMSG"}, | ||||
| 	{UPNP_E_ALREADY_REGISTERED, "UPNP_E_ALREADY_REGISTERED"}, | ||||
| 	{UPNP_E_INVALID_INTERFACE, "UPNP_E_INVALID_INTERFACE"}, | ||||
| {UPNP_E_NETWORK_ERROR, "UPNP_E_NETWORK_ERROR"}, | ||||
| {UPNP_E_SOCKET_WRITE, "UPNP_E_SOCKET_WRITE"}, | ||||
| {UPNP_E_SOCKET_READ, "UPNP_E_SOCKET_READ"}, | ||||
| @@ -101,107 +71,112 @@ struct ErrorString ErrorMessages[] = { | ||||
| {UPNP_E_SOCKET_CONNECT, "UPNP_E_SOCKET_CONNECT"}, | ||||
| {UPNP_E_OUTOF_SOCKET, "UPNP_E_OUTOF_SOCKET"}, | ||||
| {UPNP_E_LISTEN, "UPNP_E_LISTEN"}, | ||||
| 	{UPNP_E_TIMEDOUT, "UPNP_E_TIMEDOUT"}, | ||||
| 	{UPNP_E_SOCKET_ERROR, "UPNP_E_SOCKET_ERROR"}, | ||||
| 	{UPNP_E_FILE_WRITE_ERROR, "UPNP_E_FILE_WRITE_ERROR"}, | ||||
| 	{UPNP_E_CANCELED, "UPNP_E_CANCELED"}, | ||||
| {UPNP_E_EVENT_PROTOCOL, "UPNP_E_EVENT_PROTOCOL"}, | ||||
| {UPNP_E_SUBSCRIBE_UNACCEPTED, "UPNP_E_SUBSCRIBE_UNACCEPTED"}, | ||||
| {UPNP_E_UNSUBSCRIBE_UNACCEPTED, "UPNP_E_UNSUBSCRIBE_UNACCEPTED"}, | ||||
| {UPNP_E_NOTIFY_UNACCEPTED, "UPNP_E_NOTIFY_UNACCEPTED"}, | ||||
| 	{UPNP_E_INVALID_ARGUMENT, "UPNP_E_INVALID_ARGUMENT"}, | ||||
| 	{UPNP_E_FILE_NOT_FOUND, "UPNP_E_FILE_NOT_FOUND"}, | ||||
| 	{UPNP_E_FILE_READ_ERROR, "UPNP_E_FILE_READ_ERROR"}, | ||||
| 	{UPNP_E_EXT_NOT_XML, "UPNP_E_EXT_NOT_XML"}, | ||||
| 	{UPNP_E_NO_WEB_SERVER, "UPNP_E_NO_WEB_SERVER"}, | ||||
| 	{UPNP_E_OUTOF_BOUNDS, "UPNP_E_OUTOF_BOUNDS"}, | ||||
| 	{UPNP_E_NOT_FOUND, "UPNP_E_NOT_FOUND"}, | ||||
| {UPNP_E_INTERNAL_ERROR, "UPNP_E_INTERNAL_ERROR"}, | ||||
| {UPNP_E_INVALID_ARGUMENT, "UPNP_E_INVALID_ARGUMENT"}, | ||||
| {UPNP_E_OUTOF_BOUNDS, "UPNP_E_OUTOF_BOUNDS"} | ||||
| }; | ||||
|  | ||||
| const char *UpnpGetErrorMessage(int rc) | ||||
| /************************************************************************ | ||||
| * Function : UpnpGetErrorMessage | ||||
| * | ||||
| * Parameters: | ||||
| *	IN int rc: error code | ||||
| * | ||||
| * Description: | ||||
| *	This functions returns the error string mapped to the error code | ||||
| * Returns: const char * | ||||
| *	return either the right string or "Unknown Error" | ||||
| ***************************************************************************/ | ||||
| const char * | ||||
| UpnpGetErrorMessage( IN int rc ) | ||||
| { | ||||
| 	size_t i; | ||||
|     int i; | ||||
|  | ||||
| 	for (i = 0; i < sizeof (ErrorMessages) / sizeof (ErrorMessages[0]); ++i) { | ||||
| 		if (rc == ErrorMessages[i].rc) { | ||||
|     for( i = 0; i < sizeof( ErrorMessages ) / sizeof( ErrorMessages[0] ); | ||||
|          i++ ) { | ||||
|         if( rc == ErrorMessages[i].rc ) | ||||
|             return ErrorMessages[i].rcError; | ||||
| 		} | ||||
|  | ||||
|     } | ||||
|  | ||||
| 	return "Unknown error code"; | ||||
|     return "Unknown Error"; | ||||
|  | ||||
| } | ||||
|  | ||||
| /*! | ||||
|  * \todo There is some unnecessary allocation and deallocation going on here | ||||
|  * because of the way resolve_rel_url() was originally written and used. In the | ||||
|  * future it would be nice to clean this up. | ||||
|  */ | ||||
| int UpnpResolveURL( | ||||
| 	const char *BaseURL, | ||||
| 	const char *RelURL, | ||||
| 	char *AbsURL) | ||||
| /************************************************************************ | ||||
| * Function : UpnpResolveURL | ||||
| * | ||||
| * Parameters: | ||||
| *	IN char * BaseURL: Base URL string | ||||
| *	IN char * RelURL: relative URL string | ||||
| *	OUT char * AbsURL: Absolute URL string | ||||
| * Description: | ||||
| *	This functions concatinates the base URL and relative URL to generate | ||||
| *	the absolute URL | ||||
| * Returns: int | ||||
| *	return either UPNP_E_SUCCESS or appropriate error | ||||
| ***************************************************************************/ | ||||
| int | ||||
| UpnpResolveURL( IN const char *BaseURL, | ||||
|                 IN const char *RelURL, | ||||
|                 OUT char *AbsURL ) | ||||
| { | ||||
| 	int ret = UPNP_E_SUCCESS; | ||||
| 	char *tempRel = NULL; | ||||
|     // There is some unnecessary allocation and | ||||
|     // deallocation going on here because of the way | ||||
|     // resolve_rel_url was originally written and used | ||||
|     // in the future it would be nice to clean this up | ||||
|  | ||||
|     char *tempRel; | ||||
|  | ||||
|     if( RelURL == NULL ) | ||||
|         return UPNP_E_INVALID_PARAM; | ||||
|  | ||||
|     tempRel = NULL; | ||||
|  | ||||
| 	if (!RelURL) { | ||||
| 		ret = UPNP_E_INVALID_PARAM; | ||||
| 		goto ExitFunction; | ||||
| 	} | ||||
|     tempRel = resolve_rel_url((char*) BaseURL, (char*) RelURL ); | ||||
|  | ||||
|     if( tempRel ) { | ||||
|         strcpy( AbsURL, tempRel ); | ||||
|         free( tempRel ); | ||||
| 	} else | ||||
| 		ret = UPNP_E_INVALID_URL; | ||||
|     } else { | ||||
|         return UPNP_E_INVALID_URL; | ||||
|     } | ||||
|  | ||||
| ExitFunction: | ||||
|     return UPNP_E_SUCCESS; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpResolveURL2( | ||||
| 	const char *BaseURL, | ||||
| 	const char *RelURL, | ||||
| 	char **AbsURL) | ||||
| { | ||||
| 	int ret = UPNP_E_SUCCESS; | ||||
|  | ||||
| 	if (!RelURL) { | ||||
| 		ret = UPNP_E_INVALID_PARAM; | ||||
| 		goto ExitFunction; | ||||
| 	} | ||||
| 	*AbsURL = resolve_rel_url((char *)BaseURL, (char *)RelURL); | ||||
| 	if (!*AbsURL) | ||||
| 		ret = UPNP_E_INVALID_URL; | ||||
|  | ||||
| ExitFunction: | ||||
| 	return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Adds the argument in the action request or response. | ||||
| /************************************************************************ | ||||
| * Function : addToAction | ||||
| * | ||||
| * Parameters: | ||||
| *	IN int response: flag to tell if the ActionDoc is for response | ||||
| *		or request | ||||
| *	INOUT IXML_Document **ActionDoc: request or response document | ||||
| *	IN char *ActionName: Name of the action request or response | ||||
| *	IN char *ServType: Service type | ||||
| *	IN char * ArgName: Name of the argument | ||||
| *	IN char * ArgValue: Value of the argument | ||||
| * | ||||
| * Description: | ||||
| *	This function adds the argument in the action request or response. | ||||
| * This function creates the action request or response if it is a first | ||||
|  * argument, otherwise it will add the argument in the document. | ||||
| * argument else it will add the argument in the document | ||||
| * | ||||
|  * \returns UPNP_E_SUCCESS if successful, otherwise the appropriate error. | ||||
|  */ | ||||
| static int addToAction( | ||||
| 	/*! [in] flag to tell if the ActionDoc is for response or request. */ | ||||
| 	int response, | ||||
| 	/*! [in,out] Request or response document. */ | ||||
| 	IXML_Document **ActionDoc, | ||||
| 	/*! [in] Name of the action request or response. */ | ||||
| 	const char *ActionName, | ||||
| 	/*! [in] Service type. */ | ||||
| 	const char *ServType, | ||||
| 	/*! [in] Name of the argument. */ | ||||
| 	const char *ArgName, | ||||
| 	/*! [in] Value of the argument. */ | ||||
| 	const char *ArgValue) | ||||
| * Returns: int | ||||
| *	returns UPNP_E_SUCCESS if successful else returns appropriate error | ||||
| ***************************************************************************/ | ||||
| static int | ||||
| addToAction( IN int response, | ||||
|              INOUT IXML_Document ** ActionDoc, | ||||
|              IN const char *ActionName, | ||||
|              IN const char *ServType, | ||||
|              IN const char *ArgName, | ||||
|              IN const char *ArgValue ) | ||||
| { | ||||
|     char *ActBuff = NULL; | ||||
|     IXML_Node *node = NULL; | ||||
| @@ -247,32 +222,39 @@ static int addToAction( | ||||
|             Txt = ixmlDocument_createTextNode( *ActionDoc, ArgValue ); | ||||
|             ixmlNode_appendChild( ( IXML_Node * ) Ele, Txt ); | ||||
|         } | ||||
|  | ||||
|         ixmlNode_appendChild( node, ( IXML_Node * ) Ele ); | ||||
|     } | ||||
|  | ||||
|     return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Creates the action request or response from the argument list. | ||||
| /************************************************************************ | ||||
| * Function : makeAction | ||||
| * | ||||
|  * \return Action request or response document if successful, otherwise | ||||
|  * 	returns NULL | ||||
|  */ | ||||
| static IXML_Document *makeAction( | ||||
| 	/*! [in] flag to tell if the ActionDoc is for response or request. */ | ||||
| 	int response, | ||||
| 	/*! [in] Name of the action request or response. */ | ||||
| 	const char *ActionName, | ||||
| 	/*! [in] Service type. */ | ||||
| 	const char *ServType, | ||||
| 	/*! [in] Number of arguments in the action request or response. */ | ||||
| 	int NumArg, | ||||
| 	/*! [in] pointer to the first argument. */ | ||||
| 	const char *Arg, | ||||
| 	/*! [in] Argument list. */ | ||||
| 	va_list ArgList) | ||||
| * Parameters: | ||||
| *	IN int response: flag to tell if the ActionDoc is for response | ||||
| *		or request | ||||
| *	IN char * ActionName: Name of the action request or response | ||||
| *	IN char * ServType: Service type | ||||
| *	IN int NumArg :Number of arguments in the action request or response | ||||
| *	IN char * Arg : pointer to the first argument | ||||
| *	IN va_list ArgList: Argument list | ||||
| * | ||||
| * Description: | ||||
| *	This function creates the action request or response from the argument | ||||
| * list. | ||||
| * Returns: IXML_Document * | ||||
| *	returns action request or response document if successful | ||||
| *	else returns NULL | ||||
| ***************************************************************************/ | ||||
| static IXML_Document * | ||||
| makeAction( IN int response, | ||||
|             IN const char *ActionName, | ||||
|             IN const char *ServType, | ||||
|             IN int NumArg, | ||||
|             IN const char *Arg, | ||||
|             IN va_list ArgList ) | ||||
| { | ||||
|     const char *ArgName; | ||||
|     const char *ArgValue; | ||||
| @@ -301,45 +283,70 @@ static IXML_Document *makeAction( | ||||
|             "<u:%s xmlns:u=\"%s\">\r\n</u:%s>", | ||||
|             ActionName, ServType, ActionName ); | ||||
|     } | ||||
|  | ||||
|     if( ixmlParseBufferEx( ActBuff, &ActionDoc ) != IXML_SUCCESS ) { | ||||
|         free( ActBuff ); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     free( ActBuff ); | ||||
|  | ||||
|     if( ActionDoc == NULL ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     if( NumArg > 0 ) { | ||||
| 		/*va_start(ArgList, Arg); */ | ||||
|         //va_start(ArgList, Arg); | ||||
|         ArgName = Arg; | ||||
|         for ( ; ; ) { | ||||
|             ArgValue = va_arg( ArgList, const char * ); | ||||
|  | ||||
|             if( ArgName != NULL ) { | ||||
|                 node = ixmlNode_getFirstChild( ( IXML_Node * ) ActionDoc ); | ||||
|                 Ele = ixmlDocument_createElement( ActionDoc, ArgName ); | ||||
|                 if( ArgValue ) { | ||||
| 					Txt = ixmlDocument_createTextNode(ActionDoc, ArgValue); | ||||
|                     Txt = | ||||
|                         ixmlDocument_createTextNode( ActionDoc, ArgValue ); | ||||
|                     ixmlNode_appendChild( ( IXML_Node * ) Ele, Txt ); | ||||
|                 } | ||||
|  | ||||
|                 ixmlNode_appendChild( node, ( IXML_Node * ) Ele ); | ||||
|             } | ||||
|  | ||||
|             if (++Idx < NumArg) { | ||||
|                 ArgName = va_arg( ArgList, const char * ); | ||||
|             } else { | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
| 		/*va_end(ArgList); */ | ||||
|         //va_end(ArgList); | ||||
|     } | ||||
|  | ||||
|     return ActionDoc; | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Document *UpnpMakeAction( | ||||
| 	const char *ActionName, | ||||
| /************************************************************************ | ||||
| * Function : UpnpMakeAction | ||||
| * | ||||
| * Parameters: | ||||
| *	IN char * ActionName: Name of the action request or response | ||||
| *	IN char * ServType: Service type | ||||
| *	IN int NumArg :Number of arguments in the action request or response | ||||
| *	IN char * Arg : pointer to the first argument | ||||
| *	IN ... : variable argument list | ||||
| *	IN va_list ArgList: Argument list | ||||
| * | ||||
| * Description: | ||||
| *	This function creates the action request from the argument | ||||
| * list. Its a wrapper function that calls makeAction function to create | ||||
| * the action request. | ||||
| * | ||||
| * Returns: IXML_Document * | ||||
| *	returns action request document if successful  | ||||
| *	else returns NULL | ||||
| ***************************************************************************/ | ||||
| IXML_Document * | ||||
| UpnpMakeAction( const char *ActionName, | ||||
|                 const char *ServType, | ||||
|                 int NumArg, | ||||
|                 const char *Arg, | ||||
| @@ -355,9 +362,28 @@ IXML_Document *UpnpMakeAction( | ||||
|     return out; | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Document *UpnpMakeActionResponse( | ||||
| 	const char *ActionName, | ||||
| /************************************************************************ | ||||
| * Function : UpnpMakeActionResponse | ||||
| * | ||||
| * Parameters: | ||||
| *	IN char * ActionName: Name of the action request or response | ||||
| *	IN char * ServType: Service type | ||||
| *	IN int NumArg :Number of arguments in the action request or response | ||||
| *	IN char * Arg : pointer to the first argument | ||||
| *	IN ... : variable argument list | ||||
| *	IN va_list ArgList: Argument list | ||||
| * | ||||
| * Description: | ||||
| *	This function creates the action response from the argument | ||||
| * list. Its a wrapper function that calls makeAction function to create | ||||
| * the action response. | ||||
| * | ||||
| * Returns: IXML_Document * | ||||
| *	returns action response document if successful | ||||
| *	else returns NULL | ||||
| ***************************************************************************/ | ||||
| IXML_Document * | ||||
| UpnpMakeActionResponse( const char *ActionName, | ||||
|                         const char *ServType, | ||||
|                         int NumArg, | ||||
|                         const char *Arg, | ||||
| @@ -373,86 +399,89 @@ IXML_Document *UpnpMakeActionResponse( | ||||
|     return out; | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
| * Function : UpnpAddToActionResponse | ||||
| * | ||||
| * Parameters: | ||||
| *	INOUT IXML_Document **ActionResponse: action response document | ||||
| *	IN char * ActionName: Name of the action request or response | ||||
| *	IN char * ServType: Service type | ||||
| *	IN int ArgName :Name of argument to be added in the action response | ||||
| *	IN char * ArgValue : value of the argument | ||||
| * | ||||
| * Description: | ||||
| *	This function adds the argument in the action response. Its a wrapper | ||||
| * function that calls addToAction function to add the argument in the | ||||
| * action response. | ||||
| * | ||||
| * Returns: int | ||||
| *	returns UPNP_E_SUCCESS if successful | ||||
| *	else returns appropriate error | ||||
| ***************************************************************************/ | ||||
| int | ||||
| UpnpAddToActionResponse( INOUT IXML_Document ** ActionResponse, | ||||
|                          IN const char *ActionName, | ||||
|                          IN const char *ServType, | ||||
|                          IN const char *ArgName, | ||||
|                          IN const char *ArgValue ) | ||||
| { | ||||
|     return addToAction( 1, ActionResponse, ActionName, ServType, ArgName, | ||||
|                         ArgValue ); | ||||
| } | ||||
|  | ||||
| int UpnpAddToAction( | ||||
| 	IXML_Document **ActionDoc, | ||||
| /************************************************************************ | ||||
| * Function : UpnpAddToAction | ||||
| * | ||||
| * Parameters: | ||||
| *	INOUT IXML_Document **ActionDoc: action request document | ||||
| *	IN char * ActionName: Name of the action request or response | ||||
| *	IN char * ServType: Service type | ||||
| *	IN int ArgName :Name of argument to be added in the action response | ||||
| *	IN char * ArgValue : value of the argument | ||||
| * | ||||
| * Description: | ||||
| *	This function adds the argument in the action request. Its a wrapper | ||||
| * function that calls addToAction function to add the argument in the | ||||
| * action request. | ||||
| * | ||||
| * Returns: int | ||||
| *	returns UPNP_E_SUCCESS if successful | ||||
| *	else returns appropriate error | ||||
| ***************************************************************************/ | ||||
| int | ||||
| UpnpAddToAction( IXML_Document ** ActionDoc, | ||||
|                  const char *ActionName, | ||||
|                  const char *ServType, | ||||
|                  const char *ArgName, | ||||
|                  const char *ArgValue ) | ||||
| { | ||||
| 	return addToAction(0, ActionDoc, ActionName, ServType, ArgName, ArgValue); | ||||
|  | ||||
|     return addToAction( 0, ActionDoc, ActionName, ServType, ArgName, | ||||
|                         ArgValue ); | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpAddToActionResponse( | ||||
| 	IXML_Document **ActionResponse, | ||||
| 	const char *ActionName, | ||||
| 	const char *ServType, | ||||
| 	const char *ArgName, | ||||
| 	const char *ArgValue) | ||||
| /************************************************************************ | ||||
| * Function : UpnpAddToPropertySet | ||||
| * | ||||
| * Parameters: | ||||
| *	INOUT IXML_Document **PropSet: propertyset document | ||||
| *	IN char *ArgName: Name of the argument | ||||
| *	IN char *ArgValue: value of the argument | ||||
| * | ||||
| * Description: | ||||
| *	This function adds the argument in the propertyset node | ||||
| * | ||||
| * Returns: int | ||||
| *	returns UPNP_E_SUCCESS if successful else returns appropriate error | ||||
| ***************************************************************************/ | ||||
| int | ||||
| UpnpAddToPropertySet( INOUT IXML_Document ** PropSet, | ||||
|                       IN const char *ArgName, | ||||
|                       IN const char *ArgValue ) | ||||
| { | ||||
| 	return addToAction(1, ActionResponse, ActionName, ServType, ArgName, ArgValue); | ||||
| } | ||||
|  | ||||
|  | ||||
| IXML_Document *UpnpCreatePropertySet( | ||||
| 	int NumArg, | ||||
| 	const char *Arg, | ||||
| 	...) | ||||
| { | ||||
| 	va_list ArgList; | ||||
| 	int Idx = 0; | ||||
| 	char BlankDoc[] = | ||||
| 		"<e:propertyset xmlns:e=\"urn:schemas-upnp-org:event-1-0\">" | ||||
| 		"</e:propertyset>"; | ||||
| 	const char *ArgName, | ||||
| 	*ArgValue; | ||||
| 	IXML_Node *node; | ||||
| 	IXML_Element *Ele; | ||||
| 	IXML_Element *Ele1; | ||||
| 	IXML_Node *Txt; | ||||
| 	IXML_Document *PropSet; | ||||
|  | ||||
| 	if(ixmlParseBufferEx(BlankDoc, &PropSet) != IXML_SUCCESS) { | ||||
| 		return NULL; | ||||
| 	} | ||||
|  | ||||
| 	if (NumArg < 1) { | ||||
| 		return PropSet; | ||||
| 	} | ||||
|  | ||||
| 	va_start(ArgList, Arg); | ||||
| 	ArgName = Arg; | ||||
| 	while (Idx++ != NumArg) { | ||||
| 		ArgValue = va_arg(ArgList, const char *); | ||||
| 		if (ArgName != NULL /*&& ArgValue != NULL */) { | ||||
| 			node = ixmlNode_getFirstChild((IXML_Node *)PropSet); | ||||
| 			Ele1 = ixmlDocument_createElement(PropSet, "e:property"); | ||||
| 			Ele = ixmlDocument_createElement(PropSet, ArgName); | ||||
| 			if (ArgValue) { | ||||
| 				Txt = ixmlDocument_createTextNode(PropSet, ArgValue); | ||||
| 				ixmlNode_appendChild((IXML_Node *)Ele, Txt); | ||||
| 			} | ||||
| 			ixmlNode_appendChild((IXML_Node *)Ele1, (IXML_Node *)Ele); | ||||
| 			ixmlNode_appendChild(             node, (IXML_Node *)Ele1); | ||||
| 		} | ||||
| 		ArgName = va_arg(ArgList, const char *); | ||||
| 	} | ||||
| 	va_end(ArgList); | ||||
|  | ||||
| 	return PropSet; | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpAddToPropertySet( | ||||
| 	IXML_Document **PropSet, | ||||
| 	const char *ArgName, | ||||
| 	const char *ArgValue) | ||||
| { | ||||
| 	char BlankDoc[] = | ||||
| 		"<e:propertyset xmlns:e=\"urn:schemas-upnp-org:event-1-0\">" | ||||
| 		"</e:propertyset>"; | ||||
|     char BlankDoc[] = "<e:propertyset xmlns:e=\"urn:schemas" | ||||
|         "-upnp-org:event-1-0\"></e:propertyset>"; | ||||
|     IXML_Node *node; | ||||
|     IXML_Element *Ele; | ||||
|     IXML_Element *Ele1; | ||||
| @@ -486,6 +515,71 @@ int UpnpAddToPropertySet( | ||||
|     return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
| * Function : UpnpCreatePropertySet | ||||
| * | ||||
| * Parameters: | ||||
| *	IN int NumArg: Number of argument that will go in the propertyset node | ||||
| *	IN char * Args: argument strings | ||||
| * | ||||
| * Description: | ||||
| *	This function creates a propertyset node and put all the input | ||||
| *	parameters in the node as elements | ||||
| * | ||||
| * Returns: IXML_Document * | ||||
| *	returns the document containing propertyset node. | ||||
| ***************************************************************************/ | ||||
| IXML_Document * | ||||
| UpnpCreatePropertySet( IN int NumArg, | ||||
|                        IN const char *Arg, | ||||
|                        ... ) | ||||
| { | ||||
|     va_list ArgList; | ||||
|     int Idx = 0; | ||||
|     char BlankDoc[] = "<e:propertyset xmlns:e=\"urn:schemas-" | ||||
|         "upnp-org:event-1-0\"></e:propertyset>"; | ||||
|     const char *ArgName, | ||||
|      *ArgValue; | ||||
|     IXML_Node *node; | ||||
|     IXML_Element *Ele; | ||||
|     IXML_Element *Ele1; | ||||
|     IXML_Node *Txt; | ||||
|     IXML_Document *PropSet; | ||||
|  | ||||
| #endif /* EXCLUDE_DOM == 0 */ | ||||
|     if( ixmlParseBufferEx( BlankDoc, &PropSet ) != IXML_SUCCESS ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     if( NumArg < 1 ) { | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     va_start( ArgList, Arg ); | ||||
|     ArgName = Arg; | ||||
|  | ||||
|     while( Idx++ != NumArg ) { | ||||
|         ArgValue = va_arg( ArgList, const char * ); | ||||
|  | ||||
|         if( ArgName != NULL /*&& ArgValue != NULL */  ) { | ||||
|             node = ixmlNode_getFirstChild( ( IXML_Node * ) PropSet ); | ||||
|             Ele1 = ixmlDocument_createElement( PropSet, "e:property" ); | ||||
|             Ele = ixmlDocument_createElement( PropSet, ArgName ); | ||||
|             if( ArgValue ) { | ||||
|                 Txt = ixmlDocument_createTextNode( PropSet, ArgValue ); | ||||
|                 ixmlNode_appendChild( ( IXML_Node * ) Ele, Txt ); | ||||
|             } | ||||
|  | ||||
|             ixmlNode_appendChild( ( IXML_Node * ) Ele1, | ||||
|                                   ( IXML_Node * ) Ele ); | ||||
|             ixmlNode_appendChild( node, ( IXML_Node * ) Ele1 ); | ||||
|         } | ||||
|  | ||||
|         ArgName = va_arg( ArgList, const char * ); | ||||
|  | ||||
|     } | ||||
|     va_end( ArgList ); | ||||
|     return PropSet; | ||||
| } | ||||
|  | ||||
| #endif // EXCLUDE_DOM == 0 | ||||
|  | ||||
|   | ||||
| @@ -1,33 +1,33 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer. | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer in the documentation | ||||
|  * and/or other materials provided with the distribution. | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors | ||||
|  * may be used to endorse or promote products derived from this software | ||||
|  * without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #include "config.h" | ||||
| #if EXCLUDE_GENA == 0 | ||||
| @@ -63,7 +63,7 @@ error_respond( IN SOCKINFO * info, | ||||
|     int major, | ||||
|       minor; | ||||
|  | ||||
|     /* retrieve the minor and major version from the GENA request */ | ||||
|     // retrieve the minor and major version from the GENA request | ||||
|     http_CalcResponseVersion( hmsg->major_version, | ||||
|                               hmsg->minor_version, &major, &minor ); | ||||
|  | ||||
| @@ -90,40 +90,38 @@ genaCallback( IN http_parser_t * parser, | ||||
|               IN http_message_t * request, | ||||
|               INOUT SOCKINFO * info ) | ||||
| { | ||||
|     int found_function = FALSE; | ||||
|     xboolean found_function = FALSE; | ||||
|  | ||||
|     if( request->method == HTTPMETHOD_SUBSCRIBE ) { | ||||
| #ifdef INCLUDE_DEVICE_APIS | ||||
|         found_function = TRUE; | ||||
|         if( httpmsg_find_hdr( request, HDR_NT, NULL ) == NULL ) { | ||||
|             /* renew subscription */ | ||||
|             // renew subscription | ||||
|             gena_process_subscription_renewal_request | ||||
|             ( info, request ); | ||||
| 	} else { | ||||
|             /* subscribe */ | ||||
|             // subscribe | ||||
|             gena_process_subscription_request( info, request ); | ||||
| 	} | ||||
|         UpnpPrintf( UPNP_ALL, GENA, __FILE__, __LINE__, | ||||
|             "got subscription request\n" ); | ||||
|     } else if( request->method == HTTPMETHOD_UNSUBSCRIBE ) { | ||||
|         found_function = TRUE; | ||||
|         /* unsubscribe */ | ||||
|         // unsubscribe | ||||
|         gena_process_unsubscribe_request( info, request ); | ||||
| #endif | ||||
|     } else if( request->method == HTTPMETHOD_NOTIFY ) { | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
|         found_function = TRUE; | ||||
|         /* notify */ | ||||
|         // notify | ||||
|         gena_process_notification_event( info, request ); | ||||
| #endif | ||||
|     } | ||||
|  | ||||
|     if( !found_function ) { | ||||
|             /* handle missing functions of device or ctrl pt */ | ||||
|             // handle missing functions of device or ctrl pt | ||||
|             error_respond( info, HTTP_NOT_IMPLEMENTED, request ); | ||||
|     } | ||||
|     return; | ||||
|     parser = parser; | ||||
| } | ||||
| #endif /* EXCLUDE_GENA */ | ||||
| #endif // EXCLUDE_GENA | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,33 +1,33 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /************************************************************************ | ||||
| * Purpose: This file defines the functions for clients. It defines  | ||||
| @@ -36,294 +36,174 @@ | ||||
| * client   | ||||
| ************************************************************************/ | ||||
|  | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
|  | ||||
| #include "client_table.h" | ||||
|  | ||||
|  | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
|  | ||||
|  | ||||
| #include <stdlib.h> /* for calloc(), free() */ | ||||
|  | ||||
|  | ||||
| struct SClientSubscription { | ||||
| 	int m_renewEventId; | ||||
| 	UpnpString *m_SID; | ||||
| 	UpnpString *m_actualSID; | ||||
| 	UpnpString *m_eventURL; | ||||
| 	struct SClientSubscription *m_next; | ||||
| }; | ||||
|  | ||||
|  | ||||
| /** Constructor */ | ||||
| ClientSubscription *UpnpClientSubscription_new() | ||||
| { | ||||
| 	struct SClientSubscription *p = calloc(1, sizeof (struct SClientSubscription)); | ||||
| #if 0 | ||||
| 	p->renewEventId =  0; | ||||
| #endif | ||||
| 	p->m_SID = UpnpString_new(); | ||||
| 	p->m_actualSID = UpnpString_new(); | ||||
| 	p->m_eventURL = UpnpString_new(); | ||||
| 	p->m_next = NULL; | ||||
|  | ||||
| 	return (ClientSubscription *)p; | ||||
| /************************************************************************ | ||||
| *	Function :	copy_client_subscription | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription * in ;	- source client subscription | ||||
| *		client_subscription * out ;	- destination client subscription | ||||
| * | ||||
| *	Description :	Make a copy of the client subscription data | ||||
| * | ||||
| *	Return : int ; | ||||
| *		UPNP_E_OUTOF_MEMORY - On Failure to allocate memory | ||||
| *		HTTP_SUCCESS - On Success | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| CLIENTONLY( int copy_client_subscription( client_subscription * in, | ||||
|                                           client_subscription * out ) { | ||||
|             int len = strlen( in->ActualSID ) + 1; | ||||
|             int len1 = strlen( in->EventURL ) + 1; | ||||
|             memcpy( out->sid, in->sid, SID_SIZE ); | ||||
|             out->sid[SID_SIZE] = 0; | ||||
|             out->ActualSID = ( char * )malloc( len ); | ||||
|             if( out->ActualSID == NULL ) | ||||
|                 return UPNP_E_OUTOF_MEMORY; | ||||
|             out->EventURL = ( char * )malloc( len1 ); | ||||
|             if( out->EventURL == NULL ) { | ||||
|                 free(out->ActualSID); | ||||
|                 return UPNP_E_OUTOF_MEMORY; | ||||
|             } | ||||
|             memcpy( out->ActualSID, in->ActualSID, len ); | ||||
|             memcpy( out->EventURL, in->EventURL, len1 ); | ||||
|             //copies do not get RenewEvent Ids or next | ||||
|             out->RenewEventId = -1; out->next = NULL; return HTTP_SUCCESS;} | ||||
|  | ||||
|  | ||||
| /** Destructor */ | ||||
| void UpnpClientSubscription_delete(ClientSubscription *p) | ||||
| /************************************************************************ | ||||
| *	Function :	free_client_subscription | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription * sub ;	- Client subscription to be freed | ||||
| * | ||||
| *	Description :	Free memory allocated for client subscription data. | ||||
| *		Remove timer thread associated with this subscription event. | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
|             void free_client_subscription( client_subscription * sub ) { | ||||
|             upnp_timeout * event; ThreadPoolJob tempJob; if( sub ) { | ||||
|             if( sub->ActualSID ) | ||||
|             free( sub->ActualSID ); if( sub->EventURL ) | ||||
|             free( sub->EventURL ); if( sub->RenewEventId != -1 )    //do not remove timer event of copy | ||||
|             //invalid timer event id | ||||
|             { | ||||
| 	struct SClientSubscription *q = (struct SClientSubscription *)p; | ||||
|  | ||||
| 	if (!q) return; | ||||
|  | ||||
| 	q->m_renewEventId = 0; | ||||
|  | ||||
| 	UpnpString_delete(q->m_SID); | ||||
| 	q->m_SID = NULL; | ||||
|  | ||||
| 	UpnpString_delete(q->m_actualSID); | ||||
| 	q->m_actualSID = NULL; | ||||
|  | ||||
| 	UpnpString_delete(q->m_eventURL); | ||||
| 	q->m_eventURL = NULL; | ||||
|  | ||||
| 	q->m_next = NULL; | ||||
|  | ||||
| 	free(p); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** Copy Constructor */ | ||||
| ClientSubscription *UpnpClientSubscription_dup(const ClientSubscription *p) | ||||
| { | ||||
| 	ClientSubscription *q = UpnpClientSubscription_new(); | ||||
| 	 | ||||
| 	UpnpClientSubscription_assign(q, p); | ||||
| 	 | ||||
| 	return q; | ||||
| } | ||||
|  | ||||
|  | ||||
| /** Assignment operator */ | ||||
| void UpnpClientSubscription_assign(ClientSubscription *q, const ClientSubscription *p) | ||||
| { | ||||
| 	if (q != p) { | ||||
| 		/* Do not copy RenewEventId */ | ||||
| 		((struct SClientSubscription *)q)->m_renewEventId = -1; | ||||
| 		UpnpClientSubscription_set_SID(q, UpnpClientSubscription_get_SID(p)); | ||||
| 		UpnpClientSubscription_set_ActualSID(q, UpnpClientSubscription_get_ActualSID(p)); | ||||
| 		UpnpClientSubscription_set_EventURL(q, UpnpClientSubscription_get_EventURL(p)); | ||||
| 		/* Do not copy m_next */ | ||||
| 		((struct SClientSubscription *)q)->m_next = NULL; | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
| int UpnpClientSubscription_get_RenewEventId(const ClientSubscription *p) | ||||
| { | ||||
| 	return ((struct SClientSubscription *)p)->m_renewEventId; | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_set_RenewEventId(ClientSubscription *p, int n) | ||||
| { | ||||
| 	((struct SClientSubscription *)p)->m_renewEventId = n; | ||||
| } | ||||
|  | ||||
|  | ||||
| const UpnpString *UpnpClientSubscription_get_SID(const ClientSubscription *p) | ||||
| { | ||||
| 	return ((struct SClientSubscription *)p)->m_SID; | ||||
| } | ||||
|  | ||||
| const char *UpnpClientSubscription_get_SID_cstr(const ClientSubscription *p) | ||||
| { | ||||
| 	return UpnpString_get_String(UpnpClientSubscription_get_SID(p)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_set_SID(ClientSubscription *p, const UpnpString *s) | ||||
| { | ||||
| 	UpnpString_delete(((struct SClientSubscription *)p)->m_SID); | ||||
| 	((struct SClientSubscription *)p)->m_SID = UpnpString_dup(s); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_strcpy_SID(ClientSubscription *p, const char *s) | ||||
| { | ||||
| 	UpnpString_delete(((struct SClientSubscription *)p)->m_SID); | ||||
| 	((struct SClientSubscription *)p)->m_SID = UpnpString_new(); | ||||
| 	UpnpString_set_String(((struct SClientSubscription *)p)->m_SID, s); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| const UpnpString *UpnpClientSubscription_get_ActualSID(const ClientSubscription *p) | ||||
| { | ||||
| 	return ((struct SClientSubscription *)p)->m_actualSID; | ||||
| } | ||||
|  | ||||
|  | ||||
| const char *UpnpClientSubscription_get_ActualSID_cstr(const ClientSubscription *p) | ||||
| { | ||||
| 	return UpnpString_get_String(UpnpClientSubscription_get_ActualSID(p)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_set_ActualSID(ClientSubscription *p, const UpnpString *s) | ||||
| { | ||||
| 	UpnpString_delete(((struct SClientSubscription *)p)->m_actualSID); | ||||
| 	((struct SClientSubscription *)p)->m_actualSID = UpnpString_dup(s); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_strcpy_ActualSID(ClientSubscription *p, const char *s) | ||||
| { | ||||
| 	UpnpString_delete(((struct SClientSubscription *)p)->m_actualSID); | ||||
| 	((struct SClientSubscription *)p)->m_actualSID = UpnpString_new(); | ||||
| 	UpnpString_set_String(((struct SClientSubscription *)p)->m_actualSID, s); | ||||
| } | ||||
|  | ||||
|  | ||||
| const UpnpString *UpnpClientSubscription_get_EventURL(const ClientSubscription *p) | ||||
| { | ||||
| 	return ((struct SClientSubscription *)p)->m_eventURL; | ||||
| } | ||||
|  | ||||
|  | ||||
| const char *UpnpClientSubscription_get_EventURL_cstr(const ClientSubscription *p) | ||||
| { | ||||
| 	return UpnpString_get_String(UpnpClientSubscription_get_EventURL(p)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_set_EventURL(ClientSubscription *p, const UpnpString *s) | ||||
| { | ||||
| 	UpnpString_delete(((struct SClientSubscription *)p)->m_eventURL); | ||||
| 	((struct SClientSubscription *)p)->m_eventURL = UpnpString_dup(s); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_strcpy_EventURL(ClientSubscription *p, const char *s) | ||||
| { | ||||
| 	UpnpString_delete(((struct SClientSubscription *)p)->m_eventURL); | ||||
| 	((struct SClientSubscription *)p)->m_eventURL = UpnpString_new(); | ||||
| 	UpnpString_set_String(((struct SClientSubscription *)p)->m_eventURL, s); | ||||
| } | ||||
|  | ||||
|  | ||||
| ClientSubscription *UpnpClientSubscription_get_Next(const ClientSubscription *p) | ||||
| { | ||||
| 	return (ClientSubscription *)(((struct SClientSubscription *)p)->m_next); | ||||
| } | ||||
|  | ||||
|  | ||||
| void UpnpClientSubscription_set_Next(ClientSubscription *p, ClientSubscription *q) | ||||
| { | ||||
| 	((struct SClientSubscription *)p)->m_next = (struct SClientSubscription *)q; | ||||
| } | ||||
|  | ||||
|  | ||||
| void free_client_subscription(ClientSubscription *sub) | ||||
| { | ||||
| 	upnp_timeout *event; | ||||
| 	ThreadPoolJob tempJob; | ||||
| 	if (sub) { | ||||
| 		int renewEventId = UpnpClientSubscription_get_RenewEventId(sub); | ||||
| 		UpnpClientSubscription_strcpy_ActualSID(sub, ""); | ||||
| 		UpnpClientSubscription_strcpy_EventURL(sub, ""); | ||||
| 		if (renewEventId != -1) { | ||||
| 			/* do not remove timer event of copy */ | ||||
| 			/* invalid timer event id */ | ||||
| 			if (TimerThreadRemove(&gTimerThread, renewEventId, &tempJob) == 0) { | ||||
|             if( TimerThreadRemove | ||||
|                 ( &gTimerThread, sub->RenewEventId, &tempJob ) == 0 ) { | ||||
|             event = ( upnp_timeout * ) tempJob.arg; | ||||
| 				free_upnp_timeout(event); | ||||
| 			} | ||||
| 		} | ||||
| 		UpnpClientSubscription_set_RenewEventId(sub, -1); | ||||
| 	} | ||||
|             free_upnp_timeout( event );} | ||||
|             } | ||||
|  | ||||
|             sub->RenewEventId = -1;} | ||||
|             } | ||||
|  | ||||
| void freeClientSubList(ClientSubscription *list) | ||||
| { | ||||
| 	ClientSubscription *next; | ||||
| 	while (list) { | ||||
| /************************************************************************ | ||||
| *	Function :	freeClientSubList | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription * list ; Client subscription  | ||||
| * | ||||
| *	Description :	Free the client subscription table. | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
|             void freeClientSubList( client_subscription * list ) { | ||||
|             client_subscription * next; while( list ) { | ||||
|             free_client_subscription( list ); | ||||
| 		next = UpnpClientSubscription_get_Next(list); | ||||
| 		UpnpClientSubscription_delete(list); | ||||
| 		list = next; | ||||
| 	} | ||||
|             next = list->next; free( list ); list = next;} | ||||
|             } | ||||
|  | ||||
|  | ||||
| void RemoveClientSubClientSID(ClientSubscription **head, const UpnpString *sid) | ||||
| /************************************************************************ | ||||
| *	Function :	RemoveClientSubClientSID | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription **head ; Head of the subscription list	 | ||||
| *		const Upnp_SID sid ;		 Subscription ID to be mactched | ||||
| * | ||||
| *	Description :	Remove the client subscription matching the  | ||||
| *		subscritpion id represented by the const Upnp_SID sid parameter  | ||||
| *		from the table and update the table. | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
|             void RemoveClientSubClientSID( client_subscription ** head, | ||||
|                                            const Upnp_SID sid ) { | ||||
|             client_subscription * finger = ( *head ); | ||||
|             client_subscription * previous = NULL; while( finger ) { | ||||
|             if( !( strcmp( sid, finger->sid ) ) ) { | ||||
|             if( previous ) | ||||
|             previous->next = finger->next; | ||||
|             else | ||||
|             ( *head ) = finger->next; | ||||
|             finger->next = NULL; | ||||
|             freeClientSubList( finger ); finger = NULL;} | ||||
|             else | ||||
|             { | ||||
| 	ClientSubscription *finger = *head; | ||||
| 	ClientSubscription *previous = NULL; | ||||
| 	int found = 0; | ||||
| 	while (finger) { | ||||
| 		found = !strcmp( | ||||
| 			UpnpString_get_String(sid), | ||||
| 			UpnpClientSubscription_get_SID_cstr(finger)); | ||||
| 		if (found) { | ||||
| 			if (previous) { | ||||
| 				UpnpClientSubscription_set_Next(previous, | ||||
| 					UpnpClientSubscription_get_Next(finger)); | ||||
| 			} else { | ||||
| 				*head = UpnpClientSubscription_get_Next(finger); | ||||
| 			} | ||||
| 			UpnpClientSubscription_set_Next(finger, NULL); | ||||
| 			freeClientSubList(finger); | ||||
| 			finger = NULL; | ||||
| 		} else { | ||||
| 			previous = finger; | ||||
| 			finger = UpnpClientSubscription_get_Next(finger); | ||||
| 		} | ||||
|             previous = finger; finger = finger->next;} | ||||
|             } | ||||
|             } | ||||
|  | ||||
|  | ||||
| ClientSubscription *GetClientSubClientSID(ClientSubscription *head, const UpnpString *sid) | ||||
| { | ||||
| 	ClientSubscription *next = head; | ||||
| 	int found = 0; | ||||
| 	while (next) { | ||||
| 		found = !strcmp( | ||||
| 			UpnpClientSubscription_get_SID_cstr(next), | ||||
| 			UpnpString_get_String(sid)); | ||||
| 		if(found) { | ||||
| /************************************************************************ | ||||
| *	Function :	GetClientSubClientSID | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription *head ; Head of the subscription list	 | ||||
| *		const Upnp_SID sid ;		Subscription ID to be matched | ||||
| * | ||||
| *	Description :	Return the client subscription from the client table  | ||||
| *		that matches const Upnp_SID sid subscrition id value.  | ||||
| * | ||||
| *	Return : client_subscription * ; The matching subscription | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
|             client_subscription * | ||||
|             GetClientSubClientSID( client_subscription * head, | ||||
|                                    const Upnp_SID sid ) { | ||||
|             client_subscription * next = head; while( next ) { | ||||
|             if( !strcmp( next->sid, sid ) ) | ||||
|             break; | ||||
| 		} else { | ||||
| 			next = UpnpClientSubscription_get_Next(next); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return next; | ||||
| } | ||||
|  | ||||
|  | ||||
| ClientSubscription *GetClientSubActualSID(ClientSubscription *head, token *sid) | ||||
|             else | ||||
|             { | ||||
| 	ClientSubscription *next = head; | ||||
| 	while (next) { | ||||
| 		if (!memcmp( | ||||
| 			UpnpClientSubscription_get_ActualSID_cstr(next), | ||||
| 			sid->buff, sid->size)) { | ||||
|             next = next->next;} | ||||
|             } | ||||
|             return next;} | ||||
|  | ||||
| /************************************************************************ | ||||
| *	Function :	GetClientSubActualSID | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription *head ;	Head of the subscription list		 | ||||
| *		token * sid ;				Subscription ID to be matched | ||||
| * | ||||
| *	Description :	Returns the client subscription from the client  | ||||
| *		subscription table that has the matching token * sid buffer | ||||
| *		value. | ||||
| * | ||||
| *	Return : client_subscription * ; The matching subscription | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
|             client_subscription * | ||||
|             GetClientSubActualSID( client_subscription * head, | ||||
|                                    token * sid ) { | ||||
|             client_subscription * next = head; while( next ) { | ||||
|  | ||||
|             if( !memcmp( next->ActualSID, sid->buff, sid->size ) ) | ||||
|             break; | ||||
| 		} else { | ||||
| 			next = UpnpClientSubscription_get_Next(next); | ||||
| 		} | ||||
|             else | ||||
|             { | ||||
|             next = next->next;} | ||||
|             } | ||||
|             return next;} | ||||
|  | ||||
| 	return next; | ||||
| } | ||||
|  | ||||
|  | ||||
|  #endif /* INCLUDE_CLIENT_APIS */ | ||||
|  | ||||
|  ) | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,60 +1,71 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer. | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer in the documentation | ||||
|  * and/or other materials provided with the distribution. | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors | ||||
|  * may be used to endorse or promote products derived from this software | ||||
|  * without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
|  * Purpose: This file a function to extract the header information from | ||||
|  * an http message and then matches the data with XML data. | ||||
|  */ | ||||
| /************************************************************************ | ||||
| * Purpose: This file a function to extract the header information from	* | ||||
| * an http message and then matches the data with XML data.				* | ||||
| ************************************************************************/ | ||||
|  | ||||
| #include "config.h" | ||||
| #include <assert.h> | ||||
| #include "upnputil.h" | ||||
| #include "util.h" | ||||
| #include "membuffer.h" | ||||
| #include "httpparser.h" | ||||
| #include "statcodes.h" | ||||
| #include "parsetools.h" | ||||
|  | ||||
| int has_xml_content_type(http_message_t *hmsg) | ||||
| /************************************************************************ | ||||
| * Function: has_xml_content_type										 | ||||
| *																		 | ||||
| * Parameters:															 | ||||
| *	IN http_message_t* hmsg	; HTTP Message object | ||||
| *																		 | ||||
| * Description: Find the header from the HTTP message and match the		 | ||||
| *	header for xml data.												 | ||||
| *																		 | ||||
| * Returns:																 | ||||
| *	 BOOLEAN															 | ||||
| ************************************************************************/ | ||||
| xboolean | ||||
| has_xml_content_type( IN http_message_t * hmsg ) | ||||
| { | ||||
|     memptr hdr_value; | ||||
|  | ||||
|     assert( hmsg ); | ||||
|  | ||||
| 	/* find 'content-type' header which must have text/xml */ | ||||
| 	if (httpmsg_find_hdr(hmsg, HDR_CONTENT_TYPE, &hdr_value) && | ||||
| 	    matchstr(hdr_value.buf, hdr_value.length, "%itext%w/%wxml" ) == PARSE_OK) { | ||||
|     // find 'content-type' header which must have text/xml | ||||
|     if( httpmsg_find_hdr( hmsg, HDR_CONTENT_TYPE, &hdr_value ) != NULL && | ||||
|         matchstr( hdr_value.buf, hdr_value.length, | ||||
|                   "%itext%w/%wxml" ) == PARSE_OK ) { | ||||
|         return TRUE; | ||||
|     } | ||||
|     return FALSE; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,33 +1,33 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer. | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer in the documentation | ||||
|  * and/or other materials provided with the distribution. | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors | ||||
|  * may be used to endorse or promote products derived from this software | ||||
|  * without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /************************************************************************ | ||||
| * Purpose: This file defines status codes, buffers to store the status	* | ||||
| @@ -37,7 +37,7 @@ | ||||
| #include "config.h" | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include "upnputil.h" | ||||
| #include "util.h" | ||||
| #include "statcodes.h" | ||||
|  | ||||
| #ifdef WIN32 | ||||
| @@ -96,7 +96,7 @@ static const char *Http5xxStr = | ||||
|     "Service Unavailable\0" | ||||
|     "Gateway Timeout\0" "HTTP Version Not Supported\0"; | ||||
|  | ||||
| static int gInitialized = FALSE; | ||||
| static xboolean gInitialized = FALSE; | ||||
|  | ||||
| /************************************************************************ | ||||
| ************************* Functions ************************************* | ||||
| @@ -128,7 +128,7 @@ init_table( IN const char *encoded_str, | ||||
|  | ||||
|     for( i = 0; i < tbl_size; i++ ) { | ||||
|         table[i] = s; | ||||
|         s += strlen( s ) + 1;   /* next entry */ | ||||
|         s += strlen( s ) + 1;   // next entry | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -153,7 +153,7 @@ init_tables( void ) | ||||
|     init_table( Http4xxStr, Http4xxCodes, NUM_4XX_CODES ); | ||||
|     init_table( Http5xxStr, Http5xxCodes, NUM_5XX_CODES ); | ||||
|  | ||||
|     gInitialized = TRUE;        /* mark only after complete */ | ||||
|     gInitialized = TRUE;        // mark only after complete | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,68 +1,117 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
|  * \brief Implements the sockets functionality. | ||||
|  */ | ||||
| /************************************************************************ | ||||
| * Purpose: This file implements the sockets functionality  | ||||
| ************************************************************************/ | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
| #include "sock.h" | ||||
|  | ||||
| #include "unixutil.h"		/* for socklen_t, EAFNOSUPPORT */ | ||||
| #include "upnp.h" | ||||
|  | ||||
| #include <assert.h> | ||||
| #include <errno.h> | ||||
| #include <time.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #include "sock.h" | ||||
| #include "upnp.h" | ||||
| #ifndef WIN32 | ||||
|  #include <arpa/inet.h> | ||||
|  #include <netinet/in.h> | ||||
|  #include <sys/types.h> | ||||
|  #include <sys/socket.h> | ||||
|  #include <sys/time.h> | ||||
|  #include <unistd.h> | ||||
| #else | ||||
|  #include <winsock2.h> | ||||
| #endif | ||||
| #include "unixutil.h" | ||||
|  | ||||
| #ifndef MSG_NOSIGNAL | ||||
|  #define MSG_NOSIGNAL 0 | ||||
| #endif | ||||
|  | ||||
| int sock_init(OUT SOCKINFO *info, IN SOCKET sockfd) | ||||
| /************************************************************************ | ||||
| *	Function :	sock_init | ||||
| * | ||||
| *	Parameters : | ||||
| *		OUT SOCKINFO* info ;	Socket Information Object | ||||
| *		IN int sockfd ;			Socket Descriptor | ||||
| * | ||||
| *	Description :	Assign the passed in socket descriptor to socket  | ||||
| *		descriptor in the SOCKINFO structure. | ||||
| * | ||||
| *	Return : int; | ||||
| *		UPNP_E_SUCCESS	 | ||||
| *		UPNP_E_OUTOF_MEMORY | ||||
| *		UPNP_E_SOCKET_ERROR | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int | ||||
| sock_init( OUT SOCKINFO * info, | ||||
|            IN int sockfd ) | ||||
| { | ||||
|     assert( info ); | ||||
|  | ||||
|     memset( info, 0, sizeof( SOCKINFO ) ); | ||||
|  | ||||
|     info->socket = sockfd; | ||||
|  | ||||
|     return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
| int sock_init_with_ip(OUT SOCKINFO *info, IN SOCKET sockfd, | ||||
| 	IN struct sockaddr *foreign_sockaddr) | ||||
| /************************************************************************ | ||||
| *	Function :	sock_init_with_ip | ||||
| * | ||||
| *	Parameters : | ||||
| *		OUT SOCKINFO* info ;				Socket Information Object | ||||
| *		IN int sockfd ;						Socket Descriptor | ||||
| *		IN struct in_addr foreign_ip_addr ;	Remote IP Address | ||||
| *		IN unsigned short foreign_ip_port ;	Remote Port number | ||||
| * | ||||
| *	Description :	Calls the sock_init function and assigns the passed in | ||||
| *		IP address and port to the IP address and port in the SOCKINFO | ||||
| *		structure. | ||||
| * | ||||
| *	Return : int; | ||||
| *		UPNP_E_SUCCESS	 | ||||
| *		UPNP_E_OUTOF_MEMORY | ||||
| *		UPNP_E_SOCKET_ERROR | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int | ||||
| sock_init_with_ip( OUT SOCKINFO * info, | ||||
|                    IN int sockfd, | ||||
|                    IN struct in_addr foreign_ip_addr, | ||||
|                    IN unsigned short foreign_ip_port ) | ||||
| { | ||||
|     int ret; | ||||
|  | ||||
| @@ -71,86 +120,117 @@ int sock_init_with_ip(OUT SOCKINFO *info, IN SOCKET sockfd, | ||||
|         return ret; | ||||
|     } | ||||
|  | ||||
| 	memcpy(&info->foreign_sockaddr, foreign_sockaddr, | ||||
| 	       sizeof(info->foreign_sockaddr)); | ||||
|     info->foreign_ip_addr = foreign_ip_addr; | ||||
|     info->foreign_ip_port = foreign_ip_port; | ||||
|  | ||||
|     return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
| int sock_destroy(INOUT SOCKINFO *info, int ShutdownMethod) | ||||
| { | ||||
| 	int ret = UPNP_E_SUCCESS; | ||||
|  | ||||
| 	if (info->socket != -1) { | ||||
| 		shutdown(info->socket, ShutdownMethod); | ||||
| 		if (sock_close(info->socket) == -1) { | ||||
| 			ret = UPNP_E_SOCKET_ERROR; | ||||
| 		} | ||||
| 		info->socket = -1; | ||||
| 	} | ||||
|  | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
| /*! | ||||
|  * \brief Receives or sends data. Also returns the time taken to receive or | ||||
|  * send data. | ||||
| /************************************************************************ | ||||
| *	Function :	sock_destroy | ||||
| * | ||||
|  * \return | ||||
|  *	\li \c numBytes - On Success, no of bytes received or sent or | ||||
|  *	\li \c UPNP_E_TIMEDOUT - Timeout | ||||
|  *	\li \c UPNP_E_SOCKET_ERROR - Error on socket calls | ||||
|  */ | ||||
| static int sock_read_write( | ||||
| 	/*! Socket Information Object. */ | ||||
| 	IN SOCKINFO *info, | ||||
| 	/*! Buffer to get data to or send data from. */ | ||||
| *	Parameters : | ||||
| *		INOUT SOCKINFO* info ;	Socket Information Object | ||||
| *		int ShutdownMethod ;	How to shutdown the socket. Used by   | ||||
| *								sockets's shutdown()  | ||||
| * | ||||
| *	Description :	Shutsdown the socket using the ShutdownMethod to  | ||||
| *		indicate whether sends and receives on the socket will be  | ||||
| *		dis-allowed. After shutting down the socket, closesocket is called | ||||
| *		to release system resources used by the socket calls. | ||||
| * | ||||
| *	Return : int; | ||||
| *		UPNP_E_SOCKET_ERROR on failure | ||||
| *		UPNP_E_SUCCESS on success | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int | ||||
| sock_destroy( INOUT SOCKINFO * info, | ||||
|               int ShutdownMethod ) | ||||
| { | ||||
|     shutdown( info->socket, ShutdownMethod ); | ||||
|     if( UpnpCloseSocket( info->socket ) == -1 ) { | ||||
|         return UPNP_E_SOCKET_ERROR; | ||||
|     } | ||||
|  | ||||
|     return UPNP_E_SUCCESS; | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
| *	Function :	sock_read_write | ||||
| * | ||||
| *	Parameters : | ||||
| *		IN SOCKINFO *info ;	Socket Information Object | ||||
| *		OUT char* buffer ;	Buffer to get data to or send data from  | ||||
| *		IN size_t bufsize ;	Size of the buffer | ||||
| *	    IN int *timeoutSecs ;	timeout value | ||||
| *		IN xboolean bRead ;	Boolean value specifying read or write option | ||||
| * | ||||
| *	Description :	Receives or sends data. Also returns the time taken | ||||
| *		to receive or send data. | ||||
| * | ||||
| *	Return :int ; | ||||
| *		numBytes - On Success, no of bytes received or sent		 | ||||
| *		UPNP_E_TIMEDOUT - Timeout | ||||
| *		UPNP_E_SOCKET_ERROR - Error on socket calls | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| static int | ||||
| sock_read_write( IN SOCKINFO * info, | ||||
|                  OUT char *buffer, | ||||
| 	/*! Size of the buffer. */ | ||||
| 	IN int bufsize, | ||||
| 	/*! timeout value. */ | ||||
|                  IN size_t bufsize, | ||||
|                  IN int *timeoutSecs, | ||||
| 	/*! Boolean value specifying read or write option. */ | ||||
| 	IN int bRead) | ||||
|                  IN xboolean bRead ) | ||||
| { | ||||
|     int retCode; | ||||
|     fd_set readSet; | ||||
|     fd_set writeSet; | ||||
|     struct timeval timeout; | ||||
| 	long numBytes; | ||||
|     int numBytes; | ||||
|     time_t start_time = time( NULL ); | ||||
| 	SOCKET sockfd = info->socket; | ||||
| 	long bytes_sent = 0; | ||||
| 	long byte_left = 0; | ||||
| 	long num_written; | ||||
|     int sockfd = info->socket; | ||||
|     long bytes_sent = 0, | ||||
|       byte_left = 0, | ||||
|       num_written; | ||||
|  | ||||
| 	if (*timeoutSecs < 0) | ||||
|     if( *timeoutSecs < 0 ) { | ||||
|         return UPNP_E_TIMEDOUT; | ||||
|     } | ||||
|  | ||||
|     FD_ZERO( &readSet ); | ||||
|     FD_ZERO( &writeSet ); | ||||
| 	if (bRead) | ||||
| 		FD_SET(sockfd, &readSet); | ||||
| 	else | ||||
| 		FD_SET(sockfd, &writeSet); | ||||
|     if( bRead ) { | ||||
|         FD_SET( ( unsigned )sockfd, &readSet ); | ||||
|     } else { | ||||
|         FD_SET( ( unsigned )sockfd, &writeSet ); | ||||
|     } | ||||
|  | ||||
|     timeout.tv_sec = *timeoutSecs; | ||||
|     timeout.tv_usec = 0; | ||||
|  | ||||
|     while( TRUE ) { | ||||
| 		if (*timeoutSecs == 0) | ||||
| 			retCode = select(sockfd + 1, &readSet, &writeSet, | ||||
| 				NULL, NULL); | ||||
| 		else | ||||
| 			retCode = select(sockfd + 1, &readSet, &writeSet, | ||||
| 				NULL, &timeout); | ||||
| 		if (retCode == 0) | ||||
|         if( *timeoutSecs == 0 ) { | ||||
|             retCode = | ||||
|                 select( sockfd + 1, &readSet, &writeSet, NULL, NULL ); | ||||
|         } else { | ||||
|             retCode = | ||||
|                 select( sockfd + 1, &readSet, &writeSet, NULL, &timeout ); | ||||
|         } | ||||
|  | ||||
|         if( retCode == 0 ) { | ||||
|             return UPNP_E_TIMEDOUT; | ||||
|         } | ||||
|         if( retCode == -1 ) { | ||||
|             if( errno == EINTR ) | ||||
|                 continue; | ||||
| 			return UPNP_E_SOCKET_ERROR; | ||||
| 		} else | ||||
| 			/* read or write. */ | ||||
| 			break; | ||||
|             return UPNP_E_SOCKET_ERROR; // error | ||||
|         } else { | ||||
|             break;              // read or write | ||||
|         } | ||||
|     } | ||||
|  | ||||
| #ifdef SO_NOSIGPIPE | ||||
|     { | ||||
| 	int old; | ||||
| @@ -159,51 +239,96 @@ static int sock_read_write( | ||||
| 	getsockopt(sockfd, SOL_SOCKET, SO_NOSIGPIPE, &old, &olen); | ||||
| 	setsockopt(sockfd, SOL_SOCKET, SO_NOSIGPIPE, &set, sizeof(set)); | ||||
| #endif | ||||
|  | ||||
|     if( bRead ) { | ||||
| 			/* read data. */ | ||||
| 			numBytes = (long)recv(sockfd, buffer, (size_t)bufsize, MSG_NOSIGNAL); | ||||
|         // read data | ||||
|         numBytes = recv( sockfd, buffer, bufsize,MSG_NOSIGNAL); | ||||
|     } else { | ||||
|         byte_left = bufsize; | ||||
|         bytes_sent = 0; | ||||
|         while( byte_left > 0 ) { | ||||
| 				/* write data. */ | ||||
| 				num_written = send(sockfd, | ||||
| 					buffer + bytes_sent, (size_t)byte_left, | ||||
|             // write data | ||||
|             num_written = | ||||
|                 send( sockfd, buffer + bytes_sent, byte_left, | ||||
|                       MSG_DONTROUTE|MSG_NOSIGNAL); | ||||
|             if( num_written == -1 ) { | ||||
| #ifdef SO_NOSIGPIPE | ||||
| 					setsockopt(sockfd, SOL_SOCKET, | ||||
| 						SO_NOSIGPIPE, &old, olen); | ||||
| 	        setsockopt(sockfd, SOL_SOCKET, SO_NOSIGPIPE, &old, olen); | ||||
| #endif | ||||
| 					return (int)num_written; | ||||
|                 return num_written; | ||||
|             } | ||||
|  | ||||
|             byte_left = byte_left - num_written; | ||||
|             bytes_sent += num_written; | ||||
|         } | ||||
|  | ||||
|         numBytes = bytes_sent; | ||||
|     } | ||||
|  | ||||
| #ifdef SO_NOSIGPIPE | ||||
| 	setsockopt(sockfd, SOL_SOCKET, SO_NOSIGPIPE, &old, olen); | ||||
|     } | ||||
| #endif | ||||
| 	if (numBytes < 0) | ||||
| 		return UPNP_E_SOCKET_ERROR; | ||||
| 	/* subtract time used for reading/writing. */ | ||||
| 	if (*timeoutSecs != 0) | ||||
| 		*timeoutSecs -= (int)(time(NULL) - start_time); | ||||
|  | ||||
| 	return (int)numBytes; | ||||
|     if( numBytes < 0 ) { | ||||
|         return UPNP_E_SOCKET_ERROR; | ||||
|     } | ||||
|     // subtract time used for reading/writing | ||||
|     if( *timeoutSecs != 0 ) { | ||||
|         *timeoutSecs -= time( NULL ) - start_time; | ||||
|     } | ||||
|  | ||||
| int sock_read(IN SOCKINFO *info, OUT char *buffer, IN int bufsize, | ||||
|     return numBytes; | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
| *	Function :	sock_read | ||||
| * | ||||
| *	Parameters : | ||||
| *		IN SOCKINFO *info ;	Socket Information Object | ||||
| *		OUT char* buffer ;	Buffer to get data to   | ||||
| *		IN size_t bufsize ;	Size of the buffer | ||||
| *	    IN int *timeoutSecs ;	timeout value | ||||
| * | ||||
| *	Description :	Calls sock_read_write() for reading data on the  | ||||
| *		socket | ||||
| * | ||||
| *	Return : int; | ||||
| *		Values returned by sock_read_write()  | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int | ||||
| sock_read( IN SOCKINFO * info, | ||||
|            OUT char *buffer, | ||||
|            IN size_t bufsize, | ||||
|            INOUT int *timeoutSecs ) | ||||
| { | ||||
|     return sock_read_write( info, buffer, bufsize, timeoutSecs, TRUE ); | ||||
| } | ||||
|  | ||||
| int sock_write(IN SOCKINFO *info, IN const char *buffer, IN int bufsize, | ||||
| /************************************************************************ | ||||
| *	Function :	sock_write | ||||
| * | ||||
| *	Parameters : | ||||
| *		IN SOCKINFO *info ;	Socket Information Object | ||||
| *		IN char* buffer ;	Buffer to send data from  | ||||
| *		IN size_t bufsize ;	Size of the buffer | ||||
| *	    IN int *timeoutSecs ;	timeout value | ||||
| * | ||||
| *	Description :	Calls sock_read_write() for writing data on the  | ||||
| *		socket | ||||
| * | ||||
| *	Return : int; | ||||
| *		sock_read_write() | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int | ||||
| sock_write( IN SOCKINFO * info, | ||||
|             IN char *buffer, | ||||
|             IN size_t bufsize, | ||||
|             INOUT int *timeoutSecs ) | ||||
| { | ||||
| 	return sock_read_write(info, (char *)buffer, bufsize, timeoutSecs, FALSE); | ||||
|     return sock_read_write( info, buffer, bufsize, timeoutSecs, FALSE ); | ||||
| } | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,34 +1,33 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /************************************************************************ | ||||
| * Purpose: This file defines the functions for services. It defines  | ||||
| @@ -52,7 +51,7 @@ | ||||
| *	Description :	Makes a copy of the subscription | ||||
| * | ||||
| *	Return : int ; | ||||
| *		HTTP_SUCCESS - On success | ||||
| *		HTTP_SUCCESS - On Sucess | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| @@ -117,8 +116,25 @@ RemoveSubscriptionSID( Upnp_SID sid, | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| subscription *GetSubscriptionSID(const Upnp_SID sid, service_info *service) | ||||
| /************************************************************************ | ||||
| *	Function :	GetSubscriptionSID | ||||
| * | ||||
| *	Parameters : | ||||
| *		Upnp_SID sid ;	subscription ID | ||||
| *		service_info * service ;	service object providing the list of | ||||
| *						subscriptions | ||||
| * | ||||
| *	Description :	Return the subscription from the service table  | ||||
| *		that matches const Upnp_SID sid value.  | ||||
| * | ||||
| *	Return : subscription * - Pointer to the matching subscription  | ||||
| *		node; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| subscription * | ||||
| GetSubscriptionSID( Upnp_SID sid, | ||||
|                     service_info * service ) | ||||
| { | ||||
|     subscription *next = service->subscriptionList; | ||||
|     subscription *previous = NULL; | ||||
| @@ -135,7 +151,7 @@ subscription *GetSubscriptionSID(const Upnp_SID sid, service_info *service) | ||||
|         } | ||||
|     } | ||||
|     if( found ) { | ||||
|         /*get the current_time */ | ||||
|         //get the current_time | ||||
|         time( ¤t_time ); | ||||
|         if( ( found->expireTime != 0 ) | ||||
|             && ( found->expireTime < current_time ) ) { | ||||
| @@ -153,15 +169,31 @@ subscription *GetSubscriptionSID(const Upnp_SID sid, service_info *service) | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| subscription *GetNextSubscription(service_info *service, subscription *current) | ||||
| /************************************************************************ | ||||
| *	Function :	GetNextSubscription | ||||
| * | ||||
| *	Parameters : | ||||
| *		service_info * service ; service object providing the list of | ||||
| *						subscriptions | ||||
| *		subscription *current ;	current subscription object | ||||
| * | ||||
| *	Description :	Get current and valid subscription from the service  | ||||
| *		table. | ||||
| * | ||||
| *	Return : subscription * - Pointer to the next subscription node; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| subscription * | ||||
| GetNextSubscription( service_info * service, | ||||
|                      subscription * current ) | ||||
| { | ||||
|     time_t current_time; | ||||
|     subscription *next = NULL; | ||||
|     subscription *previous = NULL; | ||||
|     int notDone = 1; | ||||
|  | ||||
|     /* get the current_time */ | ||||
|     //get the current_time | ||||
|     time( ¤t_time ); | ||||
|     while( ( notDone ) && ( current ) ) { | ||||
|         previous = current; | ||||
| @@ -186,8 +218,22 @@ subscription *GetNextSubscription(service_info *service, subscription *current) | ||||
|     return next; | ||||
| } | ||||
|  | ||||
|  | ||||
| subscription *GetFirstSubscription(service_info *service) | ||||
| /************************************************************************ | ||||
| *	Function :	GetFirstSubscription | ||||
| * | ||||
| *	Parameters : | ||||
| *		service_info *service ;	service object providing the list of | ||||
| *						subscriptions | ||||
| * | ||||
| *	Description :	Gets pointer to the first subscription node in the  | ||||
| *		service table. | ||||
| * | ||||
| *	Return : subscription * - pointer to the first subscription node ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| subscription * | ||||
| GetFirstSubscription( service_info * service ) | ||||
| { | ||||
|     subscription temp; | ||||
|     subscription *next = NULL; | ||||
| @@ -195,13 +241,25 @@ subscription *GetFirstSubscription(service_info *service) | ||||
|     temp.next = service->subscriptionList; | ||||
|     next = GetNextSubscription( service, &temp ); | ||||
|     service->subscriptionList = temp.next; | ||||
| 	/* service->subscriptionList = next; */ | ||||
| 	 | ||||
|     //  service->subscriptionList=next; | ||||
|     return next; | ||||
| } | ||||
|  | ||||
|  | ||||
| void freeSubscription(subscription *sub) | ||||
| /************************************************************************ | ||||
| *	Function :	freeSubscription | ||||
| * | ||||
| *	Parameters : | ||||
| *		subscription * sub ;	subscription to be freed | ||||
| * | ||||
| *	Description :	Free's the memory allocated for storing the URL of  | ||||
| *		the subscription. | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void | ||||
| freeSubscription( subscription * sub ) | ||||
| { | ||||
|     if( sub ) { | ||||
|         free_URL_list( &sub->DeliveryURLs ); | ||||
| @@ -718,8 +776,8 @@ getSubElement( const char *element_name, | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| service_info *getServiceList( | ||||
| 	IXML_Node *node, | ||||
| service_info * | ||||
| getServiceList( IXML_Node * node, | ||||
|                 service_info ** end, | ||||
|                 char *URLBase ) | ||||
| { | ||||
| @@ -737,32 +795,43 @@ service_info *getServiceList( | ||||
|     service_info *current = NULL; | ||||
|     service_info *previous = NULL; | ||||
|     IXML_NodeList *serviceNodeList = NULL; | ||||
| 	long unsigned int NumOfServices = 0; | ||||
| 	long unsigned int i = 0; | ||||
|     int NumOfServices = 0; | ||||
|     int i = 0; | ||||
|     int fail = 0; | ||||
|  | ||||
|     if( getSubElement( "UDN", node, &UDN ) && | ||||
|         getSubElement( "serviceList", node, &serviceList ) ) { | ||||
| 		serviceNodeList = ixmlElement_getElementsByTagName( | ||||
| 			(IXML_Element *)serviceList, "service"); | ||||
|  | ||||
|         serviceNodeList = ixmlElement_getElementsByTagName( ( IXML_Element | ||||
|                                                               * ) | ||||
|                                                             serviceList, | ||||
|                                                             "service" ); | ||||
|  | ||||
|         if( serviceNodeList != NULL ) { | ||||
|             NumOfServices = ixmlNodeList_length( serviceNodeList ); | ||||
|             for( i = 0; i < NumOfServices; i++ ) { | ||||
| 				current_service = | ||||
| 				    ixmlNodeList_item(serviceNodeList, i); | ||||
|                 current_service = ixmlNodeList_item( serviceNodeList, i ); | ||||
|                 fail = 0; | ||||
|  | ||||
|                 if( current ) { | ||||
| 					current->next = malloc(sizeof(service_info)); | ||||
|                     current->next = | ||||
|                         ( service_info * ) | ||||
|                         malloc( sizeof( service_info ) ); | ||||
|  | ||||
|                     previous = current; | ||||
|                     current = current->next; | ||||
|                 } else { | ||||
| 					head = malloc(sizeof(service_info)); | ||||
|                     head = | ||||
|                         ( service_info * ) | ||||
|                         malloc( sizeof( service_info ) ); | ||||
|                     current = head; | ||||
|                 } | ||||
|  | ||||
|                 if( !current ) { | ||||
|                     freeServiceList( head ); | ||||
|                     return NULL; | ||||
|                 } | ||||
|  | ||||
|                 current->next = NULL; | ||||
|                 current->controlURL = NULL; | ||||
|                 current->eventURL = NULL; | ||||
| @@ -772,65 +841,97 @@ service_info *getServiceList( | ||||
|                 current->active = 1; | ||||
|                 current->subscriptionList = NULL; | ||||
|                 current->TotalSubscriptions = 0; | ||||
|  | ||||
|                 if( !( current->UDN = getElementValue( UDN ) ) ) | ||||
|                     fail = 1; | ||||
| 				if (!getSubElement("serviceType", current_service, &serviceType) || | ||||
| 				    !(current->serviceType = getElementValue(serviceType))) | ||||
|  | ||||
|                 if( ( !getSubElement( "serviceType", current_service, | ||||
|                                       &serviceType ) ) || | ||||
|                     ( !( current->serviceType = | ||||
|                          getElementValue( serviceType ) ) ) ) | ||||
|                     fail = 1; | ||||
| 				if (!getSubElement("serviceId", current_service, &serviceId) || | ||||
| 				    !(current->serviceId = getElementValue(serviceId))) | ||||
|  | ||||
|                 if( ( !getSubElement( "serviceId", current_service, | ||||
|                                       &serviceId ) ) || | ||||
|                     ( ! | ||||
|                       ( current->serviceId = | ||||
|                         getElementValue( serviceId ) ) ) ) | ||||
|                     fail = 1; | ||||
| 				if (!getSubElement("SCPDURL", current_service, &SCPDURL) || | ||||
| 				    !(tempDOMString = getElementValue(SCPDURL)) || | ||||
| 				    !(current->SCPDURL = resolve_rel_url(URLBase, tempDOMString))) | ||||
|  | ||||
|                 if( ( ! | ||||
|                       ( getSubElement | ||||
|                         ( "SCPDURL", current_service, &SCPDURL ) ) ) | ||||
|                     || ( !( tempDOMString = getElementValue( SCPDURL ) ) ) | ||||
|                     || | ||||
|                     ( ! | ||||
|                       ( current->SCPDURL = | ||||
|                         resolve_rel_url( URLBase, tempDOMString ) ) ) ) | ||||
|                     fail = 1; | ||||
|  | ||||
|                 ixmlFreeDOMString( tempDOMString ); | ||||
|                 tempDOMString = NULL; | ||||
| 				if (!(getSubElement("controlURL", current_service, &controlURL)) || | ||||
| 				    !(tempDOMString = getElementValue(controlURL)) || | ||||
| 				    !(current->controlURL = resolve_rel_url(URLBase, tempDOMString))) { | ||||
| 					UpnpPrintf(UPNP_INFO, GENA, __FILE__, | ||||
| 						   __LINE__, | ||||
|  | ||||
|                 if( ( ! | ||||
|                       ( getSubElement | ||||
|                         ( "controlURL", current_service, &controlURL ) ) ) | ||||
|                     || | ||||
|                     ( !( tempDOMString = getElementValue( controlURL ) ) ) | ||||
|                     || | ||||
|                     ( ! | ||||
|                       ( current->controlURL = | ||||
|                         resolve_rel_url( URLBase, tempDOMString ) ) ) ) { | ||||
|                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||
|                         "BAD OR MISSING CONTROL URL" ); | ||||
| 					UpnpPrintf(UPNP_INFO, GENA, __FILE__, | ||||
| 						   __LINE__, | ||||
|                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||
|                         "CONTROL URL SET TO NULL IN SERVICE INFO" ); | ||||
|                     current->controlURL = NULL; | ||||
|                     fail = 0; | ||||
|                 } | ||||
|  | ||||
|                 ixmlFreeDOMString( tempDOMString ); | ||||
|                 tempDOMString = NULL; | ||||
| 				if (!getSubElement("eventSubURL", current_service, &eventURL) || | ||||
| 				    !(tempDOMString = getElementValue(eventURL)) || | ||||
| 				    !(current->eventURL = resolve_rel_url(URLBase, tempDOMString))) { | ||||
| 					UpnpPrintf(UPNP_INFO, GENA, __FILE__, | ||||
| 						   __LINE__, | ||||
|  | ||||
|                 if( ( ! | ||||
|                       ( getSubElement | ||||
|                         ( "eventSubURL", current_service, &eventURL ) ) ) | ||||
|                     || ( !( tempDOMString = getElementValue( eventURL ) ) ) | ||||
|                     || | ||||
|                     ( ! | ||||
|                       ( current->eventURL = | ||||
|                         resolve_rel_url( URLBase, tempDOMString ) ) ) ) { | ||||
|                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||
|                         "BAD OR MISSING EVENT URL" ); | ||||
| 					UpnpPrintf(UPNP_INFO, GENA, __FILE__, | ||||
| 						   __LINE__, | ||||
|                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||
|                         "EVENT URL SET TO NULL IN SERVICE INFO" ); | ||||
|                     current->eventURL = NULL; | ||||
|                     fail = 0; | ||||
|                 } | ||||
|  | ||||
|                 ixmlFreeDOMString( tempDOMString ); | ||||
|                 tempDOMString = NULL; | ||||
|  | ||||
|                 if( fail ) { | ||||
|                     freeServiceList( current ); | ||||
|  | ||||
|                     if( previous ) | ||||
|                         previous->next = NULL; | ||||
|                     else | ||||
|                         head = NULL; | ||||
|  | ||||
|                     current = previous; | ||||
|                 } | ||||
|  | ||||
|             } | ||||
|  | ||||
|             ixmlNodeList_free( serviceNodeList ); | ||||
|         } | ||||
|  | ||||
|         ( *end ) = current; | ||||
|  | ||||
|         return head; | ||||
| 	} else { | ||||
| 		(*end) = NULL; | ||||
|     } else | ||||
|         return NULL; | ||||
| 	} | ||||
|  | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
| @@ -860,26 +961,27 @@ getAllServiceList( IXML_Node * node, | ||||
|     IXML_NodeList *deviceList = NULL; | ||||
|     IXML_Node *currentDevice = NULL; | ||||
|  | ||||
| 	long unsigned int NumOfDevices = 0; | ||||
| 	long unsigned int i = 0; | ||||
|     int NumOfDevices = 0; | ||||
|     int i = 0; | ||||
|  | ||||
|     ( *out_end ) = NULL; | ||||
|  | ||||
| 	deviceList = ixmlElement_getElementsByTagName( | ||||
| 		(IXML_Element *)node, "device"); | ||||
| 	if (deviceList) { | ||||
|     deviceList = | ||||
|         ixmlElement_getElementsByTagName( ( IXML_Element * ) node, | ||||
|                                           "device" ); | ||||
|     if( deviceList != NULL ) { | ||||
|         NumOfDevices = ixmlNodeList_length( deviceList ); | ||||
|         for( i = 0; i < NumOfDevices; i++ ) { | ||||
|             currentDevice = ixmlNodeList_item( deviceList, i ); | ||||
|             if( head ) { | ||||
| 				end->next = getServiceList(currentDevice, | ||||
| 					&next_end, URLBase); | ||||
| 				if (next_end) | ||||
|                 end->next = | ||||
|                     getServiceList( currentDevice, &next_end, URLBase ); | ||||
|                 end = next_end; | ||||
|             } else | ||||
| 				head = getServiceList(currentDevice, &end, | ||||
| 					URLBase); | ||||
|                 head = getServiceList( currentDevice, &end, URLBase ); | ||||
|  | ||||
|         } | ||||
|  | ||||
|         ixmlNodeList_free( deviceList ); | ||||
|     } | ||||
|  | ||||
| @@ -916,8 +1018,8 @@ removeServiceTable( IXML_Node * node, | ||||
|     service_info *current_service = NULL; | ||||
|     service_info *start_search = NULL; | ||||
|     service_info *prev_service = NULL; | ||||
|     long unsigned int NumOfDevices = 0; | ||||
|     long unsigned int i = 0; | ||||
|     int NumOfDevices = 0; | ||||
|     int i = 0; | ||||
|  | ||||
|     if( getSubElement( "root", node, &root ) ) { | ||||
|         current_service = in->serviceList; | ||||
| @@ -933,9 +1035,9 @@ removeServiceTable( IXML_Node * node, | ||||
|                     && ( ( getSubElement( "UDN", node, ¤tUDN ) ) | ||||
|                          && ( UDN = getElementValue( currentUDN ) ) ) ) { | ||||
|                     current_service = start_search; | ||||
|                     /*Services are put in the service table in the order in which they appear in the  */ | ||||
|                     /*description document, therefore we go through the list only once to remove a particular */ | ||||
|                     /*root device */ | ||||
|                     //Services are put in the service table in the order in which they appear in the  | ||||
|                     //description document, therefore we go through the list only once to remove a particular | ||||
|                     //root device | ||||
|                     while( ( current_service ) | ||||
|                            && ( strcmp( current_service->UDN, UDN ) ) ) { | ||||
|                         current_service = current_service->next; | ||||
| @@ -1061,5 +1163,4 @@ getServiceTable( IXML_Node * node, | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| #endif /* INCLUDE_DEVICE_APIS */ | ||||
|  | ||||
| #endif // INCLUDE_DEVICE_APIS | ||||
|   | ||||
| @@ -1,33 +1,33 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /************************************************************************ | ||||
| * Purpose: This file contains functions that operate on memory and  | ||||
| @@ -70,7 +70,7 @@ str_alloc( IN const char *str, | ||||
|  | ||||
|     s = ( char * )malloc( str_len + 1 ); | ||||
|     if( s == NULL ) { | ||||
|         return NULL;            /* no mem */ | ||||
|         return NULL;            // no mem | ||||
|     } | ||||
|  | ||||
|     memcpy( s, str, str_len ); | ||||
| @@ -111,8 +111,8 @@ memptr_cmp( IN memptr * m, | ||||
|     cmp = strncmp( m->buf, s, m->length ); | ||||
|  | ||||
|     if( cmp == 0 && m->length < strlen( s ) ) { | ||||
|         /* both strings equal for 'm->length' chars */ | ||||
|         /*  if m is shorter than s, then s is greater */ | ||||
|         // both strings equal for 'm->length' chars | ||||
|         //  if m is shorter than s, then s is greater | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
| @@ -147,8 +147,8 @@ memptr_cmp_nocase( IN memptr * m, | ||||
|  | ||||
|     cmp = strncasecmp( m->buf, s, m->length ); | ||||
|     if( cmp == 0 && m->length < strlen( s ) ) { | ||||
|         /* both strings equal for 'm->length' chars */ | ||||
|         /*  if m is shorter than s, then s is greater */ | ||||
|         // both strings equal for 'm->length' chars | ||||
|         //  if m is shorter than s, then s is greater | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
| @@ -204,20 +204,20 @@ membuffer_set_size( INOUT membuffer * m, | ||||
|     size_t alloc_len; | ||||
|     char *temp_buf; | ||||
|  | ||||
|     if( new_length >= m->length )   /* increase length */ | ||||
|     if( new_length >= m->length )   // increase length | ||||
|     { | ||||
|         /* need more mem? */ | ||||
|         // need more mem? | ||||
|         if( new_length <= m->capacity ) { | ||||
|             return 0;           /* have enough mem; done */ | ||||
|             return 0;           // have enough mem; done | ||||
|         } | ||||
|  | ||||
|         diff = new_length - m->length; | ||||
|         alloc_len = MAXVAL( m->size_inc, diff ) + m->capacity; | ||||
|     } else                      /* decrease length */ | ||||
|     } else                      // decrease length | ||||
|     { | ||||
|         assert( new_length <= m->length ); | ||||
|  | ||||
|         /* if diff is 0..m->size_inc, don't free */ | ||||
|         // if diff is 0..m->size_inc, don't free | ||||
|         if( ( m->capacity - new_length ) <= m->size_inc ) { | ||||
|             return 0; | ||||
|         } | ||||
| @@ -227,21 +227,21 @@ membuffer_set_size( INOUT membuffer * m, | ||||
|  | ||||
|     assert( alloc_len >= new_length ); | ||||
|  | ||||
|     temp_buf = realloc( m->buf, alloc_len + 1 );    /*LEAK_FIX_MK */ | ||||
|     temp_buf = realloc( m->buf, alloc_len + 1 );    //LEAK_FIX_MK | ||||
|  | ||||
|     /*temp_buf = Realloc( m->buf,m->length, alloc_len + 1 );LEAK_FIX_MK */ | ||||
|     //temp_buf = Realloc( m->buf,m->length, alloc_len + 1 );//LEAK_FIX_MK | ||||
|  | ||||
|     if( temp_buf == NULL ) { | ||||
|         /* try smaller size */ | ||||
|         // try smaller size | ||||
|         alloc_len = new_length; | ||||
|         temp_buf = realloc( m->buf, alloc_len + 1 );    /*LEAK_FIX_MK */ | ||||
|         /*temp_buf = Realloc( m->buf,m->length, alloc_len + 1 );LEAK_FIX_MK */ | ||||
|         temp_buf = realloc( m->buf, alloc_len + 1 );    //LEAK_FIX_MK | ||||
|         //temp_buf = Realloc( m->buf,m->length, alloc_len + 1 );//LEAK_FIX_MK | ||||
|  | ||||
|         if( temp_buf == NULL ) { | ||||
|             return UPNP_E_OUTOF_MEMORY; | ||||
|         } | ||||
|     } | ||||
|     /* save */ | ||||
|     // save | ||||
|     m->buf = temp_buf; | ||||
|     m->capacity = alloc_len; | ||||
|     return 0; | ||||
| @@ -311,7 +311,8 @@ membuffer_destroy( INOUT membuffer * m ) | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int membuffer_assign( INOUT membuffer * m, | ||||
| int | ||||
| membuffer_assign( INOUT membuffer * m, | ||||
|                   IN const void *buf, | ||||
|                   IN size_t buf_len ) | ||||
| { | ||||
| @@ -319,19 +320,20 @@ int membuffer_assign( INOUT membuffer * m, | ||||
|  | ||||
|     assert( m != NULL ); | ||||
|  | ||||
| 	/* set value to null */ | ||||
|     // set value to null | ||||
|     if( buf == NULL ) { | ||||
|         membuffer_destroy( m ); | ||||
|         return 0; | ||||
|     } | ||||
| 	/* alloc mem */ | ||||
|     // alloc mem | ||||
|     return_code = membuffer_set_size( m, buf_len ); | ||||
| 	if (return_code != 0) | ||||
|     if( return_code != 0 ) { | ||||
|         return return_code; | ||||
| 	/* copy */ | ||||
|     } | ||||
|     // copy | ||||
|     if( buf_len ) { | ||||
|         memcpy( m->buf, buf, buf_len ); | ||||
| 		m->buf[buf_len] = 0;	/* null-terminate */ | ||||
|         m->buf[buf_len] = 0;        // null-terminate | ||||
|     } | ||||
|     m->length = buf_len; | ||||
|  | ||||
| @@ -409,60 +411,108 @@ membuffer_append_str( INOUT membuffer * m, | ||||
|     return membuffer_insert( m, c_str, strlen( c_str ), m->length ); | ||||
| } | ||||
|  | ||||
| int membuffer_insert(membuffer *m, const void *buf, size_t buf_len, size_t index) | ||||
| /************************************************************************ | ||||
| *	Function :	membuffer_insert | ||||
| * | ||||
| *	Parameters : | ||||
| *		INOUT membuffer* m ; buffer whose memory size is to be increased   | ||||
| *					and appended. | ||||
| *		IN const void* buf ; source buffer whose contents will be  | ||||
| *					copied | ||||
| *		 IN size_t buf_len ; size of the source buffer | ||||
| *		int index ;	index to determine the bounds while movinf the data | ||||
| * | ||||
| *	Description : Allocates memory for the new data to be inserted. Does | ||||
| *		memory management by moving the data from the existing memory to  | ||||
| *		the newly allocated memory and then appending the new data. | ||||
| * | ||||
| *	Return : int ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int | ||||
| membuffer_insert( INOUT membuffer * m, | ||||
|                   IN const void *buf, | ||||
|                   IN size_t buf_len, | ||||
|                   int index ) | ||||
| { | ||||
|     int return_code; | ||||
|  | ||||
|     assert( m != NULL ); | ||||
|  | ||||
| 	if (index > m->length) | ||||
|     if( index < 0 || index > ( int )m->length ) | ||||
|         return UPNP_E_OUTOF_BOUNDS; | ||||
| 	if (!buf || !buf_len) { | ||||
|  | ||||
|     if( buf == NULL || buf_len == 0 ) { | ||||
|         return 0; | ||||
|     } | ||||
| 	/* alloc mem */ | ||||
|     // alloc mem | ||||
|     return_code = membuffer_set_size( m, m->length + buf_len ); | ||||
| 	if (return_code) { | ||||
|     if( return_code != 0 ) { | ||||
|         return return_code; | ||||
|     } | ||||
| 	/* insert data */ | ||||
| 	/* move data to right of insertion point */ | ||||
|     // insert data | ||||
|  | ||||
|     // move data to right of insertion point | ||||
|     memmove( m->buf + index + buf_len, m->buf + index, m->length - index ); | ||||
|     memcpy( m->buf + index, buf, buf_len ); | ||||
|     m->length += buf_len; | ||||
| 	/* null-terminate */ | ||||
| 	m->buf[m->length] = 0; | ||||
|     m->buf[m->length] = 0;      // null-terminate | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| void membuffer_delete(membuffer *m, size_t index, size_t num_bytes) | ||||
| /************************************************************************ | ||||
| *	Function :	membuffer_delete | ||||
| * | ||||
| *	Parameters : | ||||
| *		INOUT membuffer* m ; buffer whose memory size is to be decreased | ||||
| *					and copied to the odified location | ||||
| *		IN int index ;	index to determine bounds while moving data | ||||
| *		IN size_t num_bytes ;	number of bytes that the data needs to  | ||||
| *					shrink by | ||||
| * | ||||
| *	Description : Shrink the size of the buffer depending on the current  | ||||
| *		size of the bufer and te input parameters. Move contents from the  | ||||
| *		old buffer to the new sized buffer. | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void | ||||
| membuffer_delete( INOUT membuffer * m, | ||||
|                   IN int index, | ||||
|                   IN size_t num_bytes ) | ||||
| { | ||||
|     int return_value; | ||||
| 	size_t new_length; | ||||
|     int new_length; | ||||
|     size_t copy_len; | ||||
|  | ||||
|     assert( m != NULL ); | ||||
|  | ||||
| 	if (!m || !m->length) | ||||
|     if( m->length == 0 ) { | ||||
|         return; | ||||
| 	/* shrink count if it goes beyond buffer */ | ||||
|     } | ||||
|  | ||||
|     assert( index >= 0 && index < ( int )m->length ); | ||||
|  | ||||
|     // shrink count if it goes beyond buffer | ||||
|     if( index + num_bytes > m->length ) { | ||||
| 		num_bytes = m->length - index; | ||||
| 		/* every thing at and after index purged */ | ||||
| 		copy_len = 0; | ||||
|         num_bytes = m->length - ( size_t ) index; | ||||
|         copy_len = 0;           // every thing at and after index purged | ||||
|     } else { | ||||
| 		/* calc num bytes after deleted string */ | ||||
|         // calc num bytes after deleted string | ||||
|         copy_len = m->length - ( index + num_bytes ); | ||||
|     } | ||||
| 	memmove(m->buf + index, m->buf + index + num_bytes, copy_len); | ||||
| 	new_length = m->length - num_bytes; | ||||
| 	/* trim buffer */ | ||||
| 	return_value = membuffer_set_size(m, new_length); | ||||
| 	/* shrinking should always work */ | ||||
| 	assert(return_value == 0); | ||||
|  | ||||
| 	/* don't modify until buffer is set */ | ||||
|     memmove( m->buf + index, m->buf + index + num_bytes, copy_len ); | ||||
|  | ||||
|     new_length = m->length - num_bytes; | ||||
|     return_value = membuffer_set_size( m, new_length ); // trim buffer | ||||
|     assert( return_value == 0 );    // shrinking should always work | ||||
|  | ||||
|     // don't modify until buffer is set | ||||
|     m->length = new_length; | ||||
|     m->buf[new_length] = 0; | ||||
| } | ||||
| @@ -491,7 +541,7 @@ membuffer_detach( INOUT membuffer * m ) | ||||
|  | ||||
|     buf = m->buf; | ||||
|  | ||||
|     /* free all */ | ||||
|     // free all | ||||
|     membuffer_initialize( m ); | ||||
|  | ||||
|     return buf; | ||||
|   | ||||
| @@ -1,33 +1,33 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer. | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer in the documentation | ||||
|  * and/or other materials provided with the distribution. | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors | ||||
|  * may be used to endorse or promote products derived from this software | ||||
|  * without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /************************************************************************ | ||||
| * Purpose: This file contains string to integer and integer to string  | ||||
| @@ -48,7 +48,7 @@ | ||||
| *					matched. | ||||
| *		IN int num_entries ; number of entries in the table that need  | ||||
| *					to be searched. | ||||
| *		IN int case_sensitive ; whether the case should be case | ||||
| *		IN xboolean case_sensitive ; whether the case should be case | ||||
| *					sensitive or not | ||||
| * | ||||
| *	Description : Match the given name with names from the entries in the  | ||||
| @@ -65,7 +65,7 @@ map_str_to_int( IN const char *name, | ||||
|                 IN size_t name_len, | ||||
|                 IN str_int_entry * table, | ||||
|                 IN int num_entries, | ||||
|                 IN int case_sensitive ) | ||||
|                 IN xboolean case_sensitive ) | ||||
| { | ||||
|     int top, | ||||
|       mid, | ||||
| @@ -82,24 +82,24 @@ map_str_to_int( IN const char *name, | ||||
|     while( top <= bot ) { | ||||
|         mid = ( top + bot ) / 2; | ||||
|         if( case_sensitive ) { | ||||
|             /*cmp = strcmp( name, table[mid].name ); */ | ||||
|             //cmp = strcmp( name, table[mid].name ); | ||||
|             cmp = memptr_cmp( &name_ptr, table[mid].name ); | ||||
|         } else { | ||||
|             /*cmp = strcasecmp( name, table[mid].name ); */ | ||||
|             //cmp = strcasecmp( name, table[mid].name ); | ||||
|             cmp = memptr_cmp_nocase( &name_ptr, table[mid].name ); | ||||
|         } | ||||
|  | ||||
|         if( cmp > 0 ) { | ||||
|             top = mid + 1;      /* look below mid */ | ||||
|             top = mid + 1;      // look below mid | ||||
|         } else if( cmp < 0 ) { | ||||
|             bot = mid - 1;      /* look above mid */ | ||||
|         } else                  /* cmp == 0 */ | ||||
|             bot = mid - 1;      // look above mid | ||||
|         } else                  // cmp == 0 | ||||
|         { | ||||
|             return mid;         /* match; return table index */ | ||||
|             return mid;         // match; return table index | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return -1;                  /* header name not found */ | ||||
|     return -1;                  // header name not found | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
|   | ||||
| @@ -1,59 +1,65 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * * Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * * Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
|  * \brief Contains a function for freeing the memory associated with a upnp  | ||||
|  * time out event. | ||||
|  */ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /************************************************************************ | ||||
| * Purpose: This file contains a function for freeing the memory associated | ||||
| *		wuth a upnp time out event. | ||||
| ************************************************************************/ | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
|  | ||||
| #include "upnp_timeout.h" | ||||
|  | ||||
| #include <stdlib.h> | ||||
|  | ||||
| #include <stdlib.h> /* for free() */ | ||||
|  | ||||
|  | ||||
| void free_upnp_timeout(upnp_timeout *event) | ||||
| /************************************************************************ | ||||
| *	Function :	free_upnp_timeout | ||||
| * | ||||
| *	Parameters : | ||||
| *		upnp_timeout *event ;	Event which needs to be freed | ||||
| * | ||||
| *	Description : Free memory associated with event and memory for any  | ||||
| *		sub-elements  | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void | ||||
| free_upnp_timeout( upnp_timeout * event ) | ||||
| { | ||||
| 	if (event) { | ||||
| 		if (event->Event) { | ||||
| 			free(event->Event); | ||||
| 		} | ||||
| 		free(event); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|     if( event ) { | ||||
|         if( event->Event ) | ||||
|             free( event->Event ); | ||||
|         free( event ); | ||||
|  | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,67 +1,113 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  * | ||||
| /************************************************************************ | ||||
| * Purpose: This file contains functions for copying strings based on  | ||||
| * different options. | ||||
|  */ | ||||
| ************************************************************************/ | ||||
|  | ||||
| #include "config.h" | ||||
| #include "upnp.h" | ||||
| #include "upnputil.h" | ||||
| #include "util.h" | ||||
|  | ||||
| #include <string.h> | ||||
|  | ||||
| void linecopy(char dest[LINE_SIZE], const char *src) | ||||
| /************************************************************************ | ||||
| *	Function :	linecopy | ||||
| * | ||||
| *	Parameters : | ||||
| *		OUT char dest[LINE_SIZE] ;	output buffer | ||||
| *		IN const char* src ;	input buffer | ||||
| * | ||||
| *	Description : Copy no of bytes spcified by the LINE_SIZE constant,  | ||||
| *		from the source buffer. Null terminate the destination buffer | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void | ||||
| linecopy( OUT char dest[LINE_SIZE], | ||||
|           IN const char *src ) | ||||
| { | ||||
|     strncpy( dest, src, LINE_SIZE - 1 ); | ||||
| 	/* null-terminate if len(src) >= LINE_SIZE. */ | ||||
| 	dest[LINE_SIZE - 1] = '\0'; | ||||
|     dest[LINE_SIZE - 1] = '\0'; // null-terminate if len(src) >= LINE_SIZE | ||||
| } | ||||
|  | ||||
| void namecopy(char dest[NAME_SIZE], const char *src) | ||||
| /************************************************************************ | ||||
| *	Function :	namecopy | ||||
| * | ||||
| *	Parameters : | ||||
| *		OUT char dest[NAME_SIZE] ;	output buffer | ||||
| *		IN const char* src ;	input buffer | ||||
| * | ||||
| *	Description : Copy no of bytes spcified by the NAME_SIZE constant,  | ||||
| *		from the source buffer. Null terminate the destination buffer | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void | ||||
| namecopy( OUT char dest[NAME_SIZE], | ||||
|           IN const char *src ) | ||||
| { | ||||
|     strncpy( dest, src, NAME_SIZE - 1 ); | ||||
| 	/* null-terminate if len(src) >= NAME_SIZE. */ | ||||
| 	dest[NAME_SIZE - 1] = '\0'; | ||||
|     dest[NAME_SIZE - 1] = '\0'; // null-terminate if len(src) >= NAME_SIZE | ||||
| } | ||||
|  | ||||
| void linecopylen(char dest[LINE_SIZE], const char *src, size_t srclen) | ||||
| /************************************************************************ | ||||
| *	Function :	linecopylen | ||||
| * | ||||
| *	Parameters : | ||||
| *		OUT char dest[LINE_SIZE] ;	output buffer | ||||
| *		IN const char* src ;	input buffer | ||||
| *		IN size_t srclen ;	bytes to be copied. | ||||
| * | ||||
| *	Description : Determine if the srclen passed in paramter is less than  | ||||
| *		the permitted LINE_SIZE. If it is use the passed parameter, if not | ||||
| *		use the permitted LINE_SIZE as the length parameter | ||||
| *		Copy no of bytes spcified by the LINE_SIZE constant,  | ||||
| *		from the source buffer. Null terminate the destination buffer | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void | ||||
| linecopylen( OUT char dest[LINE_SIZE], | ||||
|              IN const char *src, | ||||
|              IN size_t srclen ) | ||||
| { | ||||
| 	size_t len; | ||||
|     int len; | ||||
|  | ||||
|     len = srclen < ( LINE_SIZE - 1 ) ? srclen : ( LINE_SIZE - 1 ); | ||||
|     strncpy( dest, src, len ); | ||||
|     dest[len] = '\0'; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,69 +0,0 @@ | ||||
|  | ||||
|  | ||||
| #ifndef VIRTUALDIR_H | ||||
| #define VIRTUALDIR_H | ||||
|  | ||||
|  | ||||
| /** The \b VirtualDirCallbacks structure contains the pointers to | ||||
|  *  file-related callback functions a device application can register to | ||||
|  *  virtualize URLs.   | ||||
|  */ | ||||
| struct VirtualDirCallbacks | ||||
| { | ||||
| 	/** Called by the web server to query information on a file.  The callback | ||||
| 	 *  should return 0 on success or -1 on an error. */ | ||||
| 	VDCallback_GetInfo get_info; | ||||
|  | ||||
| 	/** Called by the web server to open a file.  The callback should return | ||||
| 	 *  a valid handle if the file can be opened.  Otherwise, it should return | ||||
| 	 *  \c NULL to signify an error. */ | ||||
| 	VDCallback_Open open; | ||||
|  | ||||
| 	/** Called by the web server to perform a sequential read from an open | ||||
| 	 *  file.  The callback should copy \b buflen bytes from the file into | ||||
| 	 *  the buffer. | ||||
| 	 *  @return An integer representing one of the following: | ||||
| 	 *      \li <tt>   0</tt>:  The file contains no more data (EOF). | ||||
| 	 *      \li <tt> > 0</tt>: A successful read of the number of bytes in the | ||||
| 	 *      	return code. | ||||
| 	 *      \li <tt> < 0</tt>: An error occurred reading the file. | ||||
| 	 */ | ||||
| 	VDCallback_Read read; | ||||
|  | ||||
| 	/** Called by the web server to perform a sequential write to an open | ||||
| 	 *  file.  The callback should write \b buflen bytes into the file from | ||||
| 	 *  the buffer.  It should return the actual number of bytes written,  | ||||
| 	 *  which might be less than \b buflen in the case of a write error. | ||||
| 	 */ | ||||
| 	VDCallback_Write write; | ||||
|  | ||||
| 	/** Called by the web server to move the file pointer, or offset, into | ||||
| 	 *  an open file.  The \b origin parameter determines where to start | ||||
| 	 *  moving the file pointer.  A value of \c SEEK_CUR moves the | ||||
| 	 *  file pointer relative to where it is.  The \b offset parameter can | ||||
| 	 *  be either positive (move forward) or negative (move backward).   | ||||
| 	 *  \c SEEK_END moves relative to the end of the file.  A positive  | ||||
| 	 *  \b offset extends the file.  A negative \b offset moves backward  | ||||
| 	 *  in the file.  Finally, \c SEEK_SET moves to an absolute position in  | ||||
| 	 *  the file. In this case, \b offset must be positive.  The callback  | ||||
| 	 *  should return 0 on a successful seek or a non-zero value on an error. | ||||
| 	 */ | ||||
| 	VDCallback_Seek seek; | ||||
|  | ||||
| 	/** Called by the web server to close a file opened via the \b open | ||||
| 	 *  callback.  It should return 0 on success, or a non-zero value on an  | ||||
| 	 *  error. | ||||
| 	 */ | ||||
| 	VDCallback_Close close; | ||||
| }; | ||||
|  | ||||
|  | ||||
| typedef struct virtual_Dir_List | ||||
| { | ||||
| 	struct virtual_Dir_List *next; | ||||
| 	char dirName[NAME_SIZE]; | ||||
| } virtualDirList; | ||||
|  | ||||
|  | ||||
| #endif /* VIRTUALDIR_H */ | ||||
|  | ||||
| @@ -1,248 +1,167 @@ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef CLIENT_TABLE_H | ||||
| #define CLIENT_TABLE_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| #ifndef _CLIENT_TABLE | ||||
| #define _CLIENT_TABLE | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #include "service_table.h" | ||||
| #include "upnp.h" | ||||
| #include "UpnpString.h" | ||||
| #include "upnp_timeout.h" | ||||
| #include "uri.h" | ||||
| #include "TimerThread.h" | ||||
|  | ||||
|  | ||||
| #include <stdio.h> | ||||
| //#include <malloc.h> | ||||
| #include <stdlib.h> | ||||
| #include <time.h> | ||||
| #include "uri.h" | ||||
| #include "service_table.h" | ||||
|  | ||||
| #include "TimerThread.h" | ||||
| #include "upnp_timeout.h" | ||||
|  | ||||
| extern TimerThread gTimerThread; | ||||
|  | ||||
| CLIENTONLY( | ||||
| typedef struct CLIENT_SUBSCRIPTION { | ||||
|   Upnp_SID sid; | ||||
|   char * ActualSID; | ||||
|   char * EventURL; | ||||
|   int RenewEventId; | ||||
|   struct CLIENT_SUBSCRIPTION * next; | ||||
| } client_subscription; | ||||
|  | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
|  | ||||
|  | ||||
| typedef struct s_ClientSubscription ClientSubscription; | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Constructor. | ||||
|  */ | ||||
| ClientSubscription *UpnpClientSubscription_new(); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Destructor. | ||||
|  */ | ||||
| void UpnpClientSubscription_delete( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Copy Constructor. | ||||
|  */ | ||||
| ClientSubscription *UpnpClientSubscription_dup( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	const ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Assignment operator. | ||||
|  */ | ||||
| void UpnpClientSubscription_assign( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *q, | ||||
| 	const ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| int UpnpClientSubscription_get_RenewEventId( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	const ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_set_RenewEventId( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	/*! [in] . */ | ||||
| 	int n); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| const UpnpString *UpnpClientSubscription_get_SID( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	const ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_set_SID( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	const UpnpString *s); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_strcpy_SID( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	const char *s); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| const UpnpString *UpnpClientSubscription_get_ActualSID( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	const ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_set_ActualSID( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	const UpnpString *s); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_strcpy_ActualSID( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	const char *s); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| const UpnpString *UpnpClientSubscription_get_EventURL( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	const ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_set_EventURL( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	const UpnpString *s); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_strcpy_EventURL( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	const char *s); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| ClientSubscription *UpnpClientSubscription_get_Next( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	const ClientSubscription *p); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief  | ||||
|  */ | ||||
| void UpnpClientSubscription_set_Next( | ||||
| 	/*! [in] The \b this pointer. */ | ||||
| 	ClientSubscription *p, | ||||
| 	ClientSubscription *q); | ||||
|  | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Free memory allocated for client subscription data. | ||||
| /************************************************************************ | ||||
| *	Function :	copy_client_subscription | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription * in ;	- source client subscription | ||||
| *		client_subscription * out ;	- destination client subscription | ||||
| * | ||||
| *	Description :	Make a copy of the client subscription data | ||||
| * | ||||
| *	Return : int ; | ||||
| *		UPNP_E_OUTOF_MEMORY - On Failure to allocate memory | ||||
| *		HTTP_SUCCESS - On Success | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| int copy_client_subscription(client_subscription * in, client_subscription * out); | ||||
|  | ||||
| /************************************************************************ | ||||
| *	Function :	free_client_subscription | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription * sub ;	- Client subscription to be freed | ||||
| * | ||||
| *	Description :	Free memory allocated for client subscription data. | ||||
| *		Remove timer thread associated with this subscription event. | ||||
|  */ | ||||
| void free_client_subscription( | ||||
| 	/*! [in] Client subscription to be freed. */ | ||||
| 	ClientSubscription *sub); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Free the client subscription table. | ||||
|  */ | ||||
| void freeClientSubList( | ||||
| 	/*! [in] Client subscription list to be freed. */ | ||||
| 	ClientSubscription *list); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Remove the client subscription matching the subscritpion id | ||||
|  * represented by the const Upnp_SID sid parameter from the table and | ||||
|  * update the table. | ||||
|  */ | ||||
| void RemoveClientSubClientSID( | ||||
| 	/*! [in] Head of the subscription list. */ | ||||
| 	ClientSubscription **head, | ||||
| 	/*! [in] Subscription ID to be mactched. */ | ||||
| 	const UpnpString *sid); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Return the client subscription from the client table that matches | ||||
|  * const Upnp_SID sid subscrition id value. | ||||
| * | ||||
|  * \return The matching subscription. | ||||
|  */ | ||||
| ClientSubscription *GetClientSubClientSID( | ||||
| 	/*! [in] Head of the subscription list. */ | ||||
| 	ClientSubscription *head, | ||||
| 	/*! [in] Subscription ID to be mactched. */ | ||||
| 	const UpnpString *sid); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Returns the client subscription from the client subscription table | ||||
|  * that has the matching token *sid buffer value. | ||||
| *	Return : void ; | ||||
| * | ||||
|  * \return The matching subscription. | ||||
|  */ | ||||
| ClientSubscription *GetClientSubActualSID( | ||||
| 	/*! [in] Head of the subscription list. */ | ||||
| 	ClientSubscription *head, | ||||
| 	/*! [in] Subscription ID to be mactched. */ | ||||
| 	token *sid); | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void free_client_subscription(client_subscription * sub); | ||||
|  | ||||
|  | ||||
| #endif /* INCLUDE_CLIENT_APIS */ | ||||
| /************************************************************************ | ||||
| *	Function :	freeClientSubList | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription * list ; Client subscription  | ||||
| * | ||||
| *	Description :	Free the client subscription table. | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void freeClientSubList(client_subscription * list); | ||||
|  | ||||
| /************************************************************************ | ||||
| *	Function :	RemoveClientSubClientSID | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription **head ; Head of the subscription list	 | ||||
| *		const Upnp_SID sid ;		 Subscription ID to be mactched | ||||
| * | ||||
| *	Description :	Remove the client subscription matching the  | ||||
| *		subscritpion id represented by the const Upnp_SID sid parameter  | ||||
| *		from the table and update the table. | ||||
| * | ||||
| *	Return : void ; | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| void RemoveClientSubClientSID(client_subscription **head,  | ||||
| 				       const Upnp_SID sid); | ||||
|  | ||||
| /************************************************************************ | ||||
| *	Function :	GetClientSubClientSID | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription *head ; Head of the subscription list	 | ||||
| *		const Upnp_SID sid ;		Subscription ID to be matched | ||||
| * | ||||
| *	Description :	Return the client subscription from the client table  | ||||
| *		that matches const Upnp_SID sid subscrition id value.  | ||||
| * | ||||
| *	Return : client_subscription * ; The matching subscription | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| client_subscription * GetClientSubClientSID(client_subscription *head | ||||
| 						     , const Upnp_SID sid); | ||||
|  | ||||
| /************************************************************************ | ||||
| *	Function :	GetClientSubActualSID | ||||
| * | ||||
| *	Parameters : | ||||
| *		client_subscription *head ;	Head of the subscription list		 | ||||
| *		token * sid ;				Subscription ID to be matched | ||||
| * | ||||
| *	Description :	Returns the client subscription from the client  | ||||
| *		subscription table that has the matching token * sid buffer | ||||
| *		value. | ||||
| * | ||||
| *	Return : client_subscription * ; The matching subscription | ||||
| * | ||||
| *	Note : | ||||
| ************************************************************************/ | ||||
| client_subscription * GetClientSubActualSID(client_subscription *head | ||||
| 						     , token * sid); | ||||
| ) | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
|  | ||||
| #endif /* CLIENT_TABLE_H */ | ||||
| #endif | ||||
|  | ||||
| #endif /*	_CLIENT_TABLE */ | ||||
|   | ||||
| @@ -1,33 +1,33 @@ | ||||
| /************************************************************************** | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer. | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice, | ||||
|  * this list of conditions and the following disclaimer in the documentation | ||||
|  * and/or other materials provided with the distribution. | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors | ||||
|  * may be used to endorse or promote products derived from this software | ||||
|  * without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  **************************************************************************/ | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef INTERNAL_CONFIG_H | ||||
| #define INTERNAL_CONFIG_H  | ||||
| @@ -36,66 +36,52 @@ | ||||
| #include "autoconfig.h" | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  *  \name Compile time configuration options | ||||
|  * | ||||
| /** @name Compile time configuration options | ||||
|  *  The Linux SDK for UPnP Devices contains some compile-time parameters  | ||||
|  *  that effect the behavior of the SDK.  All configuration options are  | ||||
|  *  located in {\tt src/inc/config.h}. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|   | ||||
| //@{ | ||||
|  | ||||
| /*! | ||||
|  *  \name THREAD_IDLE_TIME | ||||
|  * | ||||
| /** @name THREAD_IDLE_TIME | ||||
|  *  The {\tt THREAD_IDLE_TIME} constant determines when a thread will be | ||||
|  *  removed from the thread pool and returned to the operating system. When  | ||||
|  *  a thread in the thread pool has been idle for this number of milliseconds | ||||
|  *  the thread will be released from the thread pool.  The default value is | ||||
|  *  5000 milliseconds (5 seconds). | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define THREAD_IDLE_TIME 5000 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name JOBS_PER_THREAD | ||||
|  * | ||||
| /** @name JOBS_PER_THREAD | ||||
|  *  The {\tt JOBS_PER_THREAD} constant determines when a new thread will be | ||||
|  *  allocated to the thread pool inside the  SDK. The thread pool will | ||||
|  *  try and maintain this jobs/thread ratio. When the jobs/thread ratio  | ||||
|  *  becomes greater than this, then a new thread (up to the max) will be  | ||||
|  *  allocated to the thread pool.  The default ratio is 10 jobs/thread. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define JOBS_PER_THREAD 10 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name MIN_THREADS | ||||
|  * | ||||
| /** @name MIN_THREADS | ||||
|  *  The {\tt MIN_THREADS} constant defines the minimum number of threads the | ||||
|  *  thread pool inside the SDK will create.  The thread pool will | ||||
|  *  always have this number of threads. These threads are used | ||||
|  *  for both callbacks into applications built on top of the SDK and also | ||||
|  *  for making connections to other control points and devices. This number | ||||
|  *  includes persistent threads.  The default value is two threads. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MIN_THREADS 2  | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name MAX_THREADS | ||||
|  * | ||||
| /** @name MAX_THREADS | ||||
|  *  The {\tt MAX_THREADS} constant defines the maximum number of threads the | ||||
|  *  thread pool inside the SDK will create.  These threads are used | ||||
|  *  for both callbacks into applications built on top of the library and also  | ||||
| @@ -104,111 +90,60 @@ | ||||
|  *  necessary for correct operation.  This value can be increased for greater | ||||
|  *  performance in operation at the expense of greater memory overhead.  The  | ||||
|  *  default value is 12. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MAX_THREADS 12  | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name THREAD_STACK_SIZE | ||||
|  * | ||||
|  * The {\tt THREAD_STACK_SIZE} constant defines the minimum stack size (in | ||||
|  * bytes) allocated for the stack of each thread the thread pool inside the | ||||
|  * SDK will create.  These threads are used for both callbacks into | ||||
|  * applications built on top of the library and also for making connections | ||||
|  * to other control points and devices.  This value will not be used if it | ||||
|  * is lower than ITHREAD_STACK_MIN or greater than a system-imposed limit. | ||||
|  * This value can be used to lower memory overhead in embedded systems. | ||||
|  * The default value is 0 (so it is not used by default). | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| #define THREAD_STACK_SIZE 0 | ||||
| /* @} */ | ||||
|  | ||||
|  | ||||
| /*! \name MAX_JOBS_TOTAL | ||||
|  * | ||||
| /** @name MAX_JOBS_TOTAL | ||||
|  *  The {\tt MAX_JOBS_TOTAL} constant determines the maximum number of jobs | ||||
|  *  that can be queued. If this limit is reached further jobs will be thrown | ||||
|  *  to avoid memory exhaustion. The default value 100. | ||||
|  *  (Added by Axis.) | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MAX_JOBS_TOTAL 100 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name DEFAULT_SOAP_CONTENT_LENGTH | ||||
|  * | ||||
| /** @name DEFAULT_SOAP_CONTENT_LENGTH | ||||
|  * SOAP messages will read at most {\tt DEFAULT_SOAP_CONTENT_LENGTH} bytes.   | ||||
|  * This prevents devices that have a misbehaving web server to send  | ||||
|  * a large amount of data to the control point causing it to crash.   | ||||
|  * This can be adjusted dynamically with {\tt UpnpSetMaxContentLength}. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| //@{ | ||||
| #define DEFAULT_SOAP_CONTENT_LENGTH 16000 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name NUM_SSDP_COPY | ||||
|  * | ||||
| /** @name NUM_SSDP_COPY | ||||
|  * This configuration parameter determines how many copies of each SSDP  | ||||
|  * advertisement and search packets will be sent. By default it will send two  | ||||
|  * copies of every packet.   | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| //@{ | ||||
| #define NUM_SSDP_COPY  2 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name SSDP_PAUSE | ||||
|  * | ||||
| /** @name SSDP_PAUSE | ||||
|  * This configuration parameter determines the pause between identical SSDP  | ||||
|  * advertisement and search packets. The pause is measured in milliseconds | ||||
|  * and defaults to 100. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| //@{ | ||||
| #define SSDP_PAUSE  100 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
| /*! | ||||
|  * \name WEB_SERVER_BUF_SIZE | ||||
|  *  | ||||
| /** @name WEB_SERVER_BUF_SIZE  | ||||
|  * This configuration parameter sets the maximum buffer size for the  | ||||
|  * webserver.  The default value is 1MB. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| //@{ | ||||
| #define WEB_SERVER_BUF_SIZE  (1024*1024) | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
| /*! | ||||
|  * \name WEB_SERVER_CONTENT_LANGUAGE | ||||
|  * | ||||
|  * This configuration parameter sets the value of the Content-Language | ||||
|  * header for the webserver. Thanks to this parameter, the use can advertize | ||||
|  * the language used by the device in the description (friendlyName) and | ||||
|  * presentation steps of UPnP. The default value is empty string so no | ||||
|  * Content-Language header is added. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| #define WEB_SERVER_CONTENT_LANGUAGE "" | ||||
| /* @} */ | ||||
|  | ||||
| /*! | ||||
|  * \name AUTO_RENEW_TIME | ||||
|  * | ||||
| /** @name AUTO_RENEW_TIME | ||||
|  * The {\tt AUTO_RENEW_TIME} is the time, in seconds, before a subscription | ||||
|  * expires that the SDK automatically resubscribes.  The default  | ||||
|  * value is 10 seconds.  Setting this value too low can result in the  | ||||
| @@ -216,131 +151,71 @@ | ||||
|  * subscription to timeout. In order to avoid continually resubscribing | ||||
|  * the minimum subscription time is five seconds more than the auto renew | ||||
|  * time. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| #define AUTO_RENEW_TIME 10 | ||||
| /* @} */ | ||||
|  | ||||
| /*! | ||||
|  * \name CP_MINIMUM_SUBSCRIPTION_TIME | ||||
|  * | ||||
| //@{ | ||||
| #define AUTO_RENEW_TIME 10 | ||||
| //@} | ||||
|  | ||||
| /** @name CP_MINIMUM_SUBSCRIPTION_TIME  | ||||
|  * The {\tt CP_MINIMUM_SUBSCRIPTION_TIME} is the minimum subscription time | ||||
|  * allowed for a control point using the SDK. Subscribing for less than | ||||
|  * this time automatically results in a subscription for this amount.  The  | ||||
|  * default value is 5 seconds more than the {\tt AUTO_RENEW_TIME}, or 15 | ||||
|  * seconds. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define CP_MINIMUM_SUBSCRIPTION_TIME (AUTO_RENEW_TIME + 5) | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name MAX_SEARCH_TIME | ||||
|  * | ||||
| /** @name MAX_SEARCH_TIME  | ||||
|  * The {\tt MAX_SEARCH_TIME} is the maximum time | ||||
|  * allowed for an SSDP search by a control point. Searching for greater than | ||||
|  * this time automatically results in a search for this amount.  The default  | ||||
|  * value is 80 seconds. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MAX_SEARCH_TIME 80 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name MIN_SEARCH_TIME | ||||
|  * | ||||
| /** @name MIN_SEARCH_TIME  | ||||
|  * The {\tt MIN_SEARCH_TIME} is the minimumm time | ||||
|  * allowed for an SSDP search by a control point. Searching for less than | ||||
|  * this time automatically results in a search for this amount.  The default  | ||||
|  * value is 2 seconds. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define MIN_SEARCH_TIME 2 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name AUTO_ADVERTISEMENT_TIME | ||||
|  * | ||||
| /** @name AUTO_ADVERTISEMENT_TIME | ||||
|  *  The {\tt AUTO_ADVERTISEMENT_TIME} is the time, in seconds, before an | ||||
|  *  device advertisements expires before a renewed advertisement is sent. | ||||
|  *  The default time is 30 seconds. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define AUTO_ADVERTISEMENT_TIME 30 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name SSDP_PACKET_DISTRIBUTE | ||||
|  * | ||||
| /** @name SSDP_PACKET_DISTRIBUTE | ||||
|  *  The {\tt SSDP_PACKET_DISTRIBUTE} enables the SSDP packets to be sent | ||||
|  *  at an interval equal to half of the expiration time of SSDP packets | ||||
|  *  minus the AUTO_ADVERTISEMENT_TIME. This is used to increase | ||||
|  *  the probability of SSDP packets reaching to control points. | ||||
|  *  It is recommended that this flag be turned on for embedded wireless  | ||||
|  *  devices. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define SSDP_PACKET_DISTRIBUTE 1 | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name GENA_NOTIFICATION_SENDING_TIMEOUT | ||||
|  * | ||||
|  * The {\tt GENA_NOTIFICATION_SENDING_TIMEOUT} specifies the number of seconds | ||||
|  * to wait for sending GENA notifications to the Control Point. | ||||
|  * | ||||
|  * This timeout will be used to know how many seconds GENA notification threads | ||||
|  * will wait to write on the socket to send the notification. By putting a | ||||
|  * lower value than HTTP_DEFAULT_TIMEOUT, the thread will not wait too long and | ||||
|  * will return quickly if writing is impossible. This is very useful as some | ||||
|  * Control Points disconnect from the network without unsubscribing as a result | ||||
|  * if HTTP_DEFAULT_TIMEOUT is used, all the GENA threads will be blocked to send | ||||
|  * notifications to those disconnected Control Points until the subscription | ||||
|  * expires. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| #define GENA_NOTIFICATION_SENDING_TIMEOUT HTTP_DEFAULT_TIMEOUT | ||||
| /* @} */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name GENA_NOTIFICATION_ANSWERING_TIMEOUT | ||||
|  * | ||||
|  * The {\tt GENA_NOTIFICATION_ANSWERING_TIMEOUT} specifies the number of seconds | ||||
|  * to wait for receiving the answer to a GENA notification from the Control | ||||
|  * Point. | ||||
|  * | ||||
|  * This timeout will be used to know how many seconds GENA notification threads | ||||
|  * will wait on the socket to read for an answer from the CP. By putting a | ||||
|  * lower value than HTTP_DEFAULT_TIMEOUT, the thread will not wait too long and | ||||
|  * will return quickly if there is no answer from the CP. This is very useful as | ||||
|  * some Control Points disconnect from the network without unsubscribing and if | ||||
|  * HTTP_DEFAULT_TIMEOUT is used, all the GENA threads will be blocked to wait | ||||
|  * for an answer from those disconnected Control Points until the subscription | ||||
|  * expires. However, it should be noted that UDA specifies a value of 30s for | ||||
|  * waiting the CP's answer. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
| #define GENA_NOTIFICATION_ANSWERING_TIMEOUT HTTP_DEFAULT_TIMEOUT | ||||
| /* @} */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name Module Exclusion | ||||
|  * | ||||
| /** @name Module Exclusion | ||||
|  *  Depending on the requirements, the user can selectively discard any of  | ||||
|  *  the major modules like SOAP, GENA, SSDP or the Internal web server. By  | ||||
|  *  default everything is included inside the SDK.  By setting any of | ||||
| @@ -356,8 +231,9 @@ | ||||
|  *    \item {\tt EXCLUDE_JNI[0,1]} | ||||
|  *  \end{itemize} | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define EXCLUDE_SSDP 0 | ||||
| #define EXCLUDE_SOAP 0 | ||||
| #define EXCLUDE_GENA 0 | ||||
| @@ -369,28 +245,24 @@ | ||||
| #else | ||||
| #	define EXCLUDE_JNI 1 | ||||
| #endif | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|      | ||||
| /*! | ||||
|  * \name DEBUG_TARGET | ||||
|  * | ||||
| /** @name DEBUG_TARGET | ||||
|  *  The user has the option to redirect the library output debug messages  | ||||
|  *  to either the screen or to a log file.  All the output messages with  | ||||
|  *  debug level 0 will go to {\tt upnp.err} and messages with debug level  | ||||
|  *  greater than zero will be redirected to {\tt upnp.out}. | ||||
|  * | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
| #define DEBUG_TARGET		1    | ||||
| /* @} */ | ||||
| //@} | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \name Other debugging features | ||||
|  * | ||||
|  * The UPnP SDK contains other features to aid in debugging: | ||||
|  * see <upnp/inc/upnpdebug.h> | ||||
| /** @name Other debugging features | ||||
|           The UPnP SDK contains other features to aid in debugging: | ||||
| 	  see <upnp/inc/upnpdebug.h> | ||||
|  */ | ||||
|  | ||||
| #define DEBUG_ALL		1 | ||||
| @@ -403,44 +275,36 @@ | ||||
| #define DEBUG_HTTP		0 | ||||
| #define DEBUG_API		0 | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * @} Compile time configuration options | ||||
|  */ | ||||
| //@} // Compile time configuration options | ||||
|  | ||||
|  | ||||
| /*************************************************************************** | ||||
|  * Do not change, Internal purpose only!!!  | ||||
|  ***************************************************************************/  | ||||
|  | ||||
| /*! | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| //@{ | ||||
|  | ||||
| /* | ||||
|  * Set additional defines based on requested configuration  | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /* configure --enable-client */ | ||||
| // configure --enable-client | ||||
| #if UPNP_HAVE_CLIENT | ||||
| #	define INCLUDE_CLIENT_APIS	1 | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* configure --enable-device */ | ||||
| // configure --enable-device | ||||
| #if UPNP_HAVE_DEVICE | ||||
| #	define INCLUDE_DEVICE_APIS	1 | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* configure --enable-webserver --enable-device */ | ||||
| // configure --enable-webserver --enable-device | ||||
| #if UPNP_HAVE_WEBSERVER | ||||
| #	define INTERNAL_WEB_SERVER	1 | ||||
| #endif | ||||
|  | ||||
|  | ||||
|  | ||||
| #undef  EXCLUDE_WEB_SERVER  | ||||
| #undef  EXCLUDE_MINISERVER  | ||||
| #ifdef  INTERNAL_WEB_SERVER | ||||
| @@ -451,7 +315,6 @@ | ||||
| #	define EXCLUDE_MINISERVER 1 | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if EXCLUDE_GENA == 1 && EXCLUDE_SOAP == 1 && EXCLUDE_WEB_SERVER == 1 | ||||
| #	undef  EXCLUDE_MINISERVER  | ||||
| #	define EXCLUDE_MINISERVER 1 | ||||
| @@ -460,7 +323,6 @@ | ||||
| #	endif | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if EXCLUDE_GENA == 0 || EXCLUDE_SOAP == 0 || EXCLUDE_WEB_SERVER == 0 | ||||
| #	undef  EXCLUDE_MINISERVER  | ||||
| #	define EXCLUDE_MINISERVER 0 | ||||
| @@ -470,9 +332,13 @@ | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * @} | ||||
|  */ | ||||
|  | ||||
| #endif /* INTERNAL_CONFIG_H */ | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
| #	define CLIENTONLY(x) x | ||||
| #else  | ||||
| #	define CLIENTONLY(x) | ||||
| #endif | ||||
|  | ||||
| //@} | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -1,83 +1,65 @@ | ||||
| /******************************************************************************* | ||||
|  * | ||||
|  * Copyright (c) 2000-2003 Intel Corporation  | ||||
|  * All rights reserved.  | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without  | ||||
|  * modification, are permitted provided that the following conditions are met:  | ||||
|  * | ||||
|  * - Redistributions of source code must retain the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer.  | ||||
|  * - Redistributions in binary form must reproduce the above copyright notice,  | ||||
|  * this list of conditions and the following disclaimer in the documentation  | ||||
|  * and/or other materials provided with the distribution.  | ||||
|  * - Neither name of Intel Corporation nor the names of its contributors  | ||||
|  * may be used to endorse or promote products derived from this software  | ||||
|  * without specific prior written permission. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  ******************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef GENA_H | ||||
| #define GENA_H | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \file | ||||
|  */ | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
| // | ||||
| // Copyright (c) 2000-2003 Intel Corporation  | ||||
| // All rights reserved.  | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without  | ||||
| // modification, are permitted provided that the following conditions are met:  | ||||
| // | ||||
| // * Redistributions of source code must retain the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer.  | ||||
| // * Redistributions in binary form must reproduce the above copyright notice,  | ||||
| // this list of conditions and the following disclaimer in the documentation  | ||||
| // and/or other materials provided with the distribution.  | ||||
| // * Neither name of Intel Corporation nor the names of its contributors  | ||||
| // may be used to endorse or promote products derived from this software  | ||||
| // without specific prior written permission. | ||||
| //  | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| // | ||||
| /////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| #ifndef _GENA_ | ||||
| #define _GENA_ | ||||
| #include "config.h" | ||||
| #include "service_table.h" | ||||
| #include "miniserver.h" | ||||
| #include "uri.h" | ||||
| #include "upnp.h" | ||||
|  | ||||
|  | ||||
| #include <string.h> | ||||
| #include <time.h> | ||||
|  | ||||
|  | ||||
| #include "ThreadPool.h" | ||||
| #include <string.h> | ||||
| #include "client_table.h" | ||||
| #include "httpparser.h" | ||||
| #include "miniserver.h" | ||||
| #include "service_table.h" | ||||
| #include "sock.h" | ||||
| #include "ThreadPool.h" | ||||
| #include "upnp.h" | ||||
| #include "UpnpString.h" | ||||
| #include "uri.h" | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| #define EXTERN_C extern "C" | ||||
| #else /* __cplusplus */ | ||||
| #else  | ||||
| #ifndef EXTERN_C | ||||
|  #define EXTERN_C  | ||||
| 	#endif /* EXTERN_C */ | ||||
| #endif /* __cplusplus */ | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief XML version comment. Not used because it is not interopeable with | ||||
|  * other UPnP vendors. | ||||
|  */ | ||||
| #define XML_VERSION "<?xml version='1.0' encoding='ISO-8859-1' ?>\n" | ||||
| #define XML_PROPERTYSET_HEADER \ | ||||
| 		"<e:propertyset xmlns:e=\"urn:schemas-upnp-org:event-1-0\">\n" | ||||
|  | ||||
|  | ||||
| #define UNABLE_MEMORY "HTTP/1.1 500 Internal Server Error\r\n\r\n" | ||||
| #define UNABLE_SERVICE_UNKNOWN "HTTP/1.1 404 Not Found\r\n\r\n" | ||||
| #define UNABLE_SERVICE_NOT_ACCEPT "HTTP/1.1 503 Service Not Available\r\n\r\n" | ||||
| #define UNABLE_SERVICE_NOT_ACCEPT \ | ||||
| 			"HTTP/1.1 503 Service Not Available\r\n\r\n" | ||||
|  | ||||
|  | ||||
| #define NOT_IMPLEMENTED "HTTP/1.1 501 Not Implemented\r\n\r\n" | ||||
| @@ -92,8 +74,6 @@ | ||||
| #define MAX_SECONDS 10 | ||||
| #define MAX_EVENTS 20 | ||||
| #define MAX_PORT_SIZE 10 | ||||
|  | ||||
|  | ||||
| #define GENA_E_BAD_RESPONSE UPNP_E_BAD_RESPONSE | ||||
| #define GENA_E_BAD_SERVICE UPNP_E_INVALID_SERVICE | ||||
| #define GENA_E_SUBSCRIPTION_UNACCEPTED UPNP_E_SUBSCRIBE_UNACCEPTED | ||||
| @@ -102,23 +82,16 @@ | ||||
| #define GENA_E_NOTIFY_UNACCEPTED UPNP_E_NOTIFY_UNACCEPTED | ||||
| #define GENA_E_NOTIFY_UNACCEPTED_REMOVE_SUB -9 | ||||
| #define GENA_E_BAD_HANDLE UPNP_E_INVALID_HANDLE | ||||
|  | ||||
|  | ||||
| #define XML_ERROR -5 | ||||
| #define XML_SUCCESS UPNP_E_SUCCESS | ||||
| #define GENA_SUCCESS UPNP_E_SUCCESS | ||||
|  | ||||
|  | ||||
| #define CALLBACK_SUCCESS 0 | ||||
| #define DEFAULT_TIMEOUT 1801 | ||||
|  | ||||
|  | ||||
| extern ithread_mutex_t GlobalClientSubscribeMutex; | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Locks the subscription. | ||||
|  */ | ||||
| // Lock the subscription | ||||
| #define SubscribeLock() \ | ||||
| 	UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, \ | ||||
| 		"Trying Subscribe Lock");  \ | ||||
| @@ -126,10 +99,7 @@ extern ithread_mutex_t GlobalClientSubscribeMutex; | ||||
| 	UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, \ | ||||
| 		"Subscribe Lock"); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Unlocks the subscription. | ||||
|  */ | ||||
| // Unlock the subscription | ||||
| #define SubscribeUnlock() \ | ||||
| 	UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, \ | ||||
| 		"Trying Subscribe UnLock"); \ | ||||
| @@ -138,9 +108,7 @@ extern ithread_mutex_t GlobalClientSubscribeMutex; | ||||
| 		"Subscribe UnLock"); | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * Structure to send NOTIFY message to all subscribed control points | ||||
|  */ | ||||
| // Structure to send NOTIFY message to all subscribed control points | ||||
| typedef struct NOTIFY_THREAD_STRUCT { | ||||
|   char * headers; | ||||
|   DOMString propertySet; | ||||
| @@ -153,233 +121,282 @@ typedef struct NOTIFY_THREAD_STRUCT { | ||||
| } notify_thread_struct; | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief This is the callback function called by the miniserver to handle | ||||
| /************************************************************************ | ||||
| * Function : genaCallback									 | ||||
| *																	 | ||||
| * Parameters:														 | ||||
| *	IN http_parser_t *parser: represents the parse state of the request | ||||
| *	IN http_message_t* request: HTTP message containing GENA request | ||||
| *	INOUT SOCKINFO *info: Structure containing information about the socket | ||||
| * | ||||
| * Description:														 | ||||
| *	This is the callback function called by the miniserver to handle  | ||||
| *	incoming GENA requests.  | ||||
| * | ||||
|  * \return UPNP_E_SUCCESS if successful, otherwise appropriate error code. | ||||
|  */ | ||||
| EXTERN_C void genaCallback( | ||||
| 	/*! [in] represents the parse state of the request */ | ||||
| 	http_parser_t *parser,  | ||||
| 	/*! [in] HTTP message containing GENA request */ | ||||
| 	http_message_t* request, | ||||
| 	/*! [in,out] Structure containing information about the socket */ | ||||
| 	SOCKINFO *info); | ||||
| * Returns: int | ||||
| *	UPNP_E_SUCCESS if successful else appropriate error | ||||
| ***************************************************************************/ | ||||
| EXTERN_C void genaCallback (IN http_parser_t *parser,  | ||||
| 							IN http_message_t* request,  | ||||
| 							IN SOCKINFO *info); | ||||
|  | ||||
|   | ||||
| /*! | ||||
|  * \brief This function subscribes to a PublisherURL (also mentioned as EventURL | ||||
|  * in some places). | ||||
| /************************************************************************ | ||||
| * Function : genaSubscribe | ||||
| *																	 | ||||
|  * It sends SUBSCRIBE http request to service processes request. Finally adds a | ||||
|  * Subscription to the clients subscription list, if service responds with OK. | ||||
| * Parameters:														 | ||||
| *	IN UpnpClient_Handle client_handle:  | ||||
| *	IN char * PublisherURL: NULL Terminated, of the form :  | ||||
| *						"http://134.134.156.80:4000/RedBulb/Event" | ||||
| *	INOUT int * TimeOut: requested Duration, if -1, then "infinite". | ||||
| *						in the OUT case: actual Duration granted  | ||||
| *						by Service, -1 for infinite | ||||
| *	OUT Upnp_SID out_sid:sid of subscription, memory passed in by caller | ||||
| * | ||||
|  * \return UPNP_E_SUCCESS if service response is OK, otherwise returns the  | ||||
|  *	appropriate error code | ||||
|  */ | ||||
| * Description:														 | ||||
| *	This function subscribes to a PublisherURL ( also mentioned as EventURL | ||||
| *	some places). It sends SUBSCRIBE http request to service processes  | ||||
| *	request. Finally adds a Subscription to  | ||||
| *	the clients subscription list, if service responds with OK | ||||
| * | ||||
| * Returns: int | ||||
| *	return UPNP_E_SUCCESS if service response is OK else  | ||||
| *	returns appropriate error | ||||
| ***************************************************************************/ | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
| EXTERN_C int genaSubscribe( | ||||
| 	/*! [in] The client handle. */ | ||||
| 	UpnpClient_Handle client_handle, | ||||
| 	/*! [in] Of the form: "http://134.134.156.80:4000/RedBulb/Event */ | ||||
| 	const UpnpString *PublisherURL, | ||||
| 	/*! [in,out] requested Duration: | ||||
| 	 * \li if -1, then "infinite". | ||||
| 	 * \li in the OUT case: actual Duration granted by Service, | ||||
| 	 * 	-1 for infinite. */ | ||||
| 	char * PublisherURL, | ||||
| 	int * TimeOut,  | ||||
| 	/*! [out] sid of subscription, memory passed in by caller. */ | ||||
| 	UpnpString *out_sid); | ||||
| #endif /* INCLUDE_CLIENT_APIS */ | ||||
| 	Upnp_SID  out_sid ); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Unsubscribes a SID. | ||||
| /************************************************************************ | ||||
| * Function : genaUnSubscribe | ||||
| *																	 | ||||
|  * It first validates the SID and client_handle,copies the subscription, sends | ||||
|  * UNSUBSCRIBE http request to service processes request and finally removes | ||||
|  * the subscription. | ||||
| * Parameters:														 | ||||
| *	IN UpnpClient_Handle client_handle: UPnP client handle | ||||
| *	IN SID in_sid: The subscription ID | ||||
| * | ||||
|  * \return UPNP_E_SUCCESS if service response is OK, otherwise returns the | ||||
|  * 	appropriate error code. | ||||
|  */ | ||||
| * Description:														 | ||||
| *	This function unsubscribes a SID. It first validates the SID and  | ||||
| *	client_handle,copies the subscription, sends UNSUBSCRIBE http request  | ||||
| *	to service processes request and finally removes the subscription | ||||
| * | ||||
| * Returns: int | ||||
| *	return UPNP_E_SUCCESS if service response is OK else  | ||||
| *	returns appropriate error | ||||
| ***************************************************************************/ | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
| EXTERN_C int genaUnSubscribe( | ||||
| 	/*! [in] UPnP client handle. */ | ||||
| 	UpnpClient_Handle client_handle, | ||||
| 	/*! [in] The subscription ID. */ | ||||
| 	const UpnpString *in_sid); | ||||
| #endif /* INCLUDE_CLIENT_APIS */ | ||||
| 	const Upnp_SID in_sid); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Unsubcribes all the outstanding subscriptions and cleans the | ||||
|  * 	subscription list. | ||||
| /************************************************************************ | ||||
| * Function : genaUnregisterClient									 | ||||
| *																	 | ||||
|  * This function is called when control point unregisters. | ||||
| * Parameters:														 | ||||
| *	IN UpnpClient_Handle client_handle: Handle containing all the control | ||||
| *			point related information | ||||
| * | ||||
|  * \returns UPNP_E_SUCCESS if successful, otherwise returns the appropriate | ||||
|  * 	error code. | ||||
|  */ | ||||
| * Description:														 | ||||
| *	This function unsubcribes all the outstanding subscriptions and cleans | ||||
| *	the subscription list. This function is called when control point  | ||||
| *	unregisters. | ||||
| * | ||||
| * Returns: int | ||||
| *	return UPNP_E_SUCCESS if successful else returns appropriate error | ||||
| ***************************************************************************/ | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
| EXTERN_C int genaUnregisterClient( | ||||
| 	/*! [in] Handle containing all the control point related information. */ | ||||
| 	UpnpClient_Handle client_handle); | ||||
| #endif /* INCLUDE_CLIENT_APIS */ | ||||
| EXTERN_C int genaUnregisterClient(UpnpClient_Handle client_handle); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * DEVICE | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Cleans the service table of the device. | ||||
| //server | ||||
| /************************************************************************ | ||||
| * Function : genaUnregisterDevice | ||||
| *																	 | ||||
|  * \return UPNP_E_SUCCESS if successful, otherwise returns GENA_E_BAD_HANDLE | ||||
|  */ | ||||
| * Parameters:														 | ||||
| *	IN UpnpDevice_Handle device_handle: Handle of the root device | ||||
| * | ||||
| * Description:														 | ||||
| *	This function cleans the service table of the device.  | ||||
| * | ||||
| * Returns: int | ||||
| *	returns UPNP_E_SUCCESS if successful else returns GENA_E_BAD_HANDLE | ||||
| ****************************************************************************/ | ||||
| #ifdef INCLUDE_DEVICE_APIS | ||||
| EXTERN_C int genaUnregisterDevice( | ||||
|  	/*! [in] Handle of the root device */ | ||||
| 	UpnpDevice_Handle device_handle); | ||||
| #endif /* INCLUDE_CLIENT_APIS */ | ||||
| EXTERN_C int genaUnregisterDevice(UpnpDevice_Handle device_handle); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Renews a SID. | ||||
| /************************************************************************ | ||||
| * Function : genaRenewSubscription | ||||
| *																	 | ||||
|  * It first validates the SID and client_handle and copies the subscription. | ||||
|  * It sends RENEW (modified SUBSCRIBE) http request to service and processes | ||||
| * Parameters:														 | ||||
| *	IN UpnpClient_Handle client_handle: Client handle | ||||
| *	IN const Upnp_SID in_sid: subscription ID | ||||
| *	INOUT int * TimeOut: requested Duration, if -1, then "infinite". | ||||
| *						in the OUT case: actual Duration granted  | ||||
| *						by Service, -1 for infinite | ||||
| * | ||||
| * Description:														 | ||||
| *	This function renews a SID. It first validates the SID and  | ||||
| *	client_handle and copies the subscription. It sends RENEW  | ||||
| *	(modified SUBSCRIBE) http request to service and processes | ||||
| *	the response. | ||||
| * | ||||
|  * \return UPNP_E_SUCCESS if service response is OK, otherwise the | ||||
|  * 	appropriate error code. | ||||
|  */ | ||||
| * Returns: int | ||||
| *	return UPNP_E_SUCCESS if service response is OK else  | ||||
| *	returns appropriate error | ||||
| ***************************************************************************/ | ||||
| #ifdef INCLUDE_CLIENT_APIS | ||||
| EXTERN_C int genaRenewSubscription( | ||||
| 	/*! [in] Client handle. */ | ||||
| 	UpnpClient_Handle client_handle, | ||||
| 	/*! [in] Subscription ID. */ | ||||
| 	const UpnpString *in_sid, | ||||
| 	/*! [in,out] requested Duration, if -1, then "infinite". In the OUT case: | ||||
| 	 * actual Duration granted by Service, -1 for infinite. */ | ||||
| 	int *TimeOut); | ||||
| #endif /* INCLUDE_CLIENT_APIS */ | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Sends a notification to all the subscribed control points. | ||||
| 	IN UpnpClient_Handle client_handle, | ||||
| 	IN const Upnp_SID in_sid, | ||||
| 	OUT int * TimeOut); | ||||
| #endif | ||||
| /**************************************************************************** | ||||
| *	Function :	genaNotifyAll | ||||
| * | ||||
|  * \return int | ||||
| *	Parameters : | ||||
| *		IN UpnpDevice_Handle device_handle : Device handle | ||||
| *		IN char *UDN :	Device udn | ||||
| *		IN char *servId :	Service ID | ||||
| *	    IN char **VarNames : array of varible names | ||||
| *	    IN char **VarValues :	array of variable values | ||||
| *		IN int var_count	 :	number of variables | ||||
| * | ||||
|  * \note This function is similar to the genaNotifyAllExt. The only difference | ||||
| *	Description : 	This function sends a notification to all the subscribed | ||||
| *	control points | ||||
| * | ||||
| *	Return :	int | ||||
| * | ||||
| *	Note : This function is similar to the genaNotifyAllExt. The only difference | ||||
| *			is it takes event variable array instead of xml document. | ||||
|  */ | ||||
| ****************************************************************************/ | ||||
| #ifdef INCLUDE_DEVICE_APIS | ||||
| EXTERN_C int genaNotifyAll( | ||||
| 	/*! [in] Device handle. */ | ||||
| 	UpnpDevice_Handle device_handle, | ||||
| 	/*! [in] Device udn. */ | ||||
| 	char *UDN, | ||||
| 	/*! [in] Service ID. */ | ||||
| 	char *servId, | ||||
| 	/*! [in] Array of varible names. */ | ||||
| 	char **VarNames, | ||||
| 	/*! [in] Array of variable values. */ | ||||
| 	char **VarValues, | ||||
| 	/*! [in] Number of variables. */ | ||||
| 	int var_count); | ||||
| #endif /* INCLUDE_DEVICE_APIS */ | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Sends a notification to all the subscribed control points. | ||||
| /**************************************************************************** | ||||
| * Function :	genaNotifyAllExt | ||||
| * | ||||
|  * \return int | ||||
| * Parameters : | ||||
| *	IN UpnpDevice_Handle device_handle : Device handle | ||||
| *	IN char *UDN :			Device udn | ||||
| *	IN char *servId :		Service ID | ||||
| *	IN IXML_Document *PropSet :	XML document Event varible property set | ||||
| * | ||||
|  * \note This function is similar to the genaNotifyAll. the only difference | ||||
|  *	is it takes the document instead of event variable array. | ||||
|  */ | ||||
| * Description : This function sends a notification to all the subscribed | ||||
| *	control points | ||||
| * | ||||
| * Return : int | ||||
| * | ||||
| * Note : This function is similar to the genaNotifyAll. the only difference | ||||
| *	is it takes the document instead of event variable array | ||||
| ****************************************************************************/ | ||||
| #ifdef INCLUDE_DEVICE_APIS | ||||
| EXTERN_C int genaNotifyAllExt( | ||||
| 	/*! [in] Device handle. */ | ||||
| 	UpnpDevice_Handle device_handle,  | ||||
| 	/*! [in] Device udn. */ | ||||
| 	char *UDN, | ||||
| 	/*! [in] Service ID. */ | ||||
| 	char *servId, | ||||
| 	/*! [in] XML document Event varible property set. */ | ||||
| 	IXML_Document *PropSet); | ||||
| #endif /* INCLUDE_DEVICE_APIS */ | ||||
| 	IN IXML_Document *PropSet); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Sends the intial state table dump to newly subscribed control point. | ||||
| /**************************************************************************** | ||||
| *	Function :	genaInitNotify | ||||
| * | ||||
|  * \return GENA_E_SUCCESS if successful, otherwise the appropriate error code. | ||||
| *	Parameters : | ||||
| *		   IN UpnpDevice_Handle device_handle :	Device handle | ||||
| *		   IN char *UDN :	Device udn | ||||
| *		   IN char *servId :	Service ID | ||||
| *		   IN char **VarNames :	Array of variable names | ||||
| *		   IN char **VarValues :	Array of variable values | ||||
| *		   IN int var_count :	array size | ||||
| *		   IN Upnp_SID sid :	subscription ID | ||||
| * | ||||
|  * \note  No other event will be sent to this control point before the  | ||||
| *	Description :	This function sends the intial state table dump to  | ||||
| *		newly subscribed control point.  | ||||
| * | ||||
| *	Return :	int | ||||
| *		returns GENA_E_SUCCESS if successful else returns appropriate error | ||||
| *  | ||||
| *	Note : No other event will be sent to this control point before the  | ||||
| *			intial state table dump. | ||||
|  */ | ||||
| ****************************************************************************/ | ||||
| #ifdef INCLUDE_DEVICE_APIS | ||||
| EXTERN_C int genaInitNotify( | ||||
| 	/*! [in] Device handle. */ | ||||
| 	UpnpDevice_Handle device_handle, | ||||
| 	/*! [in] Device udn. */ | ||||
| 	char *UDN, | ||||
| 	/*! [in] Service ID. */ | ||||
| 	char *servId, | ||||
| 	/*! [in] Array of variable names. */ | ||||
| 	char **VarNames, | ||||
| 	/*! [in] Array of variable values. */ | ||||
| 	char **VarValues, | ||||
| 	/*! [in] Array size. */ | ||||
| 	int var_count, | ||||
| 	/*! [in] Subscription ID. */ | ||||
| 	const Upnp_SID sid); | ||||
| #endif /* INCLUDE_DEVICE_APIS */ | ||||
| EXTERN_C int genaInitNotify(IN UpnpDevice_Handle device_handle, | ||||
| 	IN char *UDN, | ||||
| 	IN char *servId, | ||||
| 	IN char **VarNames, | ||||
| 	IN char **VarValues, | ||||
| 	IN int var_count, | ||||
| 	IN Upnp_SID sid); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Similar to the genaInitNofity. The only difference is that it | ||||
|  * takes the xml document for the state table and sends the intial state | ||||
|  * table dump to newly subscribed control point. | ||||
| /**************************************************************************** | ||||
| *	Function :	genaInitNotifyExt | ||||
| * | ||||
|  * \return GENA_E_SUCCESS if successful, otherwise the appropriate error code. | ||||
| *	Parameters : | ||||
| *		   IN UpnpDevice_Handle device_handle :	Device handle | ||||
| *		   IN char *UDN :	Device udn | ||||
| *		   IN char *servId :	Service ID | ||||
| *		   IN IXML_Document *PropSet :	Document of the state table | ||||
| *		   IN Upnp_SID sid :	subscription ID | ||||
| * | ||||
|  * \note No other event will be sent to this control point before the  | ||||
| *	Description :	This function is similar to the genaInitNofity. The only  | ||||
| *	difference is that it takes the xml document for the state table and  | ||||
| *	sends the intial state table dump to newly subscribed control point.  | ||||
| * | ||||
| *	Return :	int | ||||
| *		returns GENA_E_SUCCESS if successful else returns appropriate error | ||||
| *  | ||||
| *	Note : No other event will be sent to this control point before the  | ||||
| *			intial state table dump. | ||||
|  */ | ||||
| ****************************************************************************/ | ||||
| #ifdef INCLUDE_DEVICE_APIS | ||||
| EXTERN_C  int genaInitNotifyExt( | ||||
| 	/*! [in] Device handle. */ | ||||
| 	UpnpDevice_Handle device_handle,  | ||||
| 	/*! [in] Device udn. */ | ||||
| 	char *UDN,  | ||||
| 	/*! [in] Service ID. */ | ||||
| 	char *servId, | ||||
| 	/*! [in] Document of the state table. */ | ||||
| 	IXML_Document *PropSet,  | ||||
| 	/*! [in] subscription ID. */ | ||||
| 	const Upnp_SID sid); | ||||
| #endif /* INCLUDE_DEVICE_APIS */ | ||||
| 	IN UpnpDevice_Handle device_handle,  | ||||
| 	IN char *UDN,  | ||||
| 	IN char *servId, | ||||
| 	IN IXML_Document *PropSet,  | ||||
| 	IN Upnp_SID sid); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /*! | ||||
|  * \brief Sends an error message to the control point in the case of incorrect | ||||
|  * 	GENA requests. | ||||
| /************************************************************************ | ||||
| * Function : error_respond									 | ||||
| *																	 | ||||
|  * \return UPNP_E_SUCCESS if successful, otherwise appropriate error code. | ||||
|  */ | ||||
| void error_respond( | ||||
| 	/*! [in] Structure containing information about the socket. */ | ||||
| 	SOCKINFO *info, | ||||
| 	/*! [in] error code that will be in the GENA response. */ | ||||
| 	int error_code, | ||||
| 	/*! [in] GENA request Packet. */ | ||||
| 	http_message_t* hmsg); | ||||
| * Parameters:														 | ||||
| *	IN SOCKINFO *info: Structure containing information about the socket | ||||
| *	IN int error_code: error code that will be in the GENA response | ||||
| *	IN http_message_t* hmsg: GENA request Packet  | ||||
| * | ||||
| * Description:														 | ||||
| *	This function send an error message to the control point in the case | ||||
| *	incorrect GENA requests. | ||||
| * | ||||
| * Returns: int | ||||
| *	UPNP_E_SUCCESS if successful else appropriate error | ||||
| ***************************************************************************/ | ||||
| void error_respond( IN SOCKINFO *info, IN int error_code, | ||||
| 				    IN http_message_t* hmsg ); | ||||
|  | ||||
|  | ||||
| #endif // GENA | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| #endif /* GENA_H */ | ||||
|  | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user