Compare commits
242 Commits
release-1.
...
release-1.
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
01d7c05fb8 | ||
|
|
952492b44e | ||
|
|
a04c36f47e | ||
|
|
e13ffe3bf8 | ||
|
|
d3d17da6e5 | ||
|
|
e0444b26e6 | ||
|
|
cb07623dde | ||
|
|
c9f3e26f24 | ||
|
|
a3d038c885 | ||
|
|
731512b0e5 | ||
|
|
76eb3f869b | ||
|
|
b116d10f37 | ||
|
|
1a083479a9 | ||
|
|
850e6b4849 | ||
|
|
d48d73720b | ||
|
|
b7f83bb7c6 | ||
|
|
05fb3f8026 | ||
|
|
7178f300bb | ||
|
|
f7a801c3ae | ||
|
|
f299d6597a | ||
|
|
35819a7a44 | ||
|
|
f1c4ffefda | ||
|
|
a692e591de | ||
|
|
ad7272d2b5 | ||
|
|
86bef09787 | ||
|
|
c40d2bc0c9 | ||
|
|
8e39b2af85 | ||
|
|
2eb3e069ba | ||
|
|
db532afb9b | ||
|
|
1b38cc963a | ||
|
|
c67187ac94 | ||
|
|
d45f3c28cf | ||
|
|
06660b6383 | ||
|
|
41412c16ef | ||
|
|
04e5767ea0 | ||
|
|
5944960e17 | ||
|
|
d952ebfb44 | ||
|
|
56b44fee91 | ||
|
|
ff635f92c0 | ||
|
|
19a23dafba | ||
|
|
bd7f83feb5 | ||
|
|
e4678168fa | ||
|
|
a0dc3482dc | ||
|
|
87d1d3c3ec | ||
|
|
194397b6d6 | ||
|
|
b78eaf4e43 | ||
|
|
a54d6e7e83 | ||
|
|
18bf3b1c9c | ||
|
|
bb140000c0 | ||
|
|
7aef73d7eb | ||
|
|
77c73884b8 | ||
|
|
72eecacf56 | ||
|
|
601332f88f | ||
|
|
4605314569 | ||
|
|
e95b4cc53a | ||
|
|
e722d8c375 | ||
|
|
29ee36b1ca | ||
|
|
2fb791c9bb | ||
|
|
d909297aa7 | ||
|
|
9b616a08df | ||
|
|
3ab8d536a0 | ||
|
|
4f34a12a83 | ||
|
|
97a17ff5ad | ||
|
|
9965f02727 | ||
|
|
861a538cea | ||
|
|
c12d33aca6 | ||
|
|
4c3532585d | ||
|
|
71ab707e81 | ||
|
|
cec9d55c4c | ||
|
|
56c26b5199 | ||
|
|
0469388b73 | ||
|
|
268abf72fb | ||
|
|
288ef35cee | ||
|
|
7ef089b09a | ||
|
|
c13b1f7e37 | ||
|
|
3e7bf14488 | ||
|
|
a8bcbe9491 | ||
|
|
1a1570fe0f | ||
|
|
30badb44c7 | ||
|
|
3504b13eae | ||
|
|
d6f1e4112e | ||
|
|
e5887c9036 | ||
|
|
eeab71082f | ||
|
|
f6e88d5b0a | ||
|
|
add51536fc | ||
|
|
40864da7c1 | ||
|
|
5caaf3ad07 | ||
|
|
26c3f87eca | ||
|
|
20372ccef6 | ||
|
|
47c86542bc | ||
|
|
da244683cf | ||
|
|
7301f46269 | ||
|
|
bd203e780e | ||
|
|
69f3fe2330 | ||
|
|
52df3081df | ||
|
|
71e77a5b27 | ||
|
|
a79a149e6a | ||
|
|
0693adc7dc | ||
|
|
076f8e5be6 | ||
|
|
60f9df425b | ||
|
|
fa83dd4a00 | ||
|
|
795de3e077 | ||
|
|
a567576100 | ||
|
|
bc473d5e68 | ||
|
|
2940cbf94a | ||
|
|
d87c966ec5 | ||
|
|
e88d9dbedc | ||
|
|
33fcfeb79f | ||
|
|
a9c24fc7f3 | ||
|
|
537581d8ad | ||
|
|
66ea2ab11d | ||
|
|
4ca0b382ea | ||
|
|
c155d3c68f | ||
|
|
03bd7759cd | ||
|
|
80a65e5f61 | ||
|
|
3b33626e2f | ||
|
|
b35761e893 | ||
|
|
631259dcfc | ||
|
|
98e4f938d6 | ||
|
|
92c93a8010 | ||
|
|
e40e6b49d4 | ||
|
|
cec07d641a | ||
|
|
6c6fb3707f | ||
|
|
92ea719804 | ||
|
|
fed316ff3e | ||
|
|
8eb7d1c1a5 | ||
|
|
2b263b6574 | ||
|
|
e16cb4b225 | ||
|
|
0996d23318 | ||
|
|
11f9a2bafe | ||
|
|
8aca337de7 | ||
|
|
a78a048577 | ||
|
|
7338411c08 | ||
|
|
3a9ae348bc | ||
|
|
840669b253 | ||
|
|
e30e7bd586 | ||
|
|
0d3412bb24 | ||
|
|
e52dafda3b | ||
|
|
bab22c694b | ||
|
|
74665acd57 | ||
|
|
b1629b8ac8 | ||
|
|
32e510b45a | ||
|
|
063d472f80 | ||
|
|
0bbe9f62df | ||
|
|
fdb8b9ef2f | ||
|
|
6c125feea0 | ||
|
|
c4e9757bcf | ||
|
|
639d3a5a03 | ||
|
|
f46683fd0e | ||
|
|
abfa841318 | ||
|
|
3c4ff99cdb | ||
|
|
541679d651 | ||
|
|
cb1188d2bc | ||
|
|
189ce59dbe | ||
|
|
4815e52586 | ||
|
|
9051731a93 | ||
|
|
39fd869db8 | ||
|
|
8997e7fff6 | ||
|
|
7e8d1787c9 | ||
|
|
70d2a7c9e7 | ||
|
|
40e6e4503c | ||
|
|
4b0c8d52b8 | ||
|
|
c05bbec6ec | ||
|
|
d5af7efeb8 | ||
|
|
c8af5ec806 | ||
|
|
1ee8cd9e1a | ||
|
|
a0ebf23785 | ||
|
|
cdf35baa34 | ||
|
|
6d7702d3a7 | ||
|
|
6af93e6ca6 | ||
|
|
2ce88f80f0 | ||
|
|
f67ed1949b | ||
|
|
04d64a893b | ||
|
|
704dca3df1 | ||
|
|
b2a88aa70b | ||
|
|
bb5a80c05b | ||
|
|
7e8e5621a8 | ||
|
|
462505ff62 | ||
|
|
d6418b3e17 | ||
|
|
e8106e4f05 | ||
|
|
3dd133a03c | ||
|
|
79aa205657 | ||
|
|
9a28fcc95b | ||
|
|
bfbd07cb40 | ||
|
|
255d5ee874 | ||
|
|
2c3bce13bd | ||
|
|
bda942b22a | ||
|
|
ed0ebe1588 | ||
|
|
a39f3a63c3 | ||
|
|
6e7a2bb2dc | ||
|
|
c21a67f2d1 | ||
|
|
c449fd1521 | ||
|
|
594c611a33 | ||
|
|
09f2b6ca30 | ||
|
|
9b3a0999a9 | ||
|
|
d8a27bca96 | ||
|
|
6bee05a517 | ||
|
|
2e96edcbc5 | ||
|
|
ef0aa38958 | ||
|
|
86159bc2a6 | ||
|
|
bd8d6cfc8b | ||
|
|
8434e1e936 | ||
|
|
2765bc39c5 | ||
|
|
75695fcaf1 | ||
|
|
5abd1a3b3e | ||
|
|
6c31683e29 | ||
|
|
d92e26779a | ||
|
|
5d6bcabd45 | ||
|
|
7c524df1d9 | ||
|
|
58c694f57d | ||
|
|
da7f3bf1c1 | ||
|
|
8651174861 | ||
|
|
2dd19e5894 | ||
|
|
e6c548f57a | ||
|
|
32cffb5bb5 | ||
|
|
2b30575ca5 | ||
|
|
d32212a6fd | ||
|
|
508b782c79 | ||
|
|
38d5e58e22 | ||
|
|
ee5bd670d4 | ||
|
|
fcb5e7c438 | ||
|
|
243cd41974 | ||
|
|
853cd32cfe | ||
|
|
f384e54fc6 | ||
|
|
9e12768cdb | ||
|
|
4b47e6a51d | ||
|
|
a5fb5edfc9 | ||
|
|
8bd32d330b | ||
|
|
00eb52cc85 | ||
|
|
ff006272b5 | ||
|
|
852c301c5c | ||
|
|
d270499cd8 | ||
|
|
6ac867bbb1 | ||
|
|
9052ca95be | ||
|
|
ef7edf6cf8 | ||
|
|
c65ec8a720 | ||
|
|
2d22e997e1 | ||
|
|
96dc968f18 | ||
|
|
8e846368e0 | ||
|
|
d6671c464f | ||
|
|
699dd3c82e | ||
|
|
9be360bcd1 |
6
.gitignore
vendored
6
.gitignore
vendored
@@ -98,8 +98,8 @@ m4/lt~obsolete.m4
|
|||||||
stamp-h1
|
stamp-h1
|
||||||
upnp/inc/stamp-h2
|
upnp/inc/stamp-h2
|
||||||
upnp/inc/upnpconfig.h
|
upnp/inc/upnpconfig.h
|
||||||
upnp/sample/upnp_tv_combo
|
upnp/sample/tv_combo
|
||||||
upnp/sample/upnp_tv_ctrlpt
|
upnp/sample/tv_ctrlpt
|
||||||
upnp/sample/upnp_tv_device
|
upnp/sample/tv_device
|
||||||
docs/doxygen
|
docs/doxygen
|
||||||
|
|
||||||
|
|||||||
2
Doxyfile
2
Doxyfile
@@ -31,7 +31,7 @@ PROJECT_NAME = libUPnP
|
|||||||
# This could be handy for archiving the generated documentation or
|
# This could be handy for archiving the generated documentation or
|
||||||
# if some version control system is used.
|
# if some version control system is used.
|
||||||
|
|
||||||
PROJECT_NUMBER = 1.6.8
|
PROJECT_NUMBER = 1.6.16
|
||||||
|
|
||||||
# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute)
|
# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute)
|
||||||
# base path where the generated documentation will be put.
|
# base path where the generated documentation will be put.
|
||||||
|
|||||||
11
README
11
README
@@ -227,17 +227,18 @@ To build the samples (note: this is the default behaviour):
|
|||||||
% ./configure --enable-samples
|
% ./configure --enable-samples
|
||||||
% make
|
% make
|
||||||
|
|
||||||
will build the sample device "$(LIBUPNP)/upnp/upnp_tv_device" and
|
will build the sample device "$(LIBUPNP)/upnp/tv_device" and
|
||||||
sample control point "$(LIBUPNP)/upnp/upnp_tv_ctrlpt".
|
sample control point "$(LIBUPNP)/upnp/tv_ctrlpt".
|
||||||
Note : the sample device won't be built if --disable-device has been
|
Note : the sample device won't be built if --disable-device has been
|
||||||
configured, and the sample control point won't be build if --disable-client
|
configured, and the sample control point won't be build if --disable-client
|
||||||
has been configured.
|
has been configured.
|
||||||
|
|
||||||
To run the sample device, you need the "$(LIBUPNP)/upnp/sample/tvdevice/web"
|
To run the sample device, you need to create a tvdevice directory and move
|
||||||
sub-directory. Example :
|
the web directory there, giving: "$(LIBUPNP)/upnp/sample/tvdevice/web".
|
||||||
|
To run the sample invoke from the command line as follows:
|
||||||
|
|
||||||
% cd $(LIBUPNP)/upnp/sample/tvdevice
|
% cd $(LIBUPNP)/upnp/sample/tvdevice
|
||||||
% ../../upnp_tv_device
|
% ../tv_device
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
15
THANKS
15
THANKS
@@ -13,7 +13,8 @@ exempt of errors.
|
|||||||
- Arno Willig
|
- Arno Willig
|
||||||
- Bob Ciora
|
- Bob Ciora
|
||||||
- Carlo Parata
|
- Carlo Parata
|
||||||
- Chandra (inactiveneurons)
|
- Carl Benson
|
||||||
|
- Chandra Penke (inactiveneurons)
|
||||||
- Chaos
|
- Chaos
|
||||||
- Charles Nepveu (cnepveu)
|
- Charles Nepveu (cnepveu)
|
||||||
- Chris Pickel
|
- Chris Pickel
|
||||||
@@ -26,15 +27,18 @@ exempt of errors.
|
|||||||
- Eric Tanguy
|
- Eric Tanguy
|
||||||
- Erwan Velu
|
- Erwan Velu
|
||||||
- Eugene Christensen
|
- Eugene Christensen
|
||||||
- Fabrice Fontaine
|
- Fabrice Fontaine (ffontaine)
|
||||||
- Fredrik Svensson
|
- Fredrik Svensson
|
||||||
- Glen Masgai
|
- Glen Masgai
|
||||||
- Hartmut Holzgraefe - hholzgra
|
- Hartmut Holzgraefe (hholzgra)
|
||||||
|
- Iain Denniston (ectotropic)
|
||||||
- Ingo Hofmann
|
- Ingo Hofmann
|
||||||
|
- Ivan Romanov (ivanromanov)
|
||||||
- Jiri Zouhar
|
- Jiri Zouhar
|
||||||
- John Dennis
|
- John Dennis
|
||||||
- Jonathan Casiot (no_dice)
|
- Jonathan Casiot (no_dice)
|
||||||
- Josh Carroll
|
- Josh Carroll
|
||||||
|
- Juergen Lock
|
||||||
- Keith Brindley
|
- Keith Brindley
|
||||||
- Leuk_He
|
- Leuk_He
|
||||||
- Loigu
|
- Loigu
|
||||||
@@ -44,6 +48,7 @@ exempt of errors.
|
|||||||
- Nektarios K. Papadopoulos (npapadop)
|
- Nektarios K. Papadopoulos (npapadop)
|
||||||
- Nicholas Kraft
|
- Nicholas Kraft
|
||||||
- Nick Leverton (leveret)
|
- Nick Leverton (leveret)
|
||||||
|
- Obata Akio (obache)
|
||||||
- Oskar Liljeblad
|
- Oskar Liljeblad
|
||||||
- Michael (oxygenic)
|
- Michael (oxygenic)
|
||||||
- Paul Vixie
|
- Paul Vixie
|
||||||
@@ -52,8 +57,12 @@ exempt of errors.
|
|||||||
- Robert Gingher (robsbox)
|
- Robert Gingher (robsbox)
|
||||||
- Ronan Menard
|
- Ronan Menard
|
||||||
- Siva Chandran
|
- Siva Chandran
|
||||||
|
- Stefan Sommerfeld (zerocom)
|
||||||
- Stéphane Corthésy
|
- Stéphane Corthésy
|
||||||
- Steve Bresson
|
- Steve Bresson
|
||||||
- Timothy Redaelli
|
- Timothy Redaelli
|
||||||
- Titus Winters
|
- Titus Winters
|
||||||
|
- Tom (tomdev2)
|
||||||
|
- Yoichi Nakayama (yoichi)
|
||||||
|
- zephyrus (zephyrus00jp)
|
||||||
|
|
||||||
|
|||||||
@@ -19,15 +19,9 @@
|
|||||||
/* Define to 1 if fseeko (and presumably ftello) exists and is declared. */
|
/* Define to 1 if fseeko (and presumably ftello) exists and is declared. */
|
||||||
#define HAVE_FSEEKO 1
|
#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 to 1 if you have the <inttypes.h> header file. */
|
||||||
#define HAVE_INTTYPES_H 1
|
#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 to 1 if you have the <limits.h> header file. */
|
||||||
#define HAVE_LIMITS_H 1
|
#define HAVE_LIMITS_H 1
|
||||||
|
|
||||||
@@ -55,6 +49,12 @@
|
|||||||
/* Define to 1 if you have the <string.h> header file. */
|
/* Define to 1 if you have the <string.h> header file. */
|
||||||
#define HAVE_STRING_H 1
|
#define HAVE_STRING_H 1
|
||||||
|
|
||||||
|
/* Defines if strndup is available on your system */
|
||||||
|
#define HAVE_STRNDUP 1
|
||||||
|
|
||||||
|
/* Defines if strnlen is available on your system */
|
||||||
|
#define HAVE_STRNLEN 1
|
||||||
|
|
||||||
/* Define to 1 if you have the <syslog.h> header file. */
|
/* Define to 1 if you have the <syslog.h> header file. */
|
||||||
#define HAVE_SYSLOG_H 1
|
#define HAVE_SYSLOG_H 1
|
||||||
|
|
||||||
@@ -105,13 +105,16 @@
|
|||||||
#define PACKAGE_NAME "libupnp"
|
#define PACKAGE_NAME "libupnp"
|
||||||
|
|
||||||
/* Define to the full name and version of this package. */
|
/* Define to the full name and version of this package. */
|
||||||
#define PACKAGE_STRING "libupnp 1.6.8"
|
#define PACKAGE_STRING "libupnp 1.6.16"
|
||||||
|
|
||||||
/* Define to the one symbol short name of this package. */
|
/* Define to the one symbol short name of this package. */
|
||||||
#define PACKAGE_TARNAME "libupnp"
|
#define PACKAGE_TARNAME "libupnp"
|
||||||
|
|
||||||
|
/* Define to the home page for this package. */
|
||||||
|
#define PACKAGE_URL ""
|
||||||
|
|
||||||
/* Define to the version of this package. */
|
/* Define to the version of this package. */
|
||||||
#define PACKAGE_VERSION "1.6.8"
|
#define PACKAGE_VERSION "1.6.16"
|
||||||
|
|
||||||
/* Define to necessary symbol if this constant uses a non-standard name on
|
/* Define to necessary symbol if this constant uses a non-standard name on
|
||||||
your system. */
|
your system. */
|
||||||
@@ -120,6 +123,9 @@
|
|||||||
/* Define to 1 if you have the ANSI C header files. */
|
/* Define to 1 if you have the ANSI C header files. */
|
||||||
#define STDC_HEADERS 1
|
#define STDC_HEADERS 1
|
||||||
|
|
||||||
|
/* see upnpconfig.h */
|
||||||
|
#define UPNP_ENABLE_BLOCKING_TCP_CONNECTIONS 1
|
||||||
|
|
||||||
/* see upnpconfig.h */
|
/* see upnpconfig.h */
|
||||||
/* #undef UPNP_ENABLE_IPV6 */
|
/* #undef UPNP_ENABLE_IPV6 */
|
||||||
|
|
||||||
@@ -135,6 +141,18 @@
|
|||||||
/* see upnpconfig.h */
|
/* see upnpconfig.h */
|
||||||
#define UPNP_HAVE_DEVICE 1
|
#define UPNP_HAVE_DEVICE 1
|
||||||
|
|
||||||
|
/* see upnpconfig.h */
|
||||||
|
#define UPNP_HAVE_GENA 1
|
||||||
|
|
||||||
|
/* see upnpconfig.h */
|
||||||
|
#define UPNP_HAVE_OPTSSDP 1
|
||||||
|
|
||||||
|
/* see upnpconfig.h */
|
||||||
|
#define UPNP_HAVE_SOAP 1
|
||||||
|
|
||||||
|
/* see upnpconfig.h */
|
||||||
|
#define UPNP_HAVE_SSDP 1
|
||||||
|
|
||||||
/* see upnpconfig.h */
|
/* see upnpconfig.h */
|
||||||
#define UPNP_HAVE_TOOLS 1
|
#define UPNP_HAVE_TOOLS 1
|
||||||
|
|
||||||
@@ -151,19 +169,19 @@
|
|||||||
#define UPNP_VERSION_MINOR 6
|
#define UPNP_VERSION_MINOR 6
|
||||||
|
|
||||||
/* see upnpconfig.h */
|
/* see upnpconfig.h */
|
||||||
#define UPNP_VERSION_PATCH 8
|
#define UPNP_VERSION_PATCH 16
|
||||||
|
|
||||||
/* see upnpconfig.h */
|
/* see upnpconfig.h */
|
||||||
#define UPNP_VERSION_STRING "1.6.8"
|
#define UPNP_VERSION_STRING "1.6.16"
|
||||||
|
|
||||||
/* Version number of package */
|
/* Version number of package */
|
||||||
#define VERSION "1.6.8"
|
#define VERSION "1.6.16"
|
||||||
|
|
||||||
/* File Offset size */
|
/* File Offset size */
|
||||||
#define _FILE_OFFSET_BITS 64
|
#define _FILE_OFFSET_BITS 64
|
||||||
|
|
||||||
/* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */
|
/* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */
|
||||||
/* #undef _LARGEFILE_SOURCE */
|
#define _LARGEFILE_SOURCE 1
|
||||||
|
|
||||||
/* Large files support */
|
/* Large files support */
|
||||||
#define _LARGE_FILE_SOURCE /**/
|
#define _LARGE_FILE_SOURCE /**/
|
||||||
|
|||||||
@@ -40,7 +40,7 @@
|
|||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
/** The library version (string) e.g. "1.3.0" */
|
/** The library version (string) e.g. "1.3.0" */
|
||||||
#define UPNP_VERSION_STRING "1.6.8"
|
#define UPNP_VERSION_STRING "1.6.16"
|
||||||
|
|
||||||
/** Major version of the library */
|
/** Major version of the library */
|
||||||
#define UPNP_VERSION_MAJOR 1
|
#define UPNP_VERSION_MAJOR 1
|
||||||
@@ -49,7 +49,7 @@
|
|||||||
#define UPNP_VERSION_MINOR 6
|
#define UPNP_VERSION_MINOR 6
|
||||||
|
|
||||||
/** Patch version of the library */
|
/** Patch version of the library */
|
||||||
#define UPNP_VERSION_PATCH 8
|
#define UPNP_VERSION_PATCH 16
|
||||||
|
|
||||||
/** The library version (numeric) e.g. 10300 means version 1.3.0 */
|
/** The library version (numeric) e.g. 10300 means version 1.3.0 */
|
||||||
#define UPNP_VERSION \
|
#define UPNP_VERSION \
|
||||||
@@ -57,6 +57,19 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Large file support
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
/** 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
|
||||||
|
|
||||||
|
/** Large files support */
|
||||||
|
#define _LARGE_FILE_SOURCE /**/
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* Library optional features
|
* Library optional features
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
@@ -87,6 +100,26 @@
|
|||||||
#define UPNP_HAVE_WEBSERVER 1
|
#define UPNP_HAVE_WEBSERVER 1
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with the SSDP part enabled
|
||||||
|
* (i.e. configure --enable-ssdp) */
|
||||||
|
#define UPNP_HAVE_SSDP 1
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with optional SSDP headers
|
||||||
|
* support (i.e. configure --enable-optssdp) */
|
||||||
|
#define UPNP_HAVE_OPTSSDP 1
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with the SOAP part enabled
|
||||||
|
* (i.e. configure --enable-soap) */
|
||||||
|
#define UPNP_HAVE_SOAP 1
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with the GENA part enabled
|
||||||
|
* (i.e. configure --enable-gena) */
|
||||||
|
#define UPNP_HAVE_GENA 1
|
||||||
|
|
||||||
|
|
||||||
/** Defined to 1 if the library has been compiled with helper API
|
/** Defined to 1 if the library has been compiled with helper API
|
||||||
* (i.e. configure --enable-tools) : <upnp/upnptools.h> file is available */
|
* (i.e. configure --enable-tools) : <upnp/upnptools.h> file is available */
|
||||||
#define UPNP_HAVE_TOOLS 1
|
#define UPNP_HAVE_TOOLS 1
|
||||||
|
|||||||
@@ -103,8 +103,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc"
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
PreprocessorDefinitions="WIN32;IXML_INLINE="
|
PreprocessorDefinitions="WIN32;DEBUG;IXML_INLINE="
|
||||||
RuntimeLibrary="0"
|
RuntimeLibrary="0"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
Detect64BitPortabilityProblems="true"
|
Detect64BitPortabilityProblems="true"
|
||||||
|
|||||||
@@ -50,7 +50,7 @@
|
|||||||
Optimization="2"
|
Optimization="2"
|
||||||
InlineFunctionExpansion="1"
|
InlineFunctionExpansion="1"
|
||||||
AdditionalIncludeDirectories="..\..\pthreads\include;..\..\ixml\src\inc;..\..\ixml\inc;..\..\threadutil\inc;..\..\upnp\inc;..\..\upnp\src\inc;..\inc;..\msvc"
|
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"
|
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS"
|
||||||
StringPooling="true"
|
StringPooling="true"
|
||||||
RuntimeLibrary="0"
|
RuntimeLibrary="0"
|
||||||
EnableFunctionLevelLinking="true"
|
EnableFunctionLevelLinking="true"
|
||||||
@@ -80,8 +80,8 @@
|
|||||||
OutputFile="$(OutDir)\libupnp.dll"
|
OutputFile="$(OutDir)\libupnp.dll"
|
||||||
LinkIncremental="1"
|
LinkIncremental="1"
|
||||||
SuppressStartupBanner="true"
|
SuppressStartupBanner="true"
|
||||||
ProgramDatabaseFile=".\Release/libupnp.pdb"
|
ProgramDatabaseFile="$(OutDir)\libupnp.pdb"
|
||||||
ImportLibrary=".\Release/libupnp.lib"
|
ImportLibrary="$(OutDir)\libupnp.lib"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -96,7 +96,7 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCBscMakeTool"
|
Name="VCBscMakeTool"
|
||||||
SuppressStartupBanner="true"
|
SuppressStartupBanner="true"
|
||||||
OutputFile=".\Release/libupnp.bsc"
|
OutputFile="$(OutDir)\libupnp.bsc"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCFxCopTool"
|
Name="VCFxCopTool"
|
||||||
@@ -218,14 +218,6 @@
|
|||||||
Name="sources"
|
Name="sources"
|
||||||
Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
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
|
<File
|
||||||
RelativePath="..\..\ixml\src\attr.c"
|
RelativePath="..\..\ixml\src\attr.c"
|
||||||
>
|
>
|
||||||
@@ -234,10 +226,6 @@
|
|||||||
RelativePath="..\..\upnp\src\genlib\client_table\client_table.c"
|
RelativePath="..\..\upnp\src\genlib\client_table\client_table.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\Discovery.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\ixml\src\document.c"
|
RelativePath="..\..\ixml\src\document.c"
|
||||||
>
|
>
|
||||||
@@ -246,18 +234,6 @@
|
|||||||
RelativePath="..\..\ixml\src\element.c"
|
RelativePath="..\..\ixml\src\element.c"
|
||||||
>
|
>
|
||||||
</File>
|
</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
|
<File
|
||||||
RelativePath="..\..\threadutil\src\FreeList.c"
|
RelativePath="..\..\threadutil\src\FreeList.c"
|
||||||
>
|
>
|
||||||
@@ -358,10 +334,6 @@
|
|||||||
RelativePath="..\..\upnp\src\ssdp\ssdp_device.c"
|
RelativePath="..\..\upnp\src\ssdp\ssdp_device.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\ssdp\ssdp_ResultData.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\ssdp\ssdp_server.c"
|
RelativePath="..\..\upnp\src\ssdp\ssdp_server.c"
|
||||||
>
|
>
|
||||||
@@ -370,22 +342,10 @@
|
|||||||
RelativePath="..\..\upnp\src\genlib\net\http\statcodes.c"
|
RelativePath="..\..\upnp\src\genlib\net\http\statcodes.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\StateVarComplete.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\StateVarRequest.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\genlib\util\strintmap.c"
|
RelativePath="..\..\upnp\src\genlib\util\strintmap.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\SubscriptionRequest.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\uuid\sysdep.c"
|
RelativePath="..\..\upnp\src\uuid\sysdep.c"
|
||||||
>
|
>
|
||||||
@@ -447,14 +407,6 @@
|
|||||||
Name="headers"
|
Name="headers"
|
||||||
Filter="h;hpp;hxx;hm;inl"
|
Filter="h;hpp;hxx;hm;inl"
|
||||||
>
|
>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\inc\ActionComplete.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\inc\actionrequest.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\client_table.h"
|
RelativePath="..\..\upnp\src\inc\client_table.h"
|
||||||
>
|
>
|
||||||
@@ -463,22 +415,6 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\config.h"
|
RelativePath="..\..\upnp\src\inc\config.h"
|
||||||
>
|
>
|
||||||
</File>
|
</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
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\gena.h"
|
RelativePath="..\..\upnp\src\inc\gena.h"
|
||||||
>
|
>
|
||||||
@@ -563,14 +499,6 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\statcodes.h"
|
RelativePath="..\..\upnp\src\inc\statcodes.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\inc\StateVarComplete.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\inc\statevarrequest.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\statuscodes.h"
|
RelativePath="..\..\upnp\src\inc\statuscodes.h"
|
||||||
>
|
>
|
||||||
@@ -579,10 +507,6 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\strintmap.h"
|
RelativePath="..\..\upnp\src\inc\strintmap.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\inc\SubscriptionRequest.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\sysdep.h"
|
RelativePath="..\..\upnp\src\inc\sysdep.h"
|
||||||
>
|
>
|
||||||
|
|||||||
@@ -40,7 +40,7 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\ixml\inc;..\..\pthreads\include"
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\ixml\inc;..\..\pthreads\include"
|
||||||
PreprocessorDefinitions="WIN32;DEBUG"
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
@@ -80,9 +80,9 @@
|
|||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
ConfigurationType="1"
|
ConfigurationType="4"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
>
|
>
|
||||||
@@ -103,6 +103,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\ixml\inc;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="WIN32;UPNP_USE_MSVCPP"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
Detect64BitPortabilityProblems="true"
|
Detect64BitPortabilityProblems="true"
|
||||||
@@ -118,18 +120,11 @@
|
|||||||
Name="VCPreLinkEventTool"
|
Name="VCPreLinkEventTool"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLibrarianTool"
|
||||||
GenerateDebugInformation="true"
|
|
||||||
OptimizeReferences="2"
|
|
||||||
EnableCOMDATFolding="2"
|
|
||||||
TargetMachine="1"
|
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCALinkTool"
|
Name="VCALinkTool"
|
||||||
/>
|
/>
|
||||||
<Tool
|
|
||||||
Name="VCManifestTool"
|
|
||||||
/>
|
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCXDCMakeTool"
|
Name="VCXDCMakeTool"
|
||||||
/>
|
/>
|
||||||
@@ -139,12 +134,6 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCFxCopTool"
|
Name="VCFxCopTool"
|
||||||
/>
|
/>
|
||||||
<Tool
|
|
||||||
Name="VCAppVerifierTool"
|
|
||||||
/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"
|
|
||||||
/>
|
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
/>
|
/>
|
||||||
|
|||||||
@@ -40,7 +40,7 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvcombo;..\..\upnp\sample\tvcombo\linux"
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvcombo;..\..\upnp\sample\tvcombo\linux"
|
||||||
PreprocessorDefinitions="WIN32;DEBUG"
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
@@ -91,8 +91,8 @@
|
|||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
@@ -114,6 +114,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvcombo;..\..\upnp\sample\tvcombo\linux"
|
||||||
|
PreprocessorDefinitions="WIN32;UPNP_USE_MSVCPP"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
Detect64BitPortabilityProblems="true"
|
Detect64BitPortabilityProblems="true"
|
||||||
@@ -130,6 +132,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
AdditionalLibraryDirectories=""$(OutDir)";"out.vc8.$(ConfigurationName)\ixml";"out.vc8.$(ConfigurationName)\threadutil";"out.vc8.$(ConfigurationName)\libupnp""
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
OptimizeReferences="2"
|
OptimizeReferences="2"
|
||||||
EnableCOMDATFolding="2"
|
EnableCOMDATFolding="2"
|
||||||
@@ -174,15 +178,15 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\linux\upnp_tv_combo_main.c"
|
RelativePath="..\..\upnp\sample\linux\tv_combo_main.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\upnp_tv_ctrlpt.c"
|
RelativePath="..\..\upnp\sample\common\tv_ctrlpt.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\upnp_tv_device.c"
|
RelativePath="..\..\upnp\sample\common\tv_device.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
|
|||||||
@@ -40,7 +40,7 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt;..\..\upnp\sample\tvctrlpt\linux"
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt;..\..\upnp\sample\tvctrlpt\linux"
|
||||||
PreprocessorDefinitions="WIN32;DEBUG"
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
@@ -91,8 +91,8 @@
|
|||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
@@ -114,6 +114,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt;..\..\upnp\sample\tvctrlpt\linux"
|
||||||
|
PreprocessorDefinitions="WIN32;UPNP_USE_MSVCPP"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
Detect64BitPortabilityProblems="true"
|
Detect64BitPortabilityProblems="true"
|
||||||
@@ -130,6 +132,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
AdditionalLibraryDirectories=""$(OutDir)";"out.vc8.$(ConfigurationName)\ixml";"out.vc8.$(ConfigurationName)\threadutil";"out.vc8.$(ConfigurationName)\libupnp""
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
OptimizeReferences="2"
|
OptimizeReferences="2"
|
||||||
EnableCOMDATFolding="2"
|
EnableCOMDATFolding="2"
|
||||||
@@ -174,11 +178,11 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvctrlpt\upnp_tv_ctrlpt.c"
|
RelativePath="..\..\upnp\sample\common\tv_ctrlpt.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvctrlpt\linux\upnp_tv_ctrlpt_main.c"
|
RelativePath="..\..\upnp\sample\linux\tv_ctrlpt_main.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
|
|||||||
@@ -40,7 +40,7 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
||||||
PreprocessorDefinitions="WIN32;DEBUG"
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
@@ -91,8 +91,8 @@
|
|||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory=".\out.vc8.$(ConfigurationName)\$(ProjectName)"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
@@ -114,6 +114,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
||||||
|
PreprocessorDefinitions="WIN32;UPNP_USE_MSVCPP"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
Detect64BitPortabilityProblems="true"
|
Detect64BitPortabilityProblems="true"
|
||||||
@@ -130,6 +132,8 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
AdditionalLibraryDirectories=""$(OutDir)";"out.vc8.$(ConfigurationName)\ixml";"out.vc8.$(ConfigurationName)\threadutil";"out.vc8.$(ConfigurationName)\libupnp""
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
OptimizeReferences="2"
|
OptimizeReferences="2"
|
||||||
EnableCOMDATFolding="2"
|
EnableCOMDATFolding="2"
|
||||||
@@ -174,11 +178,11 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvdevice\upnp_tv_device.c"
|
RelativePath="..\..\upnp\sample\common\tv_device.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvdevice\linux\upnp_tv_device_main.c"
|
RelativePath="..\..\upnp\sample\linux\tv_device_main.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
|
|||||||
@@ -11,16 +11,20 @@
|
|||||||
<Platform
|
<Platform
|
||||||
Name="Win32"
|
Name="Win32"
|
||||||
/>
|
/>
|
||||||
|
<Platform
|
||||||
|
Name="x64"
|
||||||
|
/>
|
||||||
</Platforms>
|
</Platforms>
|
||||||
<ToolFiles>
|
<ToolFiles>
|
||||||
</ToolFiles>
|
</ToolFiles>
|
||||||
<Configurations>
|
<Configurations>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Debug|Win32"
|
Name="Debug|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="4"
|
ConfigurationType="4"
|
||||||
CharacterSet="0"
|
CharacterSet="0"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
>
|
>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCPreBuildEventTool"
|
Name="VCPreBuildEventTool"
|
||||||
@@ -41,12 +45,16 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS"
|
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="4"
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -59,6 +67,75 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLibrarianTool"
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
|
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCALinkTool"
|
Name="VCALinkTool"
|
||||||
@@ -78,11 +155,12 @@
|
|||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="4"
|
ConfigurationType="4"
|
||||||
CharacterSet="0"
|
CharacterSet="0"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
>
|
>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCPreBuildEventTool"
|
Name="VCPreBuildEventTool"
|
||||||
@@ -102,13 +180,19 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="2"
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
EnableIntrinsicFunctions="true"
|
EnableIntrinsicFunctions="true"
|
||||||
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc"
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\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;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
EnableFunctionLevelLinking="true"
|
EnableFunctionLevelLinking="true"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="3"
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -121,6 +205,354 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLibrarianTool"
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
|
PreprocessorDefinitions="DEBUG;WIN32;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
|
PreprocessorDefinitions="DEBUG;WIN32;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
EnableManagedIncrementalBuild="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\ixml\inc;..\..\ixml\src\inc;..\inc;..\..\upnp\inc"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCALinkTool"
|
Name="VCALinkTool"
|
||||||
|
|||||||
@@ -28,34 +28,112 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "tvcombo", "tvcombo.vcproj",
|
|||||||
EndProject
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug Lib|Win32 = Debug Lib|Win32
|
||||||
|
Debug Lib|x64 = Debug Lib|x64
|
||||||
Debug|Win32 = Debug|Win32
|
Debug|Win32 = Debug|Win32
|
||||||
|
Debug|x64 = Debug|x64
|
||||||
|
Release Lib|Win32 = Release Lib|Win32
|
||||||
|
Release Lib|x64 = Release Lib|x64
|
||||||
Release|Win32 = Release|Win32
|
Release|Win32 = Release|Win32
|
||||||
|
Release|x64 = Release|x64
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug Lib|Win32.ActiveCfg = Debug Lib|Win32
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug Lib|Win32.Build.0 = Debug Lib|Win32
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug Lib|x64.ActiveCfg = Debug Lib|x64
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug Lib|x64.Build.0 = Debug Lib|x64
|
||||||
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug|Win32.ActiveCfg = Debug|Win32
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||||
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug|Win32.Build.0 = Debug|Win32
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug|Win32.Build.0 = Debug|Win32
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Debug|x64.Build.0 = Debug|x64
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release Lib|Win32.ActiveCfg = Release Lib|Win32
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release Lib|Win32.Build.0 = Release Lib|Win32
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release Lib|x64.ActiveCfg = Release Lib|x64
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release Lib|x64.Build.0 = Release Lib|x64
|
||||||
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release|Win32.ActiveCfg = Release|Win32
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release|Win32.ActiveCfg = Release|Win32
|
||||||
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release|Win32.Build.0 = Release|Win32
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release|Win32.Build.0 = Release|Win32
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release|x64.ActiveCfg = Release|x64
|
||||||
|
{6227F51A-1498-4C4A-B213-F6FDED605125}.Release|x64.Build.0 = Release|x64
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug Lib|Win32.ActiveCfg = Debug Lib|Win32
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug Lib|Win32.Build.0 = Debug Lib|Win32
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug Lib|x64.ActiveCfg = Debug Lib|x64
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug Lib|x64.Build.0 = Debug Lib|x64
|
||||||
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug|Win32.ActiveCfg = Debug|Win32
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||||
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug|Win32.Build.0 = Debug|Win32
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug|Win32.Build.0 = Debug|Win32
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Debug|x64.Build.0 = Debug|x64
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release Lib|Win32.ActiveCfg = Release Lib|Win32
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release Lib|Win32.Build.0 = Release Lib|Win32
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release Lib|x64.ActiveCfg = Release Lib|x64
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release Lib|x64.Build.0 = Release Lib|x64
|
||||||
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release|Win32.ActiveCfg = Release|Win32
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release|Win32.ActiveCfg = Release|Win32
|
||||||
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release|Win32.Build.0 = Release|Win32
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release|Win32.Build.0 = Release|Win32
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release|x64.ActiveCfg = Release|x64
|
||||||
|
{9C2C266D-35A3-465F-A297-0E21D54E5C89}.Release|x64.Build.0 = Release|x64
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug Lib|Win32.ActiveCfg = Debug Lib|Win32
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug Lib|Win32.Build.0 = Debug Lib|Win32
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug Lib|x64.ActiveCfg = Debug Lib|x64
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug Lib|x64.Build.0 = Debug Lib|x64
|
||||||
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug|Win32.ActiveCfg = Debug|Win32
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||||
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug|Win32.Build.0 = Debug|Win32
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug|Win32.Build.0 = Debug|Win32
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Debug|x64.Build.0 = Debug|x64
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release Lib|Win32.ActiveCfg = Release Lib|Win32
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release Lib|Win32.Build.0 = Release Lib|Win32
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release Lib|x64.ActiveCfg = Release Lib|x64
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release Lib|x64.Build.0 = Release Lib|x64
|
||||||
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release|Win32.ActiveCfg = Release|Win32
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release|Win32.ActiveCfg = Release|Win32
|
||||||
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release|Win32.Build.0 = Release|Win32
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release|Win32.Build.0 = Release|Win32
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release|x64.ActiveCfg = Release|x64
|
||||||
|
{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}.Release|x64.Build.0 = Release|x64
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug Lib|Win32.ActiveCfg = Debug Lib|Win32
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug Lib|Win32.Build.0 = Debug Lib|Win32
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug Lib|x64.ActiveCfg = Debug Lib|x64
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug Lib|x64.Build.0 = Debug Lib|x64
|
||||||
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug|Win32.ActiveCfg = Debug|Win32
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||||
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug|Win32.Build.0 = Debug|Win32
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug|Win32.Build.0 = Debug|Win32
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Debug|x64.Build.0 = Debug|x64
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release Lib|Win32.ActiveCfg = Release Lib|Win32
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release Lib|Win32.Build.0 = Release Lib|Win32
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release Lib|x64.ActiveCfg = Release Lib|x64
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release Lib|x64.Build.0 = Release Lib|x64
|
||||||
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release|Win32.ActiveCfg = Release|Win32
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release|Win32.ActiveCfg = Release|Win32
|
||||||
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release|Win32.Build.0 = Release|Win32
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release|Win32.Build.0 = Release|Win32
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release|x64.ActiveCfg = Release|x64
|
||||||
|
{8FB56F1C-E617-4B79-96AE-1FA499A3A9B5}.Release|x64.Build.0 = Release|x64
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug Lib|Win32.ActiveCfg = Debug Lib|Win32
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug Lib|Win32.Build.0 = Debug Lib|Win32
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug Lib|x64.ActiveCfg = Debug Lib|x64
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug Lib|x64.Build.0 = Debug Lib|x64
|
||||||
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug|Win32.ActiveCfg = Debug|Win32
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||||
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug|Win32.Build.0 = Debug|Win32
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug|Win32.Build.0 = Debug|Win32
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Debug|x64.Build.0 = Debug|x64
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release Lib|Win32.ActiveCfg = Release Lib|Win32
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release Lib|Win32.Build.0 = Release Lib|Win32
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release Lib|x64.ActiveCfg = Release Lib|x64
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release Lib|x64.Build.0 = Release Lib|x64
|
||||||
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release|Win32.ActiveCfg = Release|Win32
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release|Win32.ActiveCfg = Release|Win32
|
||||||
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release|Win32.Build.0 = Release|Win32
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release|Win32.Build.0 = Release|Win32
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release|x64.ActiveCfg = Release|x64
|
||||||
|
{7FB5F4A6-74F9-471D-B358-BAA0AC1CCA0A}.Release|x64.Build.0 = Release|x64
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug Lib|Win32.ActiveCfg = Debug Lib|Win32
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug Lib|Win32.Build.0 = Debug Lib|Win32
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug Lib|x64.ActiveCfg = Debug Lib|x64
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug Lib|x64.Build.0 = Debug Lib|x64
|
||||||
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug|Win32.ActiveCfg = Debug|Win32
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||||
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug|Win32.Build.0 = Debug|Win32
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug|Win32.Build.0 = Debug|Win32
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Debug|x64.Build.0 = Debug|x64
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release Lib|Win32.ActiveCfg = Release Lib|Win32
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release Lib|Win32.Build.0 = Release Lib|Win32
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release Lib|x64.ActiveCfg = Release Lib|x64
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release Lib|x64.Build.0 = Release Lib|x64
|
||||||
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release|Win32.ActiveCfg = Release|Win32
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release|Win32.ActiveCfg = Release|Win32
|
||||||
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release|Win32.Build.0 = Release|Win32
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release|Win32.Build.0 = Release|Win32
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release|x64.ActiveCfg = Release|x64
|
||||||
|
{6365804B-22C6-4D5E-91F3-0C052EB55B4F}.Release|x64.Build.0 = Release|x64
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
<?xml version="1.0" encoding="Windows-1252"?>
|
||||||
<VisualStudioProject
|
<VisualStudioProject
|
||||||
ProjectType="Visual C++"
|
ProjectType="Visual C++"
|
||||||
Version="9,00"
|
Version="9.00"
|
||||||
Name="libupnp"
|
Name="libupnp"
|
||||||
ProjectGUID="{6227F51A-1498-4C4A-B213-F6FDED605125}"
|
ProjectGUID="{6227F51A-1498-4C4A-B213-F6FDED605125}"
|
||||||
RootNamespace="libupnp"
|
RootNamespace="libupnp"
|
||||||
@@ -11,19 +11,22 @@
|
|||||||
<Platform
|
<Platform
|
||||||
Name="Win32"
|
Name="Win32"
|
||||||
/>
|
/>
|
||||||
|
<Platform
|
||||||
|
Name="x64"
|
||||||
|
/>
|
||||||
</Platforms>
|
</Platforms>
|
||||||
<ToolFiles>
|
<ToolFiles>
|
||||||
</ToolFiles>
|
</ToolFiles>
|
||||||
<Configurations>
|
<Configurations>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="2"
|
ConfigurationType="2"
|
||||||
InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops"
|
|
||||||
UseOfMFC="0"
|
UseOfMFC="0"
|
||||||
ATLMinimizesCRunTimeLibraryUsage="false"
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
CharacterSet="0"
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
>
|
>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCPreBuildEventTool"
|
Name="VCPreBuildEventTool"
|
||||||
@@ -49,19 +52,23 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="2"
|
Optimization="2"
|
||||||
InlineFunctionExpansion="1"
|
InlineFunctionExpansion="0"
|
||||||
AdditionalIncludeDirectories="..\..\pthreads\include,..\ixml\src\inc,..\ixml\inc,..\threadutil\inc,..\upnp\inc,..\upnp\src\inc,.\inc"
|
EnableIntrinsicFunctions="true"
|
||||||
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS"
|
WholeProgramOptimization="true"
|
||||||
|
AdditionalIncludeDirectories="..\inc;..\msvc;..\..\upnp\inc;..\..\upnp\src\inc;..\..\ixml\inc;..\..\ixml\src\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
StringPooling="true"
|
StringPooling="true"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
EnableFunctionLevelLinking="true"
|
EnableFunctionLevelLinking="true"
|
||||||
PrecompiledHeaderFile=".\Release/libupnp.pch"
|
PrecompiledHeaderFile=""
|
||||||
AssemblerListingLocation=".\Release/"
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
ObjectFile=".\Release/"
|
ObjectFile="$(IntDir)\"
|
||||||
ProgramDataBaseFileName=".\Release/"
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
BrowseInformation="1"
|
BrowseInformation="0"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
SuppressStartupBanner="true"
|
SuppressStartupBanner="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -76,14 +83,20 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
AdditionalDependencies="..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib iphlpapi.lib"
|
AdditionalDependencies="pthreadvc2.lib ws2_32.lib iphlpapi.lib ixml.lib threadutil.lib"
|
||||||
OutputFile=".\Release/libupnp.dll"
|
OutputFile="$(OutDir)\$(ProjectName).dll"
|
||||||
LinkIncremental="1"
|
LinkIncremental="1"
|
||||||
SuppressStartupBanner="true"
|
SuppressStartupBanner="true"
|
||||||
ProgramDatabaseFile=".\Release/libupnp.pdb"
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="2"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
LinkTimeCodeGeneration="1"
|
||||||
RandomizedBaseAddress="1"
|
RandomizedBaseAddress="1"
|
||||||
DataExecutionPrevention="0"
|
DataExecutionPrevention="0"
|
||||||
ImportLibrary=".\Release/libupnp.lib"
|
ImportLibrary="$(TargetDir)$(TargetName).lib"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -111,11 +124,115 @@
|
|||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Debug|Win32"
|
Name="Release|x64"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="2"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
MkTypLibCompatible="true"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
TypeLibraryName=".\Release/libupnp.tlb"
|
||||||
|
HeaderFileName=""
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
WholeProgramOptimization="true"
|
||||||
|
AdditionalIncludeDirectories=""$(SolutionDir)\..\inc";"$(SolutionDir)\..\msvc";"$(SolutionDir)\..\..\upnp\inc";"$(SolutionDir)\..\..\upnp\src\inc";"$(SolutionDir)\..\..\ixml\inc";"$(SolutionDir)\..\..\ixml\src\inc";"$(SolutionDir)\..\..\threadutil\inc";"$(SolutionDir)\..\..\pthreads";"$(SolutionDir)\..\..\pthreads\include""
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ObjectFile="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
BrowseInformation="0"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
Culture="1031"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadvc2.lib ws2_32.lib iphlpapi.lib ixml.lib threadutil.lib"
|
||||||
|
OutputFile="$(OutDir)\$(ProjectName).dll"
|
||||||
|
LinkIncremental="1"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="2"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
LinkTimeCodeGeneration="1"
|
||||||
|
RandomizedBaseAddress="1"
|
||||||
|
DataExecutionPrevention="0"
|
||||||
|
ImportLibrary="$(TargetDir)$(TargetName).lib"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
OutputFile=".\Release/libupnp.bsc"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="2"
|
ConfigurationType="2"
|
||||||
InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops"
|
|
||||||
UseOfMFC="0"
|
UseOfMFC="0"
|
||||||
ATLMinimizesCRunTimeLibraryUsage="false"
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
CharacterSet="0"
|
CharacterSet="0"
|
||||||
@@ -144,19 +261,20 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\pthreads\include;..\..\ixml\src\inc;..\..\ixml\inc;..\..\threadutil\inc;..\..\upnp\inc;..\..\upnp\src\inc;..\inc;..\msvc"
|
AdditionalIncludeDirectories="..\inc;..\msvc;..\..\upnp\inc;..\..\upnp\src\inc;..\..\ixml\inc;..\..\ixml\src\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS"
|
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
PrecompiledHeaderFile="$(OutDir)\libupnp.pch"
|
PrecompiledHeaderFile=""
|
||||||
AssemblerListingLocation="$(OutDir)\"
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
ObjectFile="$(OutDir)\"
|
ObjectFile="$(IntDir)\"
|
||||||
ProgramDataBaseFileName="$(OutDir)\"
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
BrowseInformation="1"
|
BrowseInformation="0"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
SuppressStartupBanner="true"
|
SuppressStartupBanner="true"
|
||||||
DebugInformationFormat="4"
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -171,15 +289,17 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
AdditionalDependencies="..\..\pthreads\lib\pthreadvc2.lib ws2_32.lib iphlpapi.lib $(TargetDir)..\ixml\ixml.lib"
|
AdditionalDependencies="pthreadvc2.lib ws2_32.lib iphlpapi.lib ixml.lib threadutil.lib"
|
||||||
OutputFile="$(OutDir)\libupnp.dll"
|
OutputFile="$(OutDir)\$(ProjectName).dll"
|
||||||
LinkIncremental="2"
|
LinkIncremental="1"
|
||||||
SuppressStartupBanner="true"
|
SuppressStartupBanner="true"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
ProgramDatabaseFile="$(OutDir)\libupnp.pdb"
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="2"
|
||||||
RandomizedBaseAddress="1"
|
RandomizedBaseAddress="1"
|
||||||
DataExecutionPrevention="0"
|
DataExecutionPrevention="0"
|
||||||
ImportLibrary="$(OutDir)\libupnp.lib"
|
ImportLibrary="$(TargetDir)$(TargetName).lib"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -206,6 +326,436 @@
|
|||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="2"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
MkTypLibCompatible="true"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
TypeLibraryName=".\Debug/libupnp.tlb"
|
||||||
|
HeaderFileName=""
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories=""$(SolutionDir)\..\inc";"$(SolutionDir)\..\msvc";"$(SolutionDir)\..\..\upnp\inc";"$(SolutionDir)\..\..\upnp\src\inc";"$(SolutionDir)\..\..\ixml\inc";"$(SolutionDir)\..\..\ixml\src\inc";"$(SolutionDir)\..\..\threadutil\inc";"$(SolutionDir)\..\..\pthreads";"$(SolutionDir)\..\..\pthreads\include""
|
||||||
|
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ObjectFile="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
BrowseInformation="0"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
Culture="1031"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadvc2.lib ws2_32.lib iphlpapi.lib ixml.lib threadutil.lib"
|
||||||
|
OutputFile="$(OutDir)\$(ProjectName).dll"
|
||||||
|
LinkIncremental="1"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="2"
|
||||||
|
RandomizedBaseAddress="1"
|
||||||
|
DataExecutionPrevention="0"
|
||||||
|
ImportLibrary="$(TargetDir)$(TargetName).lib"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
OutputFile="$(OutDir)\libupnp.bsc"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
MkTypLibCompatible="true"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
TargetEnvironment="1"
|
||||||
|
TypeLibraryName=".\Debug/libupnp.tlb"
|
||||||
|
HeaderFileName=""
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\inc;..\msvc;..\..\upnp\inc;..\..\upnp\src\inc;..\..\ixml\inc;..\..\ixml\src\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ObjectFile="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
BrowseInformation="0"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
Culture="1031"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
OutputFile="$(OutDir)\libupnp.bsc"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
MkTypLibCompatible="true"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
TypeLibraryName=".\Debug/libupnp.tlb"
|
||||||
|
HeaderFileName=""
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories=""$(SolutionDir)\..\inc";"$(SolutionDir)\..\msvc";"$(SolutionDir)\..\..\upnp\inc";"$(SolutionDir)\..\..\upnp\src\inc";"$(SolutionDir)\..\..\ixml\inc";"$(SolutionDir)\..\..\ixml\src\inc";"$(SolutionDir)\..\..\threadutil\inc";"$(SolutionDir)\..\..\pthreads";"$(SolutionDir)\..\..\pthreads\include""
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ObjectFile="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
BrowseInformation="0"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
Culture="1031"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
OutputFile="$(OutDir)\libupnp.bsc"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
MkTypLibCompatible="true"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
TargetEnvironment="1"
|
||||||
|
TypeLibraryName=".\Release/libupnp.tlb"
|
||||||
|
HeaderFileName=""
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
WholeProgramOptimization="true"
|
||||||
|
AdditionalIncludeDirectories="..\inc;..\msvc;..\..\upnp\inc;..\..\upnp\src\inc;..\..\ixml\inc;..\..\ixml\src\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ObjectFile="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
BrowseInformation="0"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
Culture="1031"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
OutputFile=".\Release/libupnp.bsc"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="false"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
MkTypLibCompatible="true"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
TypeLibraryName=".\Release/libupnp.tlb"
|
||||||
|
HeaderFileName=""
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
WholeProgramOptimization="true"
|
||||||
|
AdditionalIncludeDirectories=""$(SolutionDir)\..\inc";"$(SolutionDir)\..\msvc";"$(SolutionDir)\..\..\upnp\inc";"$(SolutionDir)\..\..\upnp\src\inc";"$(SolutionDir)\..\..\ixml\inc";"$(SolutionDir)\..\..\ixml\src\inc";"$(SolutionDir)\..\..\threadutil\inc";"$(SolutionDir)\..\..\pthreads";"$(SolutionDir)\..\..\pthreads\include""
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
PrecompiledHeaderFile=""
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ObjectFile="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
BrowseInformation="0"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
Culture="1031"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
SuppressStartupBanner="true"
|
||||||
|
OutputFile=".\Release/libupnp.bsc"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
</Configurations>
|
</Configurations>
|
||||||
<References>
|
<References>
|
||||||
</References>
|
</References>
|
||||||
@@ -214,14 +764,6 @@
|
|||||||
Name="sources"
|
Name="sources"
|
||||||
Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
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
|
<File
|
||||||
RelativePath="..\..\ixml\src\attr.c"
|
RelativePath="..\..\ixml\src\attr.c"
|
||||||
>
|
>
|
||||||
@@ -230,10 +772,6 @@
|
|||||||
RelativePath="..\..\upnp\src\genlib\client_table\client_table.c"
|
RelativePath="..\..\upnp\src\genlib\client_table\client_table.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\Discovery.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\ixml\src\document.c"
|
RelativePath="..\..\ixml\src\document.c"
|
||||||
>
|
>
|
||||||
@@ -242,18 +780,6 @@
|
|||||||
RelativePath="..\..\ixml\src\element.c"
|
RelativePath="..\..\ixml\src\element.c"
|
||||||
>
|
>
|
||||||
</File>
|
</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
|
<File
|
||||||
RelativePath="..\..\threadutil\src\FreeList.c"
|
RelativePath="..\..\threadutil\src\FreeList.c"
|
||||||
>
|
>
|
||||||
@@ -278,10 +804,6 @@
|
|||||||
RelativePath="..\..\upnp\src\genlib\net\http\httpreadwrite.c"
|
RelativePath="..\..\upnp\src\genlib\net\http\httpreadwrite.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\inet_pton.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\ixml\src\ixml.c"
|
RelativePath="..\..\ixml\src\ixml.c"
|
||||||
>
|
>
|
||||||
@@ -354,10 +876,6 @@
|
|||||||
RelativePath="..\..\upnp\src\ssdp\ssdp_device.c"
|
RelativePath="..\..\upnp\src\ssdp\ssdp_device.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\ssdp\ssdp_ResultData.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\ssdp\ssdp_server.c"
|
RelativePath="..\..\upnp\src\ssdp\ssdp_server.c"
|
||||||
>
|
>
|
||||||
@@ -366,22 +884,10 @@
|
|||||||
RelativePath="..\..\upnp\src\genlib\net\http\statcodes.c"
|
RelativePath="..\..\upnp\src\genlib\net\http\statcodes.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\StateVarComplete.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\StateVarRequest.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\genlib\util\strintmap.c"
|
RelativePath="..\..\upnp\src\genlib\util\strintmap.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\api\SubscriptionRequest.c"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\uuid\sysdep.c"
|
RelativePath="..\..\upnp\src\uuid\sysdep.c"
|
||||||
>
|
>
|
||||||
@@ -444,11 +950,11 @@
|
|||||||
Filter="h;hpp;hxx;hm;inl"
|
Filter="h;hpp;hxx;hm;inl"
|
||||||
>
|
>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\inc\ActionComplete.h"
|
RelativePath="..\inc\autoconfig.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\inc\ActionRequest.h"
|
RelativePath="..\..\upnp\inc\Callback.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
@@ -459,22 +965,6 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\config.h"
|
RelativePath="..\..\upnp\src\inc\config.h"
|
||||||
>
|
>
|
||||||
</File>
|
</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
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\gena.h"
|
RelativePath="..\..\upnp\src\inc\gena.h"
|
||||||
>
|
>
|
||||||
@@ -495,10 +985,6 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\gmtdate.h"
|
RelativePath="..\..\upnp\src\inc\gmtdate.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\inc\http_client.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\httpparser.h"
|
RelativePath="..\..\upnp\src\inc\httpparser.h"
|
||||||
>
|
>
|
||||||
@@ -508,7 +994,7 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\inet_pton.h"
|
RelativePath="..\msvc\inttypes.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
@@ -559,28 +1045,32 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\statcodes.h"
|
RelativePath="..\..\upnp\src\inc\statcodes.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\inc\StateVarComplete.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\inc\StateVarRequest.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\statuscodes.h"
|
RelativePath="..\..\upnp\src\inc\statuscodes.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\msvc\stdint.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\strintmap.h"
|
RelativePath="..\..\upnp\src\inc\strintmap.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\inc\SubscriptionRequest.h"
|
RelativePath="..\..\upnp\src\inc\sysdep.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\sysdep.h"
|
RelativePath="..\..\upnp\inc\TemplateInclude.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\inc\TemplateSource.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\inc\TemplateUndef.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
@@ -599,10 +1089,30 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\upnpapi.h"
|
RelativePath="..\..\upnp\src\inc\upnpapi.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\inc\upnpconfig.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\inc\upnpdebug.h"
|
RelativePath="..\..\upnp\inc\upnpdebug.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\inc\UpnpGlobal.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\inc\UpnpInet.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\inc\UpnpIntTypes.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\inc\UpnpStdInt.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\inc\UpnpString.h"
|
RelativePath="..\..\upnp\inc\UpnpString.h"
|
||||||
>
|
>
|
||||||
@@ -611,6 +1121,14 @@
|
|||||||
RelativePath="..\..\upnp\inc\upnptools.h"
|
RelativePath="..\..\upnp\inc\upnptools.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\inc\UpnpUniStd.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\src\inc\upnputil.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\uri.h"
|
RelativePath="..\..\upnp\src\inc\uri.h"
|
||||||
>
|
>
|
||||||
@@ -619,27 +1137,19 @@
|
|||||||
RelativePath="..\..\upnp\src\inc\urlconfig.h"
|
RelativePath="..\..\upnp\src\inc\urlconfig.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\inc\util.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\..\upnp\src\inc\utilall.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\uuid.h"
|
RelativePath="..\..\upnp\src\inc\uuid.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\upnp\src\inc\VirtualDir.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\src\inc\webserver.h"
|
RelativePath="..\..\upnp\src\inc\webserver.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
<File
|
|
||||||
RelativePath="..\..\..\..\libupnp_win32.patch"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
</Files>
|
</Files>
|
||||||
<Globals>
|
<Globals>
|
||||||
</Globals>
|
</Globals>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
<?xml version="1.0" encoding="Windows-1252"?>
|
||||||
<VisualStudioProject
|
<VisualStudioProject
|
||||||
ProjectType="Visual C++"
|
ProjectType="Visual C++"
|
||||||
Version="9,00"
|
Version="9.00"
|
||||||
Name="threadutil"
|
Name="threadutil"
|
||||||
ProjectGUID="{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}"
|
ProjectGUID="{1D3EEF7A-D248-48C0-B6B5-ECA229FE4B3D}"
|
||||||
RootNamespace="threadutil"
|
RootNamespace="threadutil"
|
||||||
@@ -11,14 +11,17 @@
|
|||||||
<Platform
|
<Platform
|
||||||
Name="Win32"
|
Name="Win32"
|
||||||
/>
|
/>
|
||||||
|
<Platform
|
||||||
|
Name="x64"
|
||||||
|
/>
|
||||||
</Platforms>
|
</Platforms>
|
||||||
<ToolFiles>
|
<ToolFiles>
|
||||||
</ToolFiles>
|
</ToolFiles>
|
||||||
<Configurations>
|
<Configurations>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Debug|Win32"
|
Name="Debug|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="4"
|
ConfigurationType="4"
|
||||||
CharacterSet="0"
|
CharacterSet="0"
|
||||||
>
|
>
|
||||||
@@ -40,13 +43,15 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\ixml\inc;..\..\pthreads\include"
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_SECURE_NO_WARNINGS"
|
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="4"
|
DebugInformationFormat="3"
|
||||||
CompileAs="1"
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -60,8 +65,73 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLibrarianTool"
|
Name="VCLibrarianTool"
|
||||||
AdditionalDependencies="pthreadVC2.lib"
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
AdditionalLibraryDirectories="..\..\pthreads\lib"
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="DEBUG;WIN32;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCALinkTool"
|
Name="VCALinkTool"
|
||||||
@@ -81,9 +151,9 @@
|
|||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="1"
|
ConfigurationType="4"
|
||||||
CharacterSet="0"
|
CharacterSet="0"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
>
|
>
|
||||||
@@ -105,11 +175,15 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="2"
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
EnableIntrinsicFunctions="true"
|
EnableIntrinsicFunctions="true"
|
||||||
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\ixml\inc;..\..\pthreads\include"
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
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;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
EnableFunctionLevelLinking="true"
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="3"
|
DebugInformationFormat="3"
|
||||||
CompileAs="1"
|
CompileAs="1"
|
||||||
@@ -124,18 +198,12 @@
|
|||||||
Name="VCPreLinkEventTool"
|
Name="VCPreLinkEventTool"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLibrarianTool"
|
||||||
GenerateDebugInformation="true"
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
OptimizeReferences="2"
|
|
||||||
EnableCOMDATFolding="2"
|
|
||||||
TargetMachine="1"
|
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCALinkTool"
|
Name="VCALinkTool"
|
||||||
/>
|
/>
|
||||||
<Tool
|
|
||||||
Name="VCManifestTool"
|
|
||||||
/>
|
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCXDCMakeTool"
|
Name="VCXDCMakeTool"
|
||||||
/>
|
/>
|
||||||
@@ -146,7 +214,341 @@
|
|||||||
Name="VCFxCopTool"
|
Name="VCFxCopTool"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCAppVerifierTool"
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBUPNP_EXPORTS;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="DEBUG;WIN32;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="DEBUG;WIN32;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\lib\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="4"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="0"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\threadutil\inc;..\..\upnp\inc;..\..\pthreads;..\..\pthreads\include"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
@@ -204,12 +606,6 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</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>
|
</Files>
|
||||||
<Globals>
|
<Globals>
|
||||||
</Globals>
|
</Globals>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
<?xml version="1.0" encoding="Windows-1252"?>
|
||||||
<VisualStudioProject
|
<VisualStudioProject
|
||||||
ProjectType="Visual C++"
|
ProjectType="Visual C++"
|
||||||
Version="9,00"
|
Version="9.00"
|
||||||
Name="tvcombo"
|
Name="tvcombo"
|
||||||
ProjectGUID="{6365804B-22C6-4D5E-91F3-0C052EB55B4F}"
|
ProjectGUID="{6365804B-22C6-4D5E-91F3-0C052EB55B4F}"
|
||||||
RootNamespace="tvcombo"
|
RootNamespace="tvcombo"
|
||||||
@@ -11,16 +11,19 @@
|
|||||||
<Platform
|
<Platform
|
||||||
Name="Win32"
|
Name="Win32"
|
||||||
/>
|
/>
|
||||||
|
<Platform
|
||||||
|
Name="x64"
|
||||||
|
/>
|
||||||
</Platforms>
|
</Platforms>
|
||||||
<ToolFiles>
|
<ToolFiles>
|
||||||
</ToolFiles>
|
</ToolFiles>
|
||||||
<Configurations>
|
<Configurations>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Debug|Win32"
|
Name="Debug|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="0"
|
||||||
>
|
>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCPreBuildEventTool"
|
Name="VCPreBuildEventTool"
|
||||||
@@ -40,13 +43,15 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
PreprocessorDefinitions="DEBUG;WIN32"
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="4"
|
DebugInformationFormat="3"
|
||||||
CompileAs="1"
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -60,9 +65,12 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib $(TargetDir)..\libupnp\libupnp.lib"
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
AdditionalLibraryDirectories=""$(TargetDir)..\ixml";"$(TargetDir)..\threadutil";"$(TargetDir)..\libupnp""
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -88,11 +96,89 @@
|
|||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Debug|x64"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="0"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
>
|
>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -114,8 +200,13 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="2"
|
Optimization="2"
|
||||||
EnableIntrinsicFunctions="true"
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;RELEASE;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
EnableFunctionLevelLinking="true"
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="3"
|
DebugInformationFormat="3"
|
||||||
CompileAs="1"
|
CompileAs="1"
|
||||||
@@ -131,7 +222,12 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
OptimizeReferences="2"
|
OptimizeReferences="2"
|
||||||
EnableCOMDATFolding="2"
|
EnableCOMDATFolding="2"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
@@ -158,6 +254,406 @@
|
|||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;RELEASE;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="0"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="0"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
</Configurations>
|
</Configurations>
|
||||||
<References>
|
<References>
|
||||||
</References>
|
</References>
|
||||||
@@ -172,24 +668,18 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\linux\upnp_tv_combo_main.c"
|
RelativePath="..\..\upnp\sample\linux\tv_combo_main.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\upnp_tv_ctrlpt.c"
|
RelativePath="..\..\upnp\sample\common\tv_ctrlpt.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\upnp_tv_device.c"
|
RelativePath="..\..\upnp\sample\common\tv_device.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</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>
|
|
||||||
<Filter
|
<Filter
|
||||||
Name="Header Files"
|
Name="Header Files"
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
||||||
@@ -200,11 +690,11 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\upnp_tv_ctrlpt.h"
|
RelativePath="..\..\upnp\sample\common\tv_ctrlpt.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvcombo\upnp_tv_device.h"
|
RelativePath="..\..\upnp\sample\common\tv_device.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
|
|||||||
@@ -11,14 +11,17 @@
|
|||||||
<Platform
|
<Platform
|
||||||
Name="Win32"
|
Name="Win32"
|
||||||
/>
|
/>
|
||||||
|
<Platform
|
||||||
|
Name="x64"
|
||||||
|
/>
|
||||||
</Platforms>
|
</Platforms>
|
||||||
<ToolFiles>
|
<ToolFiles>
|
||||||
</ToolFiles>
|
</ToolFiles>
|
||||||
<Configurations>
|
<Configurations>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Debug|Win32"
|
Name="Debug|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
>
|
>
|
||||||
@@ -40,13 +43,16 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\ixml\inc;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt\linux;..\..\upnp\sample\tvctrlpt"
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\ixml\inc;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt\linux;..\..\upnp\sample\tvctrlpt"
|
||||||
PreprocessorDefinitions="WIN32;DEBUG"
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="4"
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -59,9 +65,12 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
AdditionalLibraryDirectories=""$(OutDir)";".\out.vc9.$(ConfigurationName)\ixml";".\out.vc9.$(ConfigurationName)\threadutil";".\out.vc9.$(ConfigurationName)\libupnp""
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -86,10 +95,88 @@
|
|||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\ixml\inc;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt\linux;..\..\upnp\sample\tvctrlpt"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
@@ -113,10 +200,16 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="2"
|
Optimization="2"
|
||||||
EnableIntrinsicFunctions="true"
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;RELEASE;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
EnableFunctionLevelLinking="true"
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="3"
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -129,7 +222,12 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
OptimizeReferences="2"
|
OptimizeReferences="2"
|
||||||
EnableCOMDATFolding="2"
|
EnableCOMDATFolding="2"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
@@ -156,6 +254,406 @@
|
|||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;RELEASE;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\ixml\inc;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt\linux;..\..\upnp\sample\tvctrlpt"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\ixml\inc;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvctrlpt\linux;..\..\upnp\sample\tvctrlpt"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
</Configurations>
|
</Configurations>
|
||||||
<References>
|
<References>
|
||||||
</References>
|
</References>
|
||||||
@@ -170,11 +668,11 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvctrlpt\upnp_tv_ctrlpt.c"
|
RelativePath="..\..\upnp\sample\common\tv_ctrlpt.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvctrlpt\linux\upnp_tv_ctrlpt_main.c"
|
RelativePath="..\..\upnp\sample\linux\tv_ctrlpt_main.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
@@ -188,16 +686,10 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvctrlpt\upnp_tv_ctrlpt.h"
|
RelativePath="..\..\upnp\sample\common\tv_ctrlpt.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</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>
|
</Files>
|
||||||
<Globals>
|
<Globals>
|
||||||
</Globals>
|
</Globals>
|
||||||
|
|||||||
@@ -11,14 +11,17 @@
|
|||||||
<Platform
|
<Platform
|
||||||
Name="Win32"
|
Name="Win32"
|
||||||
/>
|
/>
|
||||||
|
<Platform
|
||||||
|
Name="x64"
|
||||||
|
/>
|
||||||
</Platforms>
|
</Platforms>
|
||||||
<ToolFiles>
|
<ToolFiles>
|
||||||
</ToolFiles>
|
</ToolFiles>
|
||||||
<Configurations>
|
<Configurations>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Debug|Win32"
|
Name="Debug|Win32"
|
||||||
OutputDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory=".\out.vc9.$(ConfigurationName)\$(ProjectName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
>
|
>
|
||||||
@@ -40,13 +43,16 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
||||||
PreprocessorDefinitions="WIN32;DEBUG"
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
MinimalRebuild="true"
|
MinimalRebuild="true"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="3"
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="4"
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -59,9 +65,12 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
AdditionalDependencies="..\..\pthreads\lib\pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
AdditionalLibraryDirectories=""$(OutDir)";".\out.vc9.$(ConfigurationName)\ixml";".\out.vc9.$(ConfigurationName)\threadutil";".\out.vc9.$(ConfigurationName)\libupnp""
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
@@ -86,10 +95,88 @@
|
|||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
<Configuration
|
<Configuration
|
||||||
Name="Release|Win32"
|
Name="Release|Win32"
|
||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
ConfigurationType="1"
|
ConfigurationType="1"
|
||||||
CharacterSet="2"
|
CharacterSet="2"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
@@ -113,10 +200,16 @@
|
|||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="2"
|
Optimization="2"
|
||||||
EnableIntrinsicFunctions="true"
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;RELEASE;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
RuntimeLibrary="2"
|
RuntimeLibrary="2"
|
||||||
EnableFunctionLevelLinking="true"
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
DebugInformationFormat="3"
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCManagedResourceCompilerTool"
|
Name="VCManagedResourceCompilerTool"
|
||||||
@@ -129,7 +222,12 @@
|
|||||||
/>
|
/>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCLinkerTool"
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
GenerateDebugInformation="true"
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
OptimizeReferences="2"
|
OptimizeReferences="2"
|
||||||
EnableCOMDATFolding="2"
|
EnableCOMDATFolding="2"
|
||||||
TargetMachine="1"
|
TargetMachine="1"
|
||||||
@@ -156,6 +254,406 @@
|
|||||||
Name="VCPostBuildEventTool"
|
Name="VCPostBuildEventTool"
|
||||||
/>
|
/>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;RELEASE;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib"
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\ixml\inc;..\..\upnp\sample\common;..\inc;..\..\threadutil\inc;..\..\pthreads;..\..\pthreads\include;..\..\upnp\sample\tvdevice;..\..\upnp\sample\tvdevice\linux"
|
||||||
|
PreprocessorDefinitions="WIN32;DEBUG;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release Lib|x64"
|
||||||
|
OutputDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\bin\"
|
||||||
|
IntermediateDirectory="$(SolutionDir)\out.vc9.$(PlatformName)\$(ConfigurationName)\tmp\"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="2"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
TargetEnvironment="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
EnableIntrinsicFunctions="true"
|
||||||
|
AdditionalIncludeDirectories="..\..\upnp\inc;..\..\upnp\sample\common;..\..\upnp\sample;..\..\ixml\inc;..\..\pthreads;..\..\pthreads\include;..\inc;..\..\threadutil\inc;..\..\upnp\sample\tvcombo"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;RELEASE;_WINDOWS;PTW32_STATIC_LIB;UPNP_STATIC_LIB;UPNP_USE_MSVCPP;_CRT_NONSTDC_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_CRT_SECURE_NO_WARNINGS;_CRT_SECURE_NO_DEPRECATE;_SECURE_SCL;_SCL_SECURE_NO_WARNINGS;_SCL_SECURE_NO_DEPRECATE;_AFX_SECURE_NO_WARNINGS;_AFX_SECURE_NO_DEPRECATE;_SECURE_ATL;_ATL_NO_COM_SUPPORT;_ATL_SECURE_NO_WARNINGS;_ATL_SECURE_NO_DEPRECATE"
|
||||||
|
StringPooling="true"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="true"
|
||||||
|
AssemblerListingLocation="$(IntDir)\"
|
||||||
|
ProgramDataBaseFileName="$(IntDir)\$(ProjectName).pdb"
|
||||||
|
WarningLevel="3"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
AdditionalDependencies="pthreadVC2.lib ixml.lib threadutil.lib libupnp.lib ws2_32.lib iphlpapi.lib "
|
||||||
|
LinkIncremental="1"
|
||||||
|
AdditionalLibraryDirectories="..\..\pthreads\;..\..\pthreads\lib;$(OutDir)\..\lib;$(OutDir)\..\bin"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
ProgramDatabaseFile="$(OutDir)\$(ProjectName).pdb"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="17"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
</Configurations>
|
</Configurations>
|
||||||
<References>
|
<References>
|
||||||
</References>
|
</References>
|
||||||
@@ -170,11 +668,11 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvdevice\upnp_tv_device.c"
|
RelativePath="..\..\upnp\sample\common\tv_device.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvdevice\linux\upnp_tv_device_main.c"
|
RelativePath="..\..\upnp\sample\linux\tv_device_main.c"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
@@ -188,16 +686,10 @@
|
|||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\upnp\sample\tvdevice\upnp_tv_device.h"
|
RelativePath="..\..\upnp\sample\common\tv_device.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</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>
|
</Files>
|
||||||
<Globals>
|
<Globals>
|
||||||
</Globals>
|
</Globals>
|
||||||
|
|||||||
166
configure.ac
166
configure.ac
@@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
AC_PREREQ(2.60)
|
AC_PREREQ(2.60)
|
||||||
|
|
||||||
AC_INIT([libupnp], [1.6.8], [mroberto@users.sourceforge.net])
|
AC_INIT([libupnp], [1.6.16], [mroberto@users.sourceforge.net])
|
||||||
dnl ############################################################################
|
dnl ############################################################################
|
||||||
dnl # *Independently* of the above libupnp package version, the libtool version
|
dnl # *Independently* of the above libupnp package version, the libtool version
|
||||||
dnl # of the 3 libraries need to be updated whenever there is a change released:
|
dnl # of the 3 libraries need to be updated whenever there is a change released:
|
||||||
@@ -175,14 +175,134 @@ dnl # - Code has changed in threadutil
|
|||||||
dnl # revision: 0 -> 1
|
dnl # revision: 0 -> 1
|
||||||
dnl # - Code has changed in upnp
|
dnl # - Code has changed in upnp
|
||||||
dnl # revision: 0 -> 1
|
dnl # revision: 0 -> 1
|
||||||
|
dnl #
|
||||||
dnl #AC_SUBST([LT_VERSION_IXML], [2:5:0])
|
dnl #AC_SUBST([LT_VERSION_IXML], [2:5:0])
|
||||||
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [5:1:2])
|
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [5:1:2])
|
||||||
dnl #AC_SUBST([LT_VERSION_UPNP], [4:1:0])
|
dnl #AC_SUBST([LT_VERSION_UPNP], [4:1:0])
|
||||||
dnl #
|
dnl #
|
||||||
dnl ############################################################################
|
dnl ############################################################################
|
||||||
AC_SUBST([LT_VERSION_IXML], [2:5:0])
|
dnl # Release 1.6.9:
|
||||||
AC_SUBST([LT_VERSION_THREADUTIL], [5:1:2])
|
dnl # "current:revision:age"
|
||||||
AC_SUBST([LT_VERSION_UPNP], [4:1:0])
|
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 in ixml
|
||||||
|
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 ############################################################################
|
||||||
|
dnl # Release 1.6.11:
|
||||||
|
dnl # "current:revision:age"
|
||||||
|
dnl #
|
||||||
|
dnl # - Code has changed in threadutil
|
||||||
|
dnl # revision: 3 -> 4
|
||||||
|
dnl # - Code has changed in upnp
|
||||||
|
dnl # revision: 3 -> 4
|
||||||
|
dnl # - interface has changed in upnp
|
||||||
|
dnl # current: 5 -> 6
|
||||||
|
dnl # revision: 4 -> 0
|
||||||
|
dnl #
|
||||||
|
dnl #AC_SUBST([LT_VERSION_IXML], [2:6:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [5:4:2])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_UPNP], [6:0:0])
|
||||||
|
dnl #
|
||||||
|
dnl ############################################################################
|
||||||
|
dnl # Release 1.6.12:
|
||||||
|
dnl # "current:revision:age"
|
||||||
|
dnl #
|
||||||
|
dnl # - interface added in threadutil
|
||||||
|
dnl # current: 5 -> 6
|
||||||
|
dnl # revision: 4 - > 0
|
||||||
|
dnl # age: 2 -> 3
|
||||||
|
dnl # - interfaces removed in threadutil
|
||||||
|
dnl # age: 3 -> 0
|
||||||
|
dnl #
|
||||||
|
dnl #AC_SUBST([LT_VERSION_IXML], [2:6:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [6:0:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_UPNP], [6:0:0])
|
||||||
|
dnl #
|
||||||
|
dnl ############################################################################
|
||||||
|
dnl # Release 1.6.13:
|
||||||
|
dnl # "current:revision:age"
|
||||||
|
dnl #
|
||||||
|
dnl # - Code has changed in upnp
|
||||||
|
dnl # revision: 0 -> 1
|
||||||
|
dnl # - interface added in upnp
|
||||||
|
dnl # current: 6 -> 7
|
||||||
|
dnl # revision: 1 - > 0
|
||||||
|
dnl # age: 0 -> 1
|
||||||
|
dnl #
|
||||||
|
dnl #AC_SUBST([LT_VERSION_IXML], [2:6:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [6:0:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_UPNP], [7:0:1])
|
||||||
|
dnl #
|
||||||
|
dnl ############################################################################
|
||||||
|
dnl # Release 1.6.14:
|
||||||
|
dnl # "current:revision:age"
|
||||||
|
dnl #
|
||||||
|
dnl # - Code has changed in upnp
|
||||||
|
dnl # revision: 0 -> 1
|
||||||
|
dnl # - interface added in upnp
|
||||||
|
dnl # current: 7 -> 8
|
||||||
|
dnl # revision: 1 - > 0
|
||||||
|
dnl # age: 1 -> 2
|
||||||
|
dnl #
|
||||||
|
dnl #AC_SUBST([LT_VERSION_IXML], [2:6:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [6:0:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_UPNP], [8:0:2])
|
||||||
|
dnl #
|
||||||
|
dnl ############################################################################
|
||||||
|
dnl # Release 1.6.15:
|
||||||
|
dnl # "current:revision:age"
|
||||||
|
dnl #
|
||||||
|
dnl # - Code has changed in upnp
|
||||||
|
dnl # revision: 0 -> 1
|
||||||
|
dnl #
|
||||||
|
dnl #AC_SUBST([LT_VERSION_IXML], [2:6:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [6:0:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_UPNP], [8:1:2])
|
||||||
|
dnl #
|
||||||
|
dnl ############################################################################
|
||||||
|
dnl # Release 1.6.16:
|
||||||
|
dnl # "current:revision:age"
|
||||||
|
dnl #
|
||||||
|
dnl # - Code has changed in ixml
|
||||||
|
dnl # revision: 6 -> 7
|
||||||
|
dnl # - Code has changed in threadutil
|
||||||
|
dnl # revision: 0 -> 1
|
||||||
|
dnl # - Code has changed in upnp
|
||||||
|
dnl # revision: 1 -> 2
|
||||||
|
dnl # - interface changed/added/removed in upnp
|
||||||
|
dnl # current++(9); revision = 0
|
||||||
|
dnl # - interface added in upnp
|
||||||
|
dnl # age++(3)
|
||||||
|
dnl #
|
||||||
|
dnl #AC_SUBST([LT_VERSION_IXML], [2:7:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_THREADUTIL], [6:1:0])
|
||||||
|
dnl #AC_SUBST([LT_VERSION_UPNP], [9:0:3])
|
||||||
|
dnl #
|
||||||
|
dnl ############################################################################
|
||||||
|
AC_SUBST([LT_VERSION_IXML], [2:7:0])
|
||||||
|
AC_SUBST([LT_VERSION_THREADUTIL], [6:1:0])
|
||||||
|
AC_SUBST([LT_VERSION_UPNP], [9:0:3])
|
||||||
dnl ############################################################################
|
dnl ############################################################################
|
||||||
dnl # Repeating the algorithm to place it closer to the modificatin place:
|
dnl # Repeating the algorithm to place it closer to the modificatin place:
|
||||||
dnl # - library code modified: revision++
|
dnl # - library code modified: revision++
|
||||||
@@ -270,6 +390,29 @@ if test "x$enable_webserver" = xyes ; then
|
|||||||
AC_DEFINE(UPNP_HAVE_WEBSERVER, 1, [see upnpconfig.h])
|
AC_DEFINE(UPNP_HAVE_WEBSERVER, 1, [see upnpconfig.h])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
RT_BOOL_ARG_ENABLE([ssdp], [yes], [SSDP part])
|
||||||
|
if test "x$enable_ssdp" = xyes ; then
|
||||||
|
AC_DEFINE(UPNP_HAVE_SSDP, 1, [see upnpconfig.h])
|
||||||
|
fi
|
||||||
|
|
||||||
|
RT_BOOL_ARG_ENABLE([optssdp], [yes], [optionnal SSDP headers support)])
|
||||||
|
if test "x$enable_optssdp" = xyes ; then
|
||||||
|
AC_DEFINE(UPNP_HAVE_OPTSSDP, 1, [see upnpconfig.h])
|
||||||
|
enable_uuid=yes
|
||||||
|
fi
|
||||||
|
|
||||||
|
RT_BOOL_ARG_ENABLE([soap], [yes], [SOAP part])
|
||||||
|
if test "x$enable_soap" = xyes ; then
|
||||||
|
AC_DEFINE(UPNP_HAVE_SOAP, 1, [see upnpconfig.h])
|
||||||
|
fi
|
||||||
|
|
||||||
|
RT_BOOL_ARG_ENABLE([gena], [yes], [GENA part])
|
||||||
|
if test "x$enable_gena" = xyes ; then
|
||||||
|
AC_DEFINE(UPNP_HAVE_GENA, 1, [see upnpconfig.h])
|
||||||
|
enable_uuid=yes
|
||||||
|
fi
|
||||||
|
|
||||||
|
AM_CONDITIONAL(ENABLE_UUID, test x"$enable_uuid" = xyes)
|
||||||
|
|
||||||
RT_BOOL_ARG_ENABLE([tools], [yes], [helper APIs in upnptools.h])
|
RT_BOOL_ARG_ENABLE([tools], [yes], [helper APIs in upnptools.h])
|
||||||
if test "x$enable_tools" = xyes ; then
|
if test "x$enable_tools" = xyes ; then
|
||||||
@@ -286,6 +429,11 @@ if test "x$enable_notification_reordering" = xyes ; then
|
|||||||
AC_DEFINE(UPNP_ENABLE_NOTIFICATION_REORDERING, 1, [see upnpconfig.h])
|
AC_DEFINE(UPNP_ENABLE_NOTIFICATION_REORDERING, 1, [see upnpconfig.h])
|
||||||
fi
|
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])
|
RT_BOOL_ARG_ENABLE([samples], [yes], [compilation of upnp/sample/ code])
|
||||||
|
|
||||||
@@ -346,10 +494,11 @@ freebsd*)
|
|||||||
*)
|
*)
|
||||||
echo "Using non-specific system compiler settings"
|
echo "Using non-specific system compiler settings"
|
||||||
if test x"$enable_debug" = xyes; then
|
if test x"$enable_debug" = xyes; then
|
||||||
# AC_PROG_CC already sets CFLAGS to "-g -O2" by default
|
# AC_PROG_CC already sets CFLAGS to "-g -O2" by default,
|
||||||
|
# but only if CFLAGS was not previously set.
|
||||||
#:
|
#:
|
||||||
# Use -O0 in debug so that variables do not get optimized out
|
# Use -O0 in debug so that variables do not get optimized out
|
||||||
AX_CFLAGS_GCC_OPTION([-O0])
|
AX_CFLAGS_GCC_OPTION([-O0, -g])
|
||||||
else
|
else
|
||||||
# add optimise for size
|
# add optimise for size
|
||||||
AX_CFLAGS_GCC_OPTION([-Os])
|
AX_CFLAGS_GCC_OPTION([-Os])
|
||||||
@@ -450,7 +599,10 @@ fi
|
|||||||
#
|
#
|
||||||
AC_FUNC_VPRINTF
|
AC_FUNC_VPRINTF
|
||||||
AC_FUNC_FSEEKO
|
AC_FUNC_FSEEKO
|
||||||
AC_CHECK_FUNCS(ftime,, [AC_CHECK_LIB(compat, ftime)])
|
AC_CHECK_FUNC(strnlen,
|
||||||
|
AC_DEFINE(HAVE_STRNLEN, 1, [Defines if strnlen is available on your system]))
|
||||||
|
AC_CHECK_FUNC(strndup,
|
||||||
|
AC_DEFINE(HAVE_STRNDUP, 1, [Defines if strndup is available on your system]))
|
||||||
#
|
#
|
||||||
# Solaris needs -lsocket -lnsl -lrt
|
# Solaris needs -lsocket -lnsl -lrt
|
||||||
AC_SEARCH_LIBS([bind], [socket])
|
AC_SEARCH_LIBS([bind], [socket])
|
||||||
|
|||||||
@@ -738,7 +738,7 @@ EXPORT_SPEC int ixmlDocument_createDocumentEx(
|
|||||||
* \return A pointer to the new \b Document object with the nodeName set to
|
* \return A pointer to the new \b Document object with the nodeName set to
|
||||||
* "#document" or \c NULL on failure.
|
* "#document" or \c NULL on failure.
|
||||||
*/
|
*/
|
||||||
EXPORT_SPEC IXML_Document *ixmlDocument_createDocument();
|
EXPORT_SPEC IXML_Document *ixmlDocument_createDocument(void);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
|||||||
@@ -40,8 +40,11 @@ void IxmlPrintf(
|
|||||||
;
|
;
|
||||||
#else /* DEBUG */
|
#else /* DEBUG */
|
||||||
static UPNP_INLINE void IxmlPrintf(
|
static UPNP_INLINE void IxmlPrintf(
|
||||||
const char* FmtStr,
|
const char *FmtStr,
|
||||||
...) {}
|
...)
|
||||||
|
{
|
||||||
|
FmtStr = FmtStr;
|
||||||
|
}
|
||||||
#endif /* DEBUG */
|
#endif /* DEBUG */
|
||||||
|
|
||||||
|
|
||||||
@@ -59,6 +62,8 @@ static UPNP_INLINE void printNodes(
|
|||||||
IXML_Node *tmpRoot,
|
IXML_Node *tmpRoot,
|
||||||
int depth)
|
int depth)
|
||||||
{
|
{
|
||||||
|
tmpRoot = tmpRoot;
|
||||||
|
depth = depth;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -139,10 +140,11 @@ int ixmlDocument_createElementEx(
|
|||||||
errCode = IXML_INSUFFICIENT_MEMORY;
|
errCode = IXML_INSUFFICIENT_MEMORY;
|
||||||
goto ErrorHandler;
|
goto ErrorHandler;
|
||||||
}
|
}
|
||||||
// set the node fields
|
/* set the node fields */
|
||||||
newElement->n.nodeType = eELEMENT_NODE;
|
newElement->n.nodeType = eELEMENT_NODE;
|
||||||
newElement->n.nodeName = strdup(tagName);
|
newElement->n.nodeName = strdup(tagName);
|
||||||
if (newElement->n.nodeName == NULL) {
|
if (newElement->n.nodeName == NULL) {
|
||||||
|
free(newElement->tagName);
|
||||||
ixmlElement_free(newElement);
|
ixmlElement_free(newElement);
|
||||||
newElement = NULL;
|
newElement = NULL;
|
||||||
errCode = IXML_INSUFFICIENT_MEMORY;
|
errCode = IXML_INSUFFICIENT_MEMORY;
|
||||||
@@ -163,8 +165,14 @@ IXML_Element *ixmlDocument_createElement(
|
|||||||
const DOMString tagName)
|
const DOMString tagName)
|
||||||
{
|
{
|
||||||
IXML_Element *newElement = NULL;
|
IXML_Element *newElement = NULL;
|
||||||
|
int ret = IXML_SUCCESS;
|
||||||
|
|
||||||
ixmlDocument_createElementEx(doc, tagName, &newElement);
|
ret = ixmlDocument_createElementEx(doc, tagName, &newElement);
|
||||||
|
if (ret != IXML_SUCCESS) {
|
||||||
|
IxmlPrintf(__FILE__, __LINE__, "ixmlDocument_createElement",
|
||||||
|
"Error %d\n", ret);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
return newElement;
|
return newElement;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -183,7 +191,7 @@ int ixmlDocument_createDocumentEx(IXML_Document **rtDoc)
|
|||||||
|
|
||||||
ixmlDocument_init(doc);
|
ixmlDocument_init(doc);
|
||||||
|
|
||||||
doc->n.nodeName = strdup(DOCUMENTNODENAME);
|
doc->n.nodeName = strdup((const char*)DOCUMENTNODENAME);
|
||||||
if (doc->n.nodeName == NULL) {
|
if (doc->n.nodeName == NULL) {
|
||||||
ixmlDocument_free(doc);
|
ixmlDocument_free(doc);
|
||||||
doc = NULL;
|
doc = NULL;
|
||||||
@@ -229,17 +237,17 @@ int ixmlDocument_createTextNodeEx(
|
|||||||
rc = IXML_INSUFFICIENT_MEMORY;
|
rc = IXML_INSUFFICIENT_MEMORY;
|
||||||
goto ErrorHandler;
|
goto ErrorHandler;
|
||||||
}
|
}
|
||||||
// initialize the node
|
/* initialize the node */
|
||||||
ixmlNode_init(returnNode);
|
ixmlNode_init(returnNode);
|
||||||
|
|
||||||
returnNode->nodeName = strdup(TEXTNODENAME);
|
returnNode->nodeName = strdup((const char*)TEXTNODENAME);
|
||||||
if (returnNode->nodeName == NULL) {
|
if (returnNode->nodeName == NULL) {
|
||||||
ixmlNode_free(returnNode);
|
ixmlNode_free(returnNode);
|
||||||
returnNode = NULL;
|
returnNode = NULL;
|
||||||
rc = IXML_INSUFFICIENT_MEMORY;
|
rc = IXML_INSUFFICIENT_MEMORY;
|
||||||
goto ErrorHandler;
|
goto ErrorHandler;
|
||||||
}
|
}
|
||||||
// add in node value
|
/* add in node value */
|
||||||
if (data != NULL) {
|
if (data != NULL) {
|
||||||
returnNode->nodeValue = strdup(data);
|
returnNode->nodeValue = strdup(data);
|
||||||
if (returnNode->nodeValue == NULL) {
|
if (returnNode->nodeValue == NULL) {
|
||||||
@@ -295,7 +303,7 @@ int ixmlDocument_createAttributeEx(
|
|||||||
ixmlAttr_init(attrNode);
|
ixmlAttr_init(attrNode);
|
||||||
attrNode->n.nodeType = eATTRIBUTE_NODE;
|
attrNode->n.nodeType = eATTRIBUTE_NODE;
|
||||||
|
|
||||||
// set the node fields
|
/* set the node fields */
|
||||||
attrNode->n.nodeName = strdup(name);
|
attrNode->n.nodeName = strdup(name);
|
||||||
if (attrNode->n.nodeName == NULL) {
|
if (attrNode->n.nodeName == NULL) {
|
||||||
ixmlAttr_free(attrNode);
|
ixmlAttr_free(attrNode);
|
||||||
@@ -318,7 +326,8 @@ IXML_Attr *ixmlDocument_createAttribute(
|
|||||||
{
|
{
|
||||||
IXML_Attr *attrNode = NULL;
|
IXML_Attr *attrNode = NULL;
|
||||||
|
|
||||||
ixmlDocument_createAttributeEx(doc, name, &attrNode);
|
if(ixmlDocument_createAttributeEx(doc, name, &attrNode) != IXML_SUCCESS)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
return attrNode;
|
return attrNode;
|
||||||
}
|
}
|
||||||
@@ -343,7 +352,7 @@ int ixmlDocument_createAttributeNSEx(
|
|||||||
if (errCode != IXML_SUCCESS) {
|
if (errCode != IXML_SUCCESS) {
|
||||||
goto ErrorHandler;
|
goto ErrorHandler;
|
||||||
}
|
}
|
||||||
// set the namespaceURI field
|
/* set the namespaceURI field */
|
||||||
attrNode->n.namespaceURI = strdup(namespaceURI);
|
attrNode->n.namespaceURI = strdup(namespaceURI);
|
||||||
if (attrNode->n.namespaceURI == NULL) {
|
if (attrNode->n.namespaceURI == NULL) {
|
||||||
ixmlAttr_free(attrNode);
|
ixmlAttr_free(attrNode);
|
||||||
@@ -351,7 +360,7 @@ int ixmlDocument_createAttributeNSEx(
|
|||||||
errCode = IXML_INSUFFICIENT_MEMORY;
|
errCode = IXML_INSUFFICIENT_MEMORY;
|
||||||
goto ErrorHandler;
|
goto ErrorHandler;
|
||||||
}
|
}
|
||||||
// set the localName and prefix
|
/* set the localName and prefix */
|
||||||
errCode =
|
errCode =
|
||||||
ixmlNode_setNodeName((IXML_Node *)attrNode, qualifiedName);
|
ixmlNode_setNodeName((IXML_Node *)attrNode, qualifiedName);
|
||||||
if (errCode != IXML_SUCCESS) {
|
if (errCode != IXML_SUCCESS) {
|
||||||
@@ -401,7 +410,7 @@ int ixmlDocument_createCDATASectionEx(
|
|||||||
|
|
||||||
ixmlCDATASection_init(cDSectionNode);
|
ixmlCDATASection_init(cDSectionNode);
|
||||||
cDSectionNode->n.nodeType = eCDATA_SECTION_NODE;
|
cDSectionNode->n.nodeType = eCDATA_SECTION_NODE;
|
||||||
cDSectionNode->n.nodeName = strdup(CDATANODENAME);
|
cDSectionNode->n.nodeName = strdup((const char*)CDATANODENAME);
|
||||||
if (cDSectionNode->n.nodeName == NULL) {
|
if (cDSectionNode->n.nodeName == NULL) {
|
||||||
ixmlCDATASection_free(cDSectionNode);
|
ixmlCDATASection_free(cDSectionNode);
|
||||||
cDSectionNode = NULL;
|
cDSectionNode = NULL;
|
||||||
@@ -458,7 +467,7 @@ int ixmlDocument_createElementNSEx(
|
|||||||
line = __LINE__;
|
line = __LINE__;
|
||||||
goto ErrorHandler;
|
goto ErrorHandler;
|
||||||
}
|
}
|
||||||
// set the namespaceURI field
|
/* set the namespaceURI field */
|
||||||
newElement->n.namespaceURI = strdup(namespaceURI);
|
newElement->n.namespaceURI = strdup(namespaceURI);
|
||||||
if (newElement->n.namespaceURI == NULL) {
|
if (newElement->n.namespaceURI == NULL) {
|
||||||
line = __LINE__;
|
line = __LINE__;
|
||||||
@@ -467,7 +476,7 @@ int ixmlDocument_createElementNSEx(
|
|||||||
ret = IXML_INSUFFICIENT_MEMORY;
|
ret = IXML_INSUFFICIENT_MEMORY;
|
||||||
goto ErrorHandler;
|
goto ErrorHandler;
|
||||||
}
|
}
|
||||||
// set the localName and prefix
|
/* set the localName and prefix */
|
||||||
ret = ixmlNode_setNodeName((IXML_Node *)newElement, qualifiedName);
|
ret = ixmlNode_setNodeName((IXML_Node *)newElement, qualifiedName);
|
||||||
if (ret != IXML_SUCCESS) {
|
if (ret != IXML_SUCCESS) {
|
||||||
line = __LINE__;
|
line = __LINE__;
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -110,7 +111,7 @@ int ixmlElement_setAttribute(
|
|||||||
{
|
{
|
||||||
IXML_Node *attrNode;
|
IXML_Node *attrNode;
|
||||||
IXML_Attr *newAttrNode;
|
IXML_Attr *newAttrNode;
|
||||||
short errCode = IXML_SUCCESS;
|
int errCode = IXML_SUCCESS;
|
||||||
|
|
||||||
if (element == NULL || name == NULL || value == NULL) {
|
if (element == NULL || name == NULL || value == NULL) {
|
||||||
errCode = IXML_INVALID_PARAMETER;
|
errCode = IXML_INVALID_PARAMETER;
|
||||||
@@ -208,7 +209,8 @@ IXML_Attr *ixmlElement_getAttributeNode(IXML_Element *element, const DOMString n
|
|||||||
|
|
||||||
attrNode = element->n.firstAttr;
|
attrNode = element->n.firstAttr;
|
||||||
while (attrNode != NULL) {
|
while (attrNode != NULL) {
|
||||||
if (strcmp(attrNode->nodeName, name) == 0) { // found it
|
if (strcmp(attrNode->nodeName, name) == 0) {
|
||||||
|
/* found it */
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
attrNode = attrNode->nextSibling;
|
attrNode = attrNode->nextSibling;
|
||||||
@@ -231,53 +233,42 @@ int ixmlElement_setAttributeNode(
|
|||||||
IXML_Node *preSib = NULL;
|
IXML_Node *preSib = NULL;
|
||||||
IXML_Node *nextSib = NULL;
|
IXML_Node *nextSib = NULL;
|
||||||
|
|
||||||
if (element == NULL || newAttr == NULL) {
|
if (!element || !newAttr)
|
||||||
return IXML_INVALID_PARAMETER;
|
return IXML_INVALID_PARAMETER;
|
||||||
}
|
if (newAttr->n.ownerDocument != element->n.ownerDocument)
|
||||||
|
|
||||||
if (newAttr->n.ownerDocument != element->n.ownerDocument) {
|
|
||||||
return IXML_WRONG_DOCUMENT_ERR;
|
return IXML_WRONG_DOCUMENT_ERR;
|
||||||
}
|
if (newAttr->ownerElement)
|
||||||
|
|
||||||
if (newAttr->ownerElement != NULL) {
|
|
||||||
return IXML_INUSE_ATTRIBUTE_ERR;
|
return IXML_INUSE_ATTRIBUTE_ERR;
|
||||||
}
|
|
||||||
|
|
||||||
newAttr->ownerElement = element;
|
newAttr->ownerElement = element;
|
||||||
node = (IXML_Node *)newAttr;
|
node = (IXML_Node *)newAttr;
|
||||||
|
|
||||||
attrNode = element->n.firstAttr;
|
attrNode = element->n.firstAttr;
|
||||||
while (attrNode != NULL) {
|
while (attrNode) {
|
||||||
if (strcmp(attrNode->nodeName, node->nodeName) == 0) {
|
if (!strcmp(attrNode->nodeName, node->nodeName))
|
||||||
/* Found it */
|
/* Found it */
|
||||||
break;
|
break;
|
||||||
} else {
|
else
|
||||||
attrNode = attrNode->nextSibling;
|
attrNode = attrNode->nextSibling;
|
||||||
}
|
}
|
||||||
}
|
if (attrNode) {
|
||||||
|
|
||||||
if (attrNode != NULL) {
|
|
||||||
/* Already present, will replace by newAttr */
|
/* Already present, will replace by newAttr */
|
||||||
preSib = attrNode->prevSibling;
|
preSib = attrNode->prevSibling;
|
||||||
nextSib = attrNode->nextSibling;
|
nextSib = attrNode->nextSibling;
|
||||||
if (preSib != NULL) {
|
if (preSib)
|
||||||
preSib->nextSibling = node;
|
preSib->nextSibling = node;
|
||||||
}
|
if (nextSib)
|
||||||
if (nextSib != NULL) {
|
|
||||||
nextSib->prevSibling = node;
|
nextSib->prevSibling = node;
|
||||||
}
|
if (element->n.firstAttr == attrNode)
|
||||||
if (element->n.firstAttr == attrNode) {
|
|
||||||
element->n.firstAttr = node;
|
element->n.firstAttr = node;
|
||||||
}
|
if (rtAttr)
|
||||||
if (rtAttr != NULL) {
|
|
||||||
*rtAttr = (IXML_Attr *)attrNode;
|
*rtAttr = (IXML_Attr *)attrNode;
|
||||||
}
|
else
|
||||||
|
ixmlAttr_free((IXML_Attr *)attrNode);
|
||||||
} else {
|
} else {
|
||||||
/* Add this attribute */
|
/* Add this attribute */
|
||||||
if (element->n.firstAttr != NULL) {
|
if (element->n.firstAttr) {
|
||||||
prevAttr = element->n.firstAttr;
|
prevAttr = element->n.firstAttr;
|
||||||
nextAttr = prevAttr->nextSibling;
|
nextAttr = prevAttr->nextSibling;
|
||||||
while (nextAttr != NULL) {
|
while (nextAttr) {
|
||||||
prevAttr = nextAttr;
|
prevAttr = nextAttr;
|
||||||
nextAttr = prevAttr->nextSibling;
|
nextAttr = prevAttr->nextSibling;
|
||||||
}
|
}
|
||||||
@@ -289,11 +280,9 @@ int ixmlElement_setAttributeNode(
|
|||||||
node->prevSibling = NULL;
|
node->prevSibling = NULL;
|
||||||
node->nextSibling = NULL;
|
node->nextSibling = NULL;
|
||||||
}
|
}
|
||||||
|
if (rtAttr)
|
||||||
if (rtAttr != NULL) {
|
|
||||||
*rtAttr = NULL;
|
*rtAttr = NULL;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return IXML_SUCCESS;
|
return IXML_SUCCESS;
|
||||||
}
|
}
|
||||||
@@ -442,7 +431,7 @@ int ixmlElement_setAttributeNS(
|
|||||||
|
|
||||||
/* see DOM 2 spec page 59 */
|
/* see DOM 2 spec page 59 */
|
||||||
if ((newAttrNode.prefix != NULL && namespaceURI == NULL) ||
|
if ((newAttrNode.prefix != NULL && namespaceURI == NULL) ||
|
||||||
(strcmp(newAttrNode.prefix, "xml") == 0 &&
|
(newAttrNode.prefix != NULL && strcmp(newAttrNode.prefix, "xml") == 0 &&
|
||||||
strcmp(namespaceURI, "http://www.w3.org/XML/1998/namespace") != 0) ||
|
strcmp(namespaceURI, "http://www.w3.org/XML/1998/namespace") != 0) ||
|
||||||
(strcmp(qualifiedName, "xmlns") == 0 &&
|
(strcmp(qualifiedName, "xmlns") == 0 &&
|
||||||
strcmp(namespaceURI, "http://www.w3.org/2000/xmlns/") != 0)) {
|
strcmp(namespaceURI, "http://www.w3.org/2000/xmlns/") != 0)) {
|
||||||
@@ -489,15 +478,18 @@ int ixmlElement_setAttributeNS(
|
|||||||
qualifiedName,
|
qualifiedName,
|
||||||
&newAttr);
|
&newAttr);
|
||||||
if (rc != IXML_SUCCESS) {
|
if (rc != IXML_SUCCESS) {
|
||||||
|
Parser_freeNodeContent(&newAttrNode);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
newAttr->n.nodeValue = strdup(value);
|
newAttr->n.nodeValue = strdup(value);
|
||||||
if (newAttr->n.nodeValue == NULL) {
|
if (newAttr->n.nodeValue == NULL) {
|
||||||
ixmlAttr_free(newAttr);
|
ixmlAttr_free(newAttr);
|
||||||
|
Parser_freeNodeContent(&newAttrNode);
|
||||||
return IXML_INSUFFICIENT_MEMORY;
|
return IXML_INSUFFICIENT_MEMORY;
|
||||||
}
|
}
|
||||||
if (ixmlElement_setAttributeNodeNS(element, newAttr, NULL) != IXML_SUCCESS) {
|
if (ixmlElement_setAttributeNodeNS(element, newAttr, &newAttr) != IXML_SUCCESS) {
|
||||||
ixmlAttr_free(newAttr);
|
ixmlAttr_free(newAttr);
|
||||||
|
Parser_freeNodeContent(&newAttrNode);
|
||||||
return IXML_FAILED;
|
return IXML_FAILED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -555,7 +547,7 @@ IXML_Attr *ixmlElement_getAttributeNodeNS(
|
|||||||
while (attrNode != NULL) {
|
while (attrNode != NULL) {
|
||||||
if (strcmp(attrNode->localName, localName) == 0 &&
|
if (strcmp(attrNode->localName, localName) == 0 &&
|
||||||
strcmp(attrNode->namespaceURI, namespaceURI) == 0) {
|
strcmp(attrNode->namespaceURI, namespaceURI) == 0) {
|
||||||
// found it
|
/* found it */
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
attrNode = attrNode->nextSibling;
|
attrNode = attrNode->nextSibling;
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -49,7 +50,7 @@
|
|||||||
#define MAXVAL(a, b) ( (a) > (b) ? (a) : (b) )
|
#define MAXVAL(a, b) ( (a) > (b) ? (a) : (b) )
|
||||||
|
|
||||||
|
|
||||||
#define MEMBUF_DEF_SIZE_INC 20
|
#define MEMBUF_DEF_SIZE_INC 20u
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@@ -166,7 +167,7 @@ int ixml_membuf_insert(
|
|||||||
size_t buf_len,
|
size_t buf_len,
|
||||||
/*! [in] The point of insertion relative to the beggining of the
|
/*! [in] The point of insertion relative to the beggining of the
|
||||||
* ixml_membuf internal buffer. */
|
* ixml_membuf internal buffer. */
|
||||||
int index);
|
size_t index);
|
||||||
|
|
||||||
|
|
||||||
#endif /* IXML_MEMBUF_H */
|
#endif /* IXML_MEMBUF_H */
|
||||||
|
|||||||
@@ -54,37 +54,29 @@ static void copy_with_escape(
|
|||||||
/*! [in] The string to copy from. */
|
/*! [in] The string to copy from. */
|
||||||
const char *p)
|
const char *p)
|
||||||
{
|
{
|
||||||
int i;
|
size_t i;
|
||||||
int plen;
|
size_t plen;
|
||||||
|
|
||||||
if (p == NULL) {
|
if (p == NULL)
|
||||||
return;
|
return;
|
||||||
}
|
plen = strlen(p);
|
||||||
|
for (i = (size_t)0; i < plen; ++i) {
|
||||||
plen = strlen( p );
|
|
||||||
|
|
||||||
for (i = 0; i < plen; i++) {
|
|
||||||
switch (p[i]) {
|
switch (p[i]) {
|
||||||
case '<':
|
case '<':
|
||||||
ixml_membuf_append_str(buf, "<");
|
ixml_membuf_append_str(buf, "<");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '>':
|
case '>':
|
||||||
ixml_membuf_append_str(buf, ">");
|
ixml_membuf_append_str(buf, ">");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '&':
|
case '&':
|
||||||
ixml_membuf_append_str(buf, "&");
|
ixml_membuf_append_str(buf, "&");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '\'':
|
case '\'':
|
||||||
ixml_membuf_append_str(buf, "'");
|
ixml_membuf_append_str(buf, "'");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '\"':
|
case '\"':
|
||||||
ixml_membuf_append_str(buf, """);
|
ixml_membuf_append_str(buf, """);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
ixml_membuf_append(buf, &p[i]);
|
ixml_membuf_append(buf, &p[i]);
|
||||||
break;
|
break;
|
||||||
@@ -161,11 +153,11 @@ static void ixmlPrintDomTreeRecursive(
|
|||||||
} else {
|
} else {
|
||||||
ixml_membuf_append_str(buf, ">");
|
ixml_membuf_append_str(buf, ">");
|
||||||
}
|
}
|
||||||
// output the children
|
/* output the children */
|
||||||
ixmlPrintDomTreeRecursive(
|
ixmlPrintDomTreeRecursive(
|
||||||
ixmlNode_getFirstChild(nodeptr), buf);
|
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, "</");
|
||||||
ixml_membuf_append_str(buf, nodeName);
|
ixml_membuf_append_str(buf, nodeName);
|
||||||
|
|
||||||
@@ -183,7 +175,7 @@ static void ixmlPrintDomTreeRecursive(
|
|||||||
default:
|
default:
|
||||||
IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTreeRecursive",
|
IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTreeRecursive",
|
||||||
"Warning, unknown node type %d\n",
|
"Warning, unknown node type %d\n",
|
||||||
ixmlNode_getNodeType(nodeptr));
|
(int)ixmlNode_getNodeType(nodeptr));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -242,11 +234,11 @@ static void ixmlPrintDomTree(
|
|||||||
ixml_membuf_append_str(buf, ">");
|
ixml_membuf_append_str(buf, ">");
|
||||||
}
|
}
|
||||||
|
|
||||||
// output the children
|
/* output the children */
|
||||||
ixmlPrintDomTreeRecursive(
|
ixmlPrintDomTreeRecursive(
|
||||||
ixmlNode_getFirstChild(nodeptr), buf);
|
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, "</");
|
||||||
ixml_membuf_append_str(buf, nodeName);
|
ixml_membuf_append_str(buf, nodeName);
|
||||||
ixml_membuf_append_str(buf, ">\r\n");
|
ixml_membuf_append_str(buf, ">\r\n");
|
||||||
@@ -255,7 +247,7 @@ static void ixmlPrintDomTree(
|
|||||||
default:
|
default:
|
||||||
IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTree",
|
IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTree",
|
||||||
"Warning, unknown node type %d\n",
|
"Warning, unknown node type %d\n",
|
||||||
ixmlNode_getNodeType(nodeptr));
|
(int)ixmlNode_getNodeType(nodeptr));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -314,10 +306,10 @@ static void ixmlDomTreetoString(
|
|||||||
ixml_membuf_append_str(buf, ">");
|
ixml_membuf_append_str(buf, ">");
|
||||||
}
|
}
|
||||||
|
|
||||||
// output the children
|
/* output the children */
|
||||||
ixmlPrintDomTreeRecursive(ixmlNode_getFirstChild(nodeptr), buf);
|
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, "</");
|
||||||
ixml_membuf_append_str(buf, nodeName);
|
ixml_membuf_append_str(buf, nodeName);
|
||||||
ixml_membuf_append_str(buf, ">");
|
ixml_membuf_append_str(buf, ">");
|
||||||
@@ -326,7 +318,7 @@ static void ixmlDomTreetoString(
|
|||||||
default:
|
default:
|
||||||
IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTreeRecursive",
|
IxmlPrintf(__FILE__, __LINE__, "ixmlPrintDomTreeRecursive",
|
||||||
"Warning, unknown node type %d\n",
|
"Warning, unknown node type %d\n",
|
||||||
ixmlNode_getNodeType(nodeptr));
|
(int)ixmlNode_getNodeType(nodeptr));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ void IxmlPrintf(
|
|||||||
|
|
||||||
void printNodes(IXML_Node *tmpRoot, int depth)
|
void printNodes(IXML_Node *tmpRoot, int depth)
|
||||||
{
|
{
|
||||||
int i;
|
unsigned long i;
|
||||||
IXML_NodeList *NodeList1;
|
IXML_NodeList *NodeList1;
|
||||||
IXML_Node *ChildNode1;
|
IXML_Node *ChildNode1;
|
||||||
unsigned short NodeType;
|
unsigned short NodeType;
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -75,10 +76,10 @@ static int ixml_membuf_set_size(
|
|||||||
diff = new_length - m->length;
|
diff = new_length - m->length;
|
||||||
alloc_len = MAXVAL(m->size_inc, diff) + m->capacity;
|
alloc_len = MAXVAL(m->size_inc, diff) + m->capacity;
|
||||||
} else {
|
} else {
|
||||||
// decrease length
|
/* decrease length */
|
||||||
assert(new_length <= m->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) {
|
if ((m->capacity - new_length) <= m->size_inc) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -87,11 +88,11 @@ static int ixml_membuf_set_size(
|
|||||||
|
|
||||||
assert(alloc_len >= new_length);
|
assert(alloc_len >= new_length);
|
||||||
|
|
||||||
temp_buf = realloc(m->buf, alloc_len + 1);
|
temp_buf = realloc(m->buf, alloc_len + (size_t)1);
|
||||||
if (temp_buf == NULL) {
|
if (temp_buf == NULL) {
|
||||||
/* try smaller size */
|
/* try smaller size */
|
||||||
alloc_len = new_length;
|
alloc_len = new_length;
|
||||||
temp_buf = realloc(m->buf, alloc_len + 1);
|
temp_buf = realloc(m->buf, alloc_len + (size_t)1);
|
||||||
if (temp_buf == NULL) {
|
if (temp_buf == NULL) {
|
||||||
return IXML_INSUFFICIENT_MEMORY;
|
return IXML_INSUFFICIENT_MEMORY;
|
||||||
}
|
}
|
||||||
@@ -110,8 +111,8 @@ void ixml_membuf_init(ixml_membuf *m)
|
|||||||
|
|
||||||
m->size_inc = MEMBUF_DEF_SIZE_INC;
|
m->size_inc = MEMBUF_DEF_SIZE_INC;
|
||||||
m->buf = NULL;
|
m->buf = NULL;
|
||||||
m->length = 0;
|
m->length = (size_t)0;
|
||||||
m->capacity = 0;
|
m->capacity = (size_t)0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -135,21 +136,21 @@ int ixml_membuf_assign(
|
|||||||
|
|
||||||
assert(m != NULL);
|
assert(m != NULL);
|
||||||
|
|
||||||
// set value to null
|
/* set value to null */
|
||||||
if (buf == NULL) {
|
if (buf == NULL) {
|
||||||
ixml_membuf_destroy(m);
|
ixml_membuf_destroy(m);
|
||||||
return IXML_SUCCESS;
|
return IXML_SUCCESS;
|
||||||
}
|
}
|
||||||
// alloc mem
|
/* alloc mem */
|
||||||
return_code = ixml_membuf_set_size(m, buf_len);
|
return_code = ixml_membuf_set_size(m, buf_len);
|
||||||
if (return_code != 0) {
|
if (return_code != 0) {
|
||||||
return return_code;
|
return return_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
// copy
|
/* copy */
|
||||||
memcpy(m->buf, buf, buf_len);
|
memcpy(m->buf, buf, buf_len);
|
||||||
|
|
||||||
// null-terminate
|
/* null-terminate */
|
||||||
m->buf[buf_len] = 0;
|
m->buf[buf_len] = 0;
|
||||||
m->length = buf_len;
|
m->length = buf_len;
|
||||||
|
|
||||||
@@ -171,7 +172,7 @@ int ixml_membuf_append(
|
|||||||
{
|
{
|
||||||
assert(m != NULL);
|
assert(m != NULL);
|
||||||
|
|
||||||
return ixml_membuf_insert(m, buf, 1, m->length);
|
return ixml_membuf_insert(m, buf, (size_t)1, m->length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -187,17 +188,17 @@ int ixml_membuf_insert(
|
|||||||
INOUT ixml_membuf *m,
|
INOUT ixml_membuf *m,
|
||||||
IN const void *buf,
|
IN const void *buf,
|
||||||
IN size_t buf_len,
|
IN size_t buf_len,
|
||||||
int index)
|
size_t index)
|
||||||
{
|
{
|
||||||
int return_code = 0;
|
int return_code = 0;
|
||||||
|
|
||||||
assert(m != NULL);
|
assert(m != NULL);
|
||||||
|
|
||||||
if (index < 0 || index > (int)m->length) {
|
if (index > m->length) {
|
||||||
return IXML_INDEX_SIZE_ERR;
|
return IXML_INDEX_SIZE_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (buf == NULL || buf_len == 0) {
|
if (buf == NULL || buf_len == (size_t)0) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/* alloc mem */
|
/* alloc mem */
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -53,11 +54,11 @@ static unsigned long ixmlNamedNodeMap_getItemNumber(
|
|||||||
IN const char *name)
|
IN const char *name)
|
||||||
{
|
{
|
||||||
IXML_Node *tempNode;
|
IXML_Node *tempNode;
|
||||||
unsigned long returnItemNo = 0;
|
unsigned long returnItemNo = 0lu;
|
||||||
|
|
||||||
assert(nnMap != NULL && name != NULL);
|
assert(nnMap != NULL && name != NULL);
|
||||||
if (nnMap == NULL || name == NULL) {
|
if (nnMap == NULL || name == NULL) {
|
||||||
return IXML_INVALID_ITEM_NUMBER;
|
return (unsigned long)IXML_INVALID_ITEM_NUMBER;
|
||||||
}
|
}
|
||||||
|
|
||||||
tempNode = nnMap->nodeItem;
|
tempNode = nnMap->nodeItem;
|
||||||
@@ -69,7 +70,7 @@ static unsigned long ixmlNamedNodeMap_getItemNumber(
|
|||||||
returnItemNo++;
|
returnItemNo++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return IXML_INVALID_ITEM_NUMBER;
|
return (unsigned long)IXML_INVALID_ITEM_NUMBER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -85,17 +86,17 @@ IXML_Node *ixmlNamedNodeMap_getNamedItem(
|
|||||||
IXML_NamedNodeMap *nnMap,
|
IXML_NamedNodeMap *nnMap,
|
||||||
const DOMString name)
|
const DOMString name)
|
||||||
{
|
{
|
||||||
long index;
|
unsigned long index;
|
||||||
|
|
||||||
if (nnMap == NULL || name == NULL) {
|
if (nnMap == NULL || name == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
index = ixmlNamedNodeMap_getItemNumber(nnMap, name);
|
index = ixmlNamedNodeMap_getItemNumber(nnMap, name);
|
||||||
if (index == IXML_INVALID_ITEM_NUMBER) {
|
if (index == (unsigned long)IXML_INVALID_ITEM_NUMBER) {
|
||||||
return NULL;
|
return NULL;
|
||||||
} else {
|
} else {
|
||||||
return ixmlNamedNodeMap_item(nnMap, (unsigned long)index);
|
return ixmlNamedNodeMap_item(nnMap, index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -111,12 +112,12 @@ IXML_Node *ixmlNamedNodeMap_item(
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (index > ixmlNamedNodeMap_getLength(nnMap) - 1) {
|
if (index > ixmlNamedNodeMap_getLength(nnMap) - 1lu) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
tempNode = nnMap->nodeItem;
|
tempNode = nnMap->nodeItem;
|
||||||
for (i = 0; i < index && tempNode != NULL; ++i) {
|
for (i = 0u; i < index && tempNode != NULL; ++i) {
|
||||||
tempNode = tempNode->nextSibling;
|
tempNode = tempNode->nextSibling;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -127,11 +128,11 @@ IXML_Node *ixmlNamedNodeMap_item(
|
|||||||
unsigned long ixmlNamedNodeMap_getLength(IXML_NamedNodeMap *nnMap)
|
unsigned long ixmlNamedNodeMap_getLength(IXML_NamedNodeMap *nnMap)
|
||||||
{
|
{
|
||||||
IXML_Node *tempNode;
|
IXML_Node *tempNode;
|
||||||
unsigned long length = 0;
|
unsigned long length = 0lu;
|
||||||
|
|
||||||
if (nnMap != NULL) {
|
if (nnMap != NULL) {
|
||||||
tempNode = nnMap->nodeItem;
|
tempNode = nnMap->nodeItem;
|
||||||
for (length = 0; tempNode != NULL; ++length) {
|
for (length = 0lu; tempNode != NULL; ++length) {
|
||||||
tempNode = tempNode->nextSibling;
|
tempNode = tempNode->nextSibling;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -165,7 +166,7 @@ int ixmlNamedNodeMap_addToNamedNodeMap(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (*nnMap == NULL) {
|
if (*nnMap == NULL) {
|
||||||
// nodelist is empty
|
/* nodelist is empty */
|
||||||
*nnMap = (IXML_NamedNodeMap *)malloc(sizeof (IXML_NamedNodeMap));
|
*nnMap = (IXML_NamedNodeMap *)malloc(sizeof (IXML_NamedNodeMap));
|
||||||
if (*nnMap == NULL) {
|
if (*nnMap == NULL) {
|
||||||
return IXML_INSUFFICIENT_MEMORY;
|
return IXML_INSUFFICIENT_MEMORY;
|
||||||
|
|||||||
125
ixml/src/node.c
125
ixml/src/node.c
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -90,9 +91,13 @@ static void ixmlNode_freeSingleNode(
|
|||||||
if (nodeptr->localName != NULL) {
|
if (nodeptr->localName != NULL) {
|
||||||
free(nodeptr->localName);
|
free(nodeptr->localName);
|
||||||
}
|
}
|
||||||
if (nodeptr->nodeType == eELEMENT_NODE) {
|
switch (nodeptr->nodeType ) {
|
||||||
|
case eELEMENT_NODE:
|
||||||
element = (IXML_Element *)nodeptr;
|
element = (IXML_Element *)nodeptr;
|
||||||
free(element->tagName);
|
free(element->tagName);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
free(nodeptr);
|
free(nodeptr);
|
||||||
}
|
}
|
||||||
@@ -280,7 +285,7 @@ unsigned short ixmlNode_getNodeType(IXML_Node *nodeptr)
|
|||||||
if (nodeptr != NULL) {
|
if (nodeptr != NULL) {
|
||||||
return nodeptr->nodeType;
|
return nodeptr->nodeType;
|
||||||
} else {
|
} else {
|
||||||
return eINVALID_NODE;
|
return (unsigned short)eINVALID_NODE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -397,6 +402,7 @@ static BOOL ixmlNode_isParent(
|
|||||||
|
|
||||||
assert(nodeptr != NULL && toFind != NULL);
|
assert(nodeptr != NULL && toFind != NULL);
|
||||||
|
|
||||||
|
if (nodeptr != NULL && toFind != NULL)
|
||||||
found = toFind->parentNode == nodeptr;
|
found = toFind->parentNode == nodeptr;
|
||||||
|
|
||||||
return found;
|
return found;
|
||||||
@@ -422,17 +428,22 @@ static BOOL ixmlNode_allowChildren(
|
|||||||
case eTEXT_NODE:
|
case eTEXT_NODE:
|
||||||
case eCDATA_SECTION_NODE:
|
case eCDATA_SECTION_NODE:
|
||||||
return FALSE;
|
return FALSE;
|
||||||
break;
|
|
||||||
|
|
||||||
case eELEMENT_NODE:
|
case eELEMENT_NODE:
|
||||||
if (newChild->nodeType == eATTRIBUTE_NODE ||
|
switch (newChild->nodeType) {
|
||||||
newChild->nodeType == eDOCUMENT_NODE) {
|
case eATTRIBUTE_NODE:
|
||||||
|
case eDOCUMENT_NODE:
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case eDOCUMENT_NODE:
|
case eDOCUMENT_NODE:
|
||||||
if (newChild->nodeType != eELEMENT_NODE) {
|
switch (newChild->nodeType) {
|
||||||
|
case eELEMENT_NODE:
|
||||||
|
break;
|
||||||
|
default:
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -500,7 +511,7 @@ int ixmlNode_insertBefore(
|
|||||||
|
|
||||||
if (refChild != NULL) {
|
if (refChild != NULL) {
|
||||||
if (ixmlNode_isParent(nodeptr, newChild) == TRUE) {
|
if (ixmlNode_isParent(nodeptr, newChild) == TRUE) {
|
||||||
ixmlNode_removeChild(nodeptr, newChild, NULL);
|
ixmlNode_removeChild(nodeptr, newChild, &newChild);
|
||||||
newChild->nextSibling = NULL;
|
newChild->nextSibling = NULL;
|
||||||
newChild->prevSibling = NULL;
|
newChild->prevSibling = NULL;
|
||||||
}
|
}
|
||||||
@@ -542,11 +553,11 @@ int ixmlNode_replaceChild(
|
|||||||
if (ixmlNode_allowChildren(nodeptr, newChild) == FALSE) {
|
if (ixmlNode_allowChildren(nodeptr, newChild) == FALSE) {
|
||||||
return IXML_HIERARCHY_REQUEST_ERR;
|
return IXML_HIERARCHY_REQUEST_ERR;
|
||||||
}
|
}
|
||||||
// if newChild was created from a different document
|
/* if newChild was created from a different document */
|
||||||
if (nodeptr->ownerDocument != newChild->ownerDocument) {
|
if (nodeptr->ownerDocument != newChild->ownerDocument) {
|
||||||
return IXML_WRONG_DOCUMENT_ERR;
|
return IXML_WRONG_DOCUMENT_ERR;
|
||||||
}
|
}
|
||||||
// if refChild is not a child of nodeptr
|
/* if refChild is not a child of nodeptr */
|
||||||
if (ixmlNode_isParent(nodeptr, oldChild) != TRUE) {
|
if (ixmlNode_isParent(nodeptr, oldChild) != TRUE) {
|
||||||
return IXML_NOT_FOUND_ERR;
|
return IXML_NOT_FOUND_ERR;
|
||||||
}
|
}
|
||||||
@@ -566,29 +577,23 @@ int ixmlNode_removeChild(
|
|||||||
IXML_Node *oldChild,
|
IXML_Node *oldChild,
|
||||||
IXML_Node **returnNode)
|
IXML_Node **returnNode)
|
||||||
{
|
{
|
||||||
if (nodeptr == NULL || oldChild == NULL) {
|
if (!nodeptr || !oldChild)
|
||||||
return IXML_INVALID_PARAMETER;
|
return IXML_INVALID_PARAMETER;
|
||||||
}
|
if (!ixmlNode_isParent(nodeptr, oldChild))
|
||||||
|
|
||||||
if (ixmlNode_isParent(nodeptr, oldChild) == FALSE ) {
|
|
||||||
return IXML_NOT_FOUND_ERR;
|
return IXML_NOT_FOUND_ERR;
|
||||||
}
|
if (oldChild->prevSibling)
|
||||||
|
|
||||||
if (oldChild->prevSibling != NULL) {
|
|
||||||
oldChild->prevSibling->nextSibling = oldChild->nextSibling;
|
oldChild->prevSibling->nextSibling = oldChild->nextSibling;
|
||||||
}
|
if (nodeptr->firstChild == oldChild)
|
||||||
if (nodeptr->firstChild == oldChild) {
|
|
||||||
nodeptr->firstChild = oldChild->nextSibling;
|
nodeptr->firstChild = oldChild->nextSibling;
|
||||||
}
|
if (oldChild->nextSibling)
|
||||||
if (oldChild->nextSibling != NULL) {
|
|
||||||
oldChild->nextSibling->prevSibling = oldChild->prevSibling;
|
oldChild->nextSibling->prevSibling = oldChild->prevSibling;
|
||||||
}
|
|
||||||
oldChild->nextSibling = NULL;
|
oldChild->nextSibling = NULL;
|
||||||
oldChild->prevSibling = NULL;
|
oldChild->prevSibling = NULL;
|
||||||
oldChild->parentNode = NULL;
|
oldChild->parentNode = NULL;
|
||||||
if (returnNode != NULL) {
|
if (returnNode)
|
||||||
*returnNode = oldChild;
|
*returnNode = oldChild;
|
||||||
}
|
else
|
||||||
|
ixmlNode_free(oldChild);
|
||||||
|
|
||||||
return IXML_SUCCESS;
|
return IXML_SUCCESS;
|
||||||
}
|
}
|
||||||
@@ -617,7 +622,7 @@ int ixmlNode_appendChild(IXML_Node *nodeptr, IXML_Node *newChild)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ixmlNode_isParent(nodeptr, newChild) == TRUE ) {
|
if (ixmlNode_isParent(nodeptr, newChild) == TRUE ) {
|
||||||
ixmlNode_removeChild(nodeptr, newChild, NULL);
|
ixmlNode_removeChild(nodeptr, newChild, &newChild);
|
||||||
}
|
}
|
||||||
/* set the parent node pointer */
|
/* set the parent node pointer */
|
||||||
newChild->parentNode = nodeptr;
|
newChild->parentNode = nodeptr;
|
||||||
@@ -650,6 +655,7 @@ static IXML_Node *ixmlNode_cloneTextNode(
|
|||||||
IXML_Node *nodeptr)
|
IXML_Node *nodeptr)
|
||||||
{
|
{
|
||||||
IXML_Node *newNode = NULL;
|
IXML_Node *newNode = NULL;
|
||||||
|
int rc;
|
||||||
|
|
||||||
assert(nodeptr != NULL);
|
assert(nodeptr != NULL);
|
||||||
|
|
||||||
@@ -658,8 +664,16 @@ static IXML_Node *ixmlNode_cloneTextNode(
|
|||||||
return NULL;
|
return NULL;
|
||||||
} else {
|
} else {
|
||||||
ixmlNode_init(newNode);
|
ixmlNode_init(newNode);
|
||||||
ixmlNode_setNodeName(newNode, nodeptr->nodeName);
|
rc = ixmlNode_setNodeName(newNode, nodeptr->nodeName);
|
||||||
ixmlNode_setNodeValue(newNode, nodeptr->nodeValue);
|
if (rc != IXML_SUCCESS) {
|
||||||
|
ixmlNode_free(newNode);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
rc = ixmlNode_setNodeValue(newNode, nodeptr->nodeValue);
|
||||||
|
if (rc != IXML_SUCCESS) {
|
||||||
|
ixmlNode_free(newNode);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
newNode->nodeType = eTEXT_NODE;
|
newNode->nodeType = eTEXT_NODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -678,15 +692,24 @@ static IXML_CDATASection *ixmlNode_cloneCDATASect(
|
|||||||
IXML_CDATASection *newCDATA = NULL;
|
IXML_CDATASection *newCDATA = NULL;
|
||||||
IXML_Node *newNode;
|
IXML_Node *newNode;
|
||||||
IXML_Node *srcNode;
|
IXML_Node *srcNode;
|
||||||
|
int rc;
|
||||||
|
|
||||||
assert(nodeptr != NULL);
|
assert(nodeptr != NULL);
|
||||||
newCDATA = (IXML_CDATASection *)malloc(sizeof (IXML_CDATASection));
|
newCDATA = (IXML_CDATASection *)malloc(sizeof (IXML_CDATASection));
|
||||||
if (newCDATA != NULL) {
|
if (newCDATA != NULL) {
|
||||||
newNode = (IXML_Node *)newCDATA;
|
newNode = (IXML_Node *)newCDATA;
|
||||||
ixmlNode_init(newNode);
|
ixmlCDATASection_init(newCDATA);
|
||||||
srcNode = (IXML_Node *)nodeptr;
|
srcNode = (IXML_Node *)nodeptr;
|
||||||
ixmlNode_setNodeName(newNode, srcNode->nodeName);
|
rc = ixmlNode_setNodeName(newNode, srcNode->nodeName);
|
||||||
ixmlNode_setNodeValue(newNode, srcNode->nodeValue);
|
if (rc != IXML_SUCCESS) {
|
||||||
|
ixmlCDATASection_free(newCDATA);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
rc = ixmlNode_setNodeValue(newNode, srcNode->nodeValue);
|
||||||
|
if (rc != IXML_SUCCESS) {
|
||||||
|
ixmlCDATASection_free(newCDATA);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
newNode->nodeType = eCDATA_SECTION_NODE;
|
newNode->nodeType = eCDATA_SECTION_NODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -761,34 +784,29 @@ static IXML_Element *ixmlNode_cloneElement(
|
|||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns a clone of a document node.
|
* \brief Returns a new document node.
|
||||||
*
|
*
|
||||||
* \return A clone of a document node.
|
* Currently, the IXML_Document struct is just a node, so this function
|
||||||
|
* just mallocs the IXML_Document, sets the node type and name.
|
||||||
|
*
|
||||||
|
* \return A new document node.
|
||||||
*/
|
*/
|
||||||
static IXML_Document *ixmlNode_cloneDoc(
|
static IXML_Document *ixmlNode_newDoc(void)
|
||||||
/*! [in] The \b Node to clone. */
|
|
||||||
IXML_Document *nodeptr)
|
|
||||||
{
|
{
|
||||||
IXML_Document *newDoc;
|
IXML_Document *newDoc;
|
||||||
IXML_Node *docNode;
|
IXML_Node *docNode;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
assert(nodeptr != NULL);
|
|
||||||
|
|
||||||
newDoc = (IXML_Document *)malloc(sizeof (IXML_Document));
|
newDoc = (IXML_Document *)malloc(sizeof (IXML_Document));
|
||||||
if (newDoc == NULL) {
|
if (!newDoc)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
|
||||||
|
|
||||||
ixmlDocument_init(newDoc);
|
ixmlDocument_init(newDoc);
|
||||||
docNode = (IXML_Node *) newDoc;
|
docNode = (IXML_Node *)newDoc;
|
||||||
|
|
||||||
rc = ixmlNode_setNodeName(docNode, DOCUMENTNODENAME);
|
rc = ixmlNode_setNodeName(docNode, DOCUMENTNODENAME);
|
||||||
if (rc != IXML_SUCCESS) {
|
if (rc != IXML_SUCCESS) {
|
||||||
ixmlDocument_free(newDoc);
|
ixmlDocument_free(newDoc);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
newDoc->n.nodeType = eDOCUMENT_NODE;
|
newDoc->n.nodeType = eDOCUMENT_NODE;
|
||||||
|
|
||||||
return newDoc;
|
return newDoc;
|
||||||
@@ -916,6 +934,8 @@ static IXML_Node *ixmlNode_cloneNodeTreeRecursive(
|
|||||||
switch (nodeptr->nodeType) {
|
switch (nodeptr->nodeType) {
|
||||||
case eELEMENT_NODE:
|
case eELEMENT_NODE:
|
||||||
newElement = ixmlNode_cloneElement((IXML_Element *)nodeptr);
|
newElement = ixmlNode_cloneElement((IXML_Element *)nodeptr);
|
||||||
|
if (newElement == NULL)
|
||||||
|
return NULL;
|
||||||
newElement->n.firstAttr = ixmlNode_cloneNodeTreeRecursive(
|
newElement->n.firstAttr = ixmlNode_cloneNodeTreeRecursive(
|
||||||
nodeptr->firstAttr, deep);
|
nodeptr->firstAttr, deep);
|
||||||
if (deep) {
|
if (deep) {
|
||||||
@@ -936,6 +956,8 @@ static IXML_Node *ixmlNode_cloneNodeTreeRecursive(
|
|||||||
|
|
||||||
case eATTRIBUTE_NODE:
|
case eATTRIBUTE_NODE:
|
||||||
newAttr = ixmlNode_cloneAttr((IXML_Attr *)nodeptr);
|
newAttr = ixmlNode_cloneAttr((IXML_Attr *)nodeptr);
|
||||||
|
if (newAttr == NULL)
|
||||||
|
return NULL;
|
||||||
nextSib = ixmlNode_cloneNodeTreeRecursive(nodeptr->nextSibling, deep);
|
nextSib = ixmlNode_cloneNodeTreeRecursive(nodeptr->nextSibling, deep);
|
||||||
newAttr->n.nextSibling = nextSib;
|
newAttr->n.nextSibling = nextSib;
|
||||||
if (nextSib != NULL) {
|
if (nextSib != NULL) {
|
||||||
@@ -954,7 +976,9 @@ static IXML_Node *ixmlNode_cloneNodeTreeRecursive(
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case eDOCUMENT_NODE:
|
case eDOCUMENT_NODE:
|
||||||
newDoc = ixmlNode_cloneDoc((IXML_Document *)nodeptr);
|
newDoc = ixmlNode_newDoc();
|
||||||
|
if (newDoc == NULL)
|
||||||
|
return NULL;
|
||||||
newNode = (IXML_Node *)newDoc;
|
newNode = (IXML_Node *)newDoc;
|
||||||
if (deep) {
|
if (deep) {
|
||||||
newNode->firstChild = ixmlNode_cloneNodeTreeRecursive(
|
newNode->firstChild = ixmlNode_cloneNodeTreeRecursive(
|
||||||
@@ -1001,6 +1025,8 @@ static IXML_Node *ixmlNode_cloneNodeTree(
|
|||||||
switch (nodeptr->nodeType) {
|
switch (nodeptr->nodeType) {
|
||||||
case eELEMENT_NODE:
|
case eELEMENT_NODE:
|
||||||
newElement = ixmlNode_cloneElement((IXML_Element *)nodeptr);
|
newElement = ixmlNode_cloneElement((IXML_Element *)nodeptr);
|
||||||
|
if (newElement == NULL)
|
||||||
|
return NULL;
|
||||||
newElement->n.firstAttr = ixmlNode_cloneNodeTreeRecursive(nodeptr->firstAttr, deep);
|
newElement->n.firstAttr = ixmlNode_cloneNodeTreeRecursive(nodeptr->firstAttr, deep);
|
||||||
if (deep) {
|
if (deep) {
|
||||||
newElement->n.firstChild = ixmlNode_cloneNodeTreeRecursive(
|
newElement->n.firstChild = ixmlNode_cloneNodeTreeRecursive(
|
||||||
@@ -1041,6 +1067,7 @@ static IXML_Node *ixmlNode_cloneNodeTree(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* by spec, the duplicate node has no parent */
|
/* by spec, the duplicate node has no parent */
|
||||||
|
if (newNode != NULL)
|
||||||
newNode->parentNode = NULL;
|
newNode->parentNode = NULL;
|
||||||
|
|
||||||
return newNode;
|
return newNode;
|
||||||
@@ -1112,7 +1139,8 @@ IXML_NamedNodeMap *ixmlNode_getAttributes(IXML_Node *nodeptr)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nodeptr->nodeType == eELEMENT_NODE) {
|
switch(nodeptr->nodeType) {
|
||||||
|
case eELEMENT_NODE:
|
||||||
returnNamedNodeMap = (IXML_NamedNodeMap *)malloc(sizeof(IXML_NamedNodeMap));
|
returnNamedNodeMap = (IXML_NamedNodeMap *)malloc(sizeof(IXML_NamedNodeMap));
|
||||||
if(returnNamedNodeMap == NULL) {
|
if(returnNamedNodeMap == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
@@ -1130,7 +1158,7 @@ IXML_NamedNodeMap *ixmlNode_getAttributes(IXML_Node *nodeptr)
|
|||||||
tempNode = tempNode->nextSibling;
|
tempNode = tempNode->nextSibling;
|
||||||
}
|
}
|
||||||
return returnNamedNodeMap;
|
return returnNamedNodeMap;
|
||||||
} else {
|
default:
|
||||||
/* if not an ELEMENT_NODE */
|
/* if not an ELEMENT_NODE */
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@@ -1150,8 +1178,13 @@ BOOL ixmlNode_hasChildNodes(IXML_Node *nodeptr)
|
|||||||
BOOL ixmlNode_hasAttributes(IXML_Node *nodeptr)
|
BOOL ixmlNode_hasAttributes(IXML_Node *nodeptr)
|
||||||
{
|
{
|
||||||
if (nodeptr != NULL) {
|
if (nodeptr != NULL) {
|
||||||
if (nodeptr->nodeType == eELEMENT_NODE && nodeptr->firstAttr != NULL) {
|
switch (nodeptr->nodeType) {
|
||||||
|
case eELEMENT_NODE:
|
||||||
|
if (nodeptr->firstAttr != NULL)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -57,17 +58,17 @@ IXML_Node *ixmlNodeList_item(
|
|||||||
IXML_NodeList *next;
|
IXML_NodeList *next;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
// if the list ptr is NULL
|
/* if the list ptr is NULL */
|
||||||
if (nList == NULL) {
|
if (nList == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
// if index is more than list length
|
/* if index is more than list length */
|
||||||
if (index > ixmlNodeList_length(nList) - 1) {
|
if (index > ixmlNodeList_length(nList) - 1lu) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
next = nList;
|
next = nList;
|
||||||
for (i = 0; i < index && next != NULL; ++i) {
|
for (i = 0u; i < index && next != NULL; ++i) {
|
||||||
next = next->next;
|
next = next->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -93,7 +94,7 @@ int ixmlNodeList_addToNodeList(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (*nList == NULL) {
|
if (*nList == NULL) {
|
||||||
// nodelist is empty
|
/* nodelist is empty */
|
||||||
*nList = (IXML_NodeList *)malloc(sizeof (IXML_NodeList));
|
*nList = (IXML_NodeList *)malloc(sizeof (IXML_NodeList));
|
||||||
if (*nList == NULL) {
|
if (*nList == NULL) {
|
||||||
return IXML_INSUFFICIENT_MEMORY;
|
return IXML_INSUFFICIENT_MEMORY;
|
||||||
@@ -127,7 +128,7 @@ int ixmlNodeList_addToNodeList(
|
|||||||
unsigned long ixmlNodeList_length(IXML_NodeList *nList)
|
unsigned long ixmlNodeList_length(IXML_NodeList *nList)
|
||||||
{
|
{
|
||||||
IXML_NodeList *list;
|
IXML_NodeList *list;
|
||||||
unsigned long length = 0;
|
unsigned long length = 0lu;
|
||||||
|
|
||||||
list = nList;
|
list = nList;
|
||||||
while (list != NULL) {
|
while (list != NULL) {
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
Version: 1.6.8
|
Version: 1.6.16
|
||||||
Summary: Universal Plug and Play (UPnP) SDK
|
Summary: Universal Plug and Play (UPnP) SDK
|
||||||
Name: libupnp
|
Name: libupnp
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
# $Id: Makefile.am,v 1.2 2006/02/27 21:38:56 r3mi Exp $
|
|
||||||
#
|
#
|
||||||
# "Makefile.am" for "libupnp/threadutil"
|
# "Makefile.am" for "libupnp/threadutil"
|
||||||
#
|
#
|
||||||
# (C) Copyright 2005 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net>
|
# (C) Copyright 2005 Remi Turboult <r3mi@users.sourceforge.net>
|
||||||
#
|
#
|
||||||
|
|
||||||
AM_CPPFLAGS = -I$(srcdir)/inc -I$(srcdir)/src/inc
|
AM_CPPFLAGS = -I$(srcdir)/inc -I$(srcdir)/src/inc
|
||||||
@@ -19,12 +18,21 @@ lib_LTLIBRARIES = libthreadutil.la
|
|||||||
libthreadutil_la_LDFLAGS = -version-info $(LT_VERSION_THREADUTIL)
|
libthreadutil_la_LDFLAGS = -version-info $(LT_VERSION_THREADUTIL)
|
||||||
|
|
||||||
libthreadutil_la_SOURCES = \
|
libthreadutil_la_SOURCES = \
|
||||||
src/FreeList.c src/LinkedList.c \
|
inc/FreeList.h \
|
||||||
src/ThreadPool.c src/TimerThread.c
|
src/FreeList.c \
|
||||||
|
inc/LinkedList.h \
|
||||||
|
src/LinkedList.c \
|
||||||
|
inc/ThreadPool.h \
|
||||||
|
src/ThreadPool.c \
|
||||||
|
inc/TimerThread.h \
|
||||||
|
src/TimerThread.c
|
||||||
|
|
||||||
upnpincludedir = $(includedir)/upnp
|
upnpincludedir = $(includedir)/upnp
|
||||||
upnpinclude_HEADERS = \
|
|
||||||
inc/FreeList.h inc/LinkedList.h \
|
upnpinclude_HEADERS = \
|
||||||
inc/ThreadPool.h inc/TimerThread.h \
|
inc/ithread.h \
|
||||||
inc/ithread.h
|
inc/FreeList.h \
|
||||||
|
inc/LinkedList.h \
|
||||||
|
inc/ThreadPool.h \
|
||||||
|
inc/TimerThread.h
|
||||||
|
|
||||||
|
|||||||
@@ -29,118 +29,99 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef FREE_LIST_H
|
#ifndef FREE_LIST_H
|
||||||
#define FREE_LIST_H
|
#define FREE_LIST_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#include "ithread.h"
|
#include "ithread.h"
|
||||||
|
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Name: FreeListNode
|
* Free list node. points to next free item.
|
||||||
*
|
* Memory for node is borrowed from allocated items.
|
||||||
* Description:
|
* \internal
|
||||||
* free list node. points to next free item.
|
*/
|
||||||
* memory for node is borrowed from allocated items.
|
|
||||||
* Internal Use Only.
|
|
||||||
*****************************************************************************/
|
|
||||||
typedef struct FREELISTNODE
|
typedef struct FREELISTNODE
|
||||||
{
|
{
|
||||||
struct FREELISTNODE *next;
|
struct FREELISTNODE *next;
|
||||||
} FreeListNode;
|
} FreeListNode;
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
|
||||||
* Name: FreeList
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Stores head and size of free list, as well as mutex for protection.
|
* Stores head and size of free list, as well as mutex for protection.
|
||||||
* Internal Use Only.
|
* \internal
|
||||||
*****************************************************************************/
|
*/
|
||||||
typedef struct FREELIST
|
typedef struct FREELIST
|
||||||
{
|
{
|
||||||
FreeListNode *head;
|
FreeListNode *head;
|
||||||
size_t element_size;
|
size_t element_size;
|
||||||
int maxFreeListLength;
|
int maxFreeListLength;
|
||||||
int freeListLength;
|
int freeListLength;
|
||||||
|
} FreeList;
|
||||||
|
|
||||||
}FreeList;
|
/*!
|
||||||
|
* \brief Initializes Free List.
|
||||||
/****************************************************************************
|
|
||||||
* Function: FreeListInit
|
|
||||||
*
|
*
|
||||||
* Description:
|
* Must be called first and only once for FreeList.
|
||||||
* Initializes Free List. Must be called first.
|
*
|
||||||
* And only once for FreeList.
|
* \return:
|
||||||
* Parameters:
|
* \li \c 0 on success.
|
||||||
* free_list - must be valid, non null, pointer to a linked list.
|
* \li \c EINVAL on failure.
|
||||||
* size_t - size of elements to store in free list
|
*/
|
||||||
* maxFreeListSize - max size that the free list can grow to
|
int FreeListInit(
|
||||||
* before returning memory to O.S.
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* Returns:
|
FreeList *free_list,
|
||||||
* 0 on success. Nonzero on failure.
|
/*! Size of elements to store in free list. */
|
||||||
* Always returns 0.
|
|
||||||
*****************************************************************************/
|
|
||||||
int FreeListInit(FreeList *free_list,
|
|
||||||
size_t elementSize,
|
size_t elementSize,
|
||||||
int maxFreeListSize);
|
/*! Max size that the free list can grow to before returning
|
||||||
|
* memory to O.S. */
|
||||||
|
int maxFreeListLength);
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: FreeListAlloc
|
* \brief Allocates chunk of set size.
|
||||||
*
|
*
|
||||||
* Description:
|
* If a free item is available in the list, returnes the stored item,
|
||||||
* Allocates chunk of set size.
|
* otherwise calls the O.S. to allocate memory.
|
||||||
* 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);
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Function: FreeListFree
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Non NULL on success. NULL on failure.
|
||||||
* Returns an item to the Free List.
|
*/
|
||||||
* If the free list is smaller than the max size than
|
void *FreeListAlloc(
|
||||||
* adds the item to the free list.
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* Otherwise returns the item to the O.S.
|
FreeList *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 FreeListFree (FreeList *free_list,void * element);
|
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: FreeListDestroy
|
* \brief Returns an item to the Free List.
|
||||||
*
|
*
|
||||||
* Description:
|
* If the free list is smaller than the max size then adds the item to the
|
||||||
* Releases the resources stored with the free list.
|
* free list, otherwise returns the item to the O.S.
|
||||||
* Parameters:
|
*
|
||||||
* free_list - must be valid, non null, pointer to a linked list.
|
* \return:
|
||||||
* Returns:
|
* \li \c 0 on success.
|
||||||
* 0 on success. Nonzero on failure.
|
* \li \c EINVAL on failure.
|
||||||
* Always returns 0.
|
*/
|
||||||
*****************************************************************************/
|
int FreeListFree(
|
||||||
int FreeListDestroy (FreeList *free_list);
|
/*! Must be valid, non null, pointer to a free list. */
|
||||||
|
FreeList *free_list,
|
||||||
|
/*! Must be a pointer allocated by FreeListAlloc. */
|
||||||
|
void *element);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Releases the resources stored with the free list.
|
||||||
|
*
|
||||||
|
* \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);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,58 +29,34 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef LINKED_LIST_H
|
#ifndef LINKED_LIST_H
|
||||||
#define LINKED_LIST_H
|
#define LINKED_LIST_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "FreeList.h"
|
#include "FreeList.h"
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#define EOUTOFMEM (-7 & 1<<29)
|
#define EOUTOFMEM (-7 & 1<<29)
|
||||||
|
|
||||||
|
|
||||||
#define FREELISTSIZE 100
|
#define FREELISTSIZE 100
|
||||||
#define LIST_SUCCESS 1
|
#define LIST_SUCCESS 1
|
||||||
#define LIST_FAIL 0
|
#define LIST_FAIL 0
|
||||||
|
|
||||||
|
/*! Function for freeing list items. */
|
||||||
/****************************************************************************
|
|
||||||
* Name: free_routine
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Function for freeing list items
|
|
||||||
*****************************************************************************/
|
|
||||||
typedef void (*free_function)(void *arg);
|
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);
|
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
|
typedef struct LISTNODE
|
||||||
{
|
{
|
||||||
struct LISTNODE *prev;
|
struct LISTNODE *prev;
|
||||||
@@ -88,14 +64,10 @@ typedef struct LISTNODE
|
|||||||
void *item;
|
void *item;
|
||||||
} ListNode;
|
} ListNode;
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* Linked list (no protection).
|
||||||
* Name: LinkedList
|
|
||||||
*
|
*
|
||||||
* Description:
|
* Because this is for internal use, parameters are NOT checked for validity.
|
||||||
* 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 first item of the list is stored at node: head->next
|
||||||
* The last item of the list is stored at node: tail->prev
|
* The last item of the list is stored at node: tail->prev
|
||||||
* If head->next=tail, then list is empty.
|
* If head->next=tail, then list is empty.
|
||||||
@@ -103,249 +75,211 @@ typedef struct LISTNODE
|
|||||||
*
|
*
|
||||||
* LinkedList g;
|
* LinkedList g;
|
||||||
* ListNode *temp = NULL;
|
* 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
|
typedef struct LINKEDLIST
|
||||||
{
|
{
|
||||||
ListNode head; /* head, first item is stored at: head->next */
|
/*! head, first item is stored at: head->next */
|
||||||
ListNode tail; /* tail, last item is stored at: tail->prev */
|
ListNode head;
|
||||||
long size; /* size of list */
|
/*! tail, last item is stored at: tail->prev */
|
||||||
FreeList freeNodeList; /* free list to use */
|
ListNode tail;
|
||||||
free_function free_func; /* free function to use */
|
/*! size of list */
|
||||||
cmp_routine cmp_func; /* compare function to use */
|
long size;
|
||||||
|
/*! free list to use */
|
||||||
|
FreeList freeNodeList;
|
||||||
|
/*! free function to use */
|
||||||
|
free_function free_func;
|
||||||
|
/*! compare function to use */
|
||||||
|
cmp_routine cmp_func;
|
||||||
} LinkedList;
|
} LinkedList;
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Initializes LinkedList. Must be called first and only once for List.
|
||||||
* Function: ListInit
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return
|
||||||
* Initializes LinkedList. Must be called first.
|
* \li \c 0 on success.
|
||||||
* And only once for List.
|
* \li \c EOUTOFMEM on failure.
|
||||||
* Parameters:
|
*/
|
||||||
* list - must be valid, non null, pointer to a linked list.
|
int ListInit(
|
||||||
* cmp_func - function used to compare items. (May be NULL)
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* free_func - function used to free items. (May be NULL)
|
LinkedList *list,
|
||||||
* Returns:
|
/*! Function used to compare items. (May be NULL). */
|
||||||
* 0 on success, EOUTOFMEM on failure.
|
cmp_routine cmp_func,
|
||||||
*****************************************************************************/
|
/*! Function used to free items. (May be NULL). */
|
||||||
int ListInit(LinkedList *list,cmp_routine cmp_func, free_function free_func);
|
free_function free_func);
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Adds a node to the head of the list. Node gets immediately after
|
||||||
* Function: ListAddHead
|
* list head.
|
||||||
*
|
*
|
||||||
* 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:
|
* Precondition:
|
||||||
* The list has been initialized.
|
* The list has been initialized.
|
||||||
*****************************************************************************/
|
|
||||||
ListNode *ListAddHead(LinkedList *list, void *item);
|
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Function: ListAddTail
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return The pointer to the ListNode on success, NULL on failure.
|
||||||
* Adds a node to the tail of the list.
|
*/
|
||||||
* Node gets added immediately before list.tail.
|
ListNode *ListAddHead(
|
||||||
* Parameters:
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* LinkedList *list - must be valid, non null, pointer to a linked list.
|
LinkedList *list,
|
||||||
* void * item - item to be added
|
/*! Item to be added. */
|
||||||
* Returns:
|
void *item);
|
||||||
* 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 to the tail of the list. Node gets added immediately
|
||||||
|
* before list.tail.
|
||||||
|
*
|
||||||
|
* 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);
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: ListAddAfter
|
* \brief Adds a node after the specified node. Node gets added immediately
|
||||||
|
* after bnode.
|
||||||
*
|
*
|
||||||
* Description:
|
* Precondition: The list has been initialized.
|
||||||
* Adds a node after the specified node.
|
*
|
||||||
* Node gets added immediately after bnode.
|
* \return The pointer to the ListNode on success, NULL on failure.
|
||||||
* Parameters:
|
*/
|
||||||
* LinkedList *list - must be valid, non null, pointer to a linked list.
|
ListNode *ListAddAfter(
|
||||||
* void * item - item to be added
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* ListNode * bnode - node to add after
|
LinkedList *list,
|
||||||
* Returns:
|
/*! Item to be added. */
|
||||||
* The pointer to the ListNode on success, NULL on failure.
|
void *item,
|
||||||
* Precondition:
|
/*! Node to add after. */
|
||||||
* The list has been initialized.
|
ListNode *bnode);
|
||||||
*****************************************************************************/
|
|
||||||
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);
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: ListAddBefore
|
* \brief Removes a node from the list. The memory for the node is freed.
|
||||||
*
|
*
|
||||||
* Description:
|
* Precondition: The list has been initialized.
|
||||||
* Adds a node before the specified node.
|
*
|
||||||
* Node gets added immediately before anode.
|
* \return The pointer to the item stored in the node or NULL if the item
|
||||||
* Parameters:
|
* is freed.
|
||||||
* LinkedList *list - must be valid, non null, pointer to a linked list.
|
*/
|
||||||
* ListNode * anode - node to add the in front of.
|
void *ListDelNode(
|
||||||
* void * item - item to be added
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* Returns:
|
LinkedList *list,
|
||||||
* The pointer to the ListNode on success, NULL on failure.
|
/*! Node to delete. */
|
||||||
* Precondition:
|
ListNode *dnode,
|
||||||
* The list has been initialized.
|
/*! if !0 then item is freed using free function. If 0 (or free
|
||||||
*****************************************************************************/
|
* function is NULL) then item is not freed. */
|
||||||
ListNode *ListAddBefore(LinkedList *list,void *item, ListNode *anode);
|
int freeItem);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \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);
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: ListDelNode
|
* \brief Returns the head of the list.
|
||||||
*
|
*
|
||||||
* Description:
|
* Precondition: The list has been initialized.
|
||||||
* Removes a node from the list
|
*
|
||||||
* The memory for the node is freed.
|
* \return The head of the list. NULL if list is empty.
|
||||||
* Parameters:
|
*/
|
||||||
* LinkedList *list - must be valid, non null, pointer to a linked list.
|
ListNode *ListHead(
|
||||||
* ListNode *dnode - done to delete.
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* freeItem - if !0 then item is freed using free function.
|
LinkedList *list);
|
||||||
* 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.
|
||||||
|
*
|
||||||
|
* Precondition: The list has been initialized.
|
||||||
|
*
|
||||||
|
* \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);
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: ListDestroy
|
* \brief Returns the next item in the list.
|
||||||
*
|
*
|
||||||
* Description:
|
* Precondition: The list has been initialized.
|
||||||
* Removes all memory associated with list nodes.
|
|
||||||
* Does not free LinkedList *list.
|
|
||||||
*
|
*
|
||||||
* Parameters:
|
* \return The next item in the list. NULL if there are no more items in list.
|
||||||
* LinkedList *list - must be valid, non null, pointer to a linked list.
|
*/
|
||||||
* freeItem - if !0 then items are freed using the free_function.
|
ListNode *ListNext(
|
||||||
* if 0 (or free function is NULL) then items are not freed.
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* Returns:
|
LinkedList *list,
|
||||||
* 0 on success. Always returns 0.
|
/*! Node from the list. */
|
||||||
* Precondition:
|
ListNode *node);
|
||||||
* The list has been initialized.
|
|
||||||
*****************************************************************************/
|
|
||||||
int ListDestroy(LinkedList *list, int freeItem);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Returns the previous item in the list.
|
||||||
|
*
|
||||||
|
* Precondition: The list has been initialized.
|
||||||
|
*
|
||||||
|
* \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);
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: ListHead
|
* \brief Finds the specified item in the list.
|
||||||
*
|
*
|
||||||
* 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);
|
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* 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
|
* Uses the compare function specified in ListInit. If compare function
|
||||||
* is NULL then compares items as pointers.
|
* 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);
|
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Function: ListSize
|
|
||||||
*
|
*
|
||||||
* Description:
|
* Precondition: The list has been initialized.
|
||||||
* Returns the size of the list.
|
*
|
||||||
* Parameters:
|
* \return The node containing the item. NULL if no node contains the item.
|
||||||
* LinkedList *list - must be valid, non null, pointer to a linked list.
|
*/
|
||||||
|
ListNode* ListFind(
|
||||||
* Returns:
|
/*! Must be valid, non null, pointer to a linked list. */
|
||||||
* The number of items in the list.
|
LinkedList *list,
|
||||||
* Precondition:
|
/*! The node to start from, NULL if to start from beginning. */
|
||||||
* The list has been initialized.
|
ListNode *start,
|
||||||
*****************************************************************************/
|
/*! The item to search for. */
|
||||||
int ListSize(LinkedList* list);
|
void *item);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Returns the size of the list.
|
||||||
|
*
|
||||||
|
* 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);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,26 +30,21 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef THREADPOOL_H
|
#ifndef THREADPOOL_H
|
||||||
#define THREADPOOL_H
|
#define THREADPOOL_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "FreeList.h"
|
#include "FreeList.h"
|
||||||
#include "ithread.h"
|
#include "ithread.h"
|
||||||
#include "LinkedList.h"
|
#include "LinkedList.h"
|
||||||
#include "UpnpInet.h"
|
#include "UpnpInet.h"
|
||||||
#include "UpnpGlobal.h" /* for UPNP_INLINE, EXPORT_SPEC */
|
#include "UpnpGlobal.h" /* for UPNP_INLINE, EXPORT_SPEC */
|
||||||
|
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
struct timezone
|
struct timezone
|
||||||
@@ -63,82 +59,63 @@
|
|||||||
#if defined(__OSX__) || defined(__APPLE__) || defined(__NetBSD__)
|
#if defined(__OSX__) || defined(__APPLE__) || defined(__NetBSD__)
|
||||||
#include <sys/resource.h> /* for setpriority() */
|
#include <sys/resource.h> /* for setpriority() */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*! Size of job free list */
|
/*! Size of job free list */
|
||||||
#define JOBFREELISTSIZE 100
|
#define JOBFREELISTSIZE 100
|
||||||
|
|
||||||
|
|
||||||
#define INFINITE_THREADS -1
|
#define INFINITE_THREADS -1
|
||||||
|
|
||||||
|
|
||||||
#define EMAXTHREADS (-8 & 1<<29)
|
#define EMAXTHREADS (-8 & 1<<29)
|
||||||
|
|
||||||
|
|
||||||
/*! Invalid Policy */
|
/*! Invalid Policy */
|
||||||
#define INVALID_POLICY (-9 & 1<<29)
|
#define INVALID_POLICY (-9 & 1<<29)
|
||||||
|
|
||||||
|
|
||||||
/*! Invalid JOB Id */
|
/*! Invalid JOB Id */
|
||||||
#define INVALID_JOB_ID (-2 & 1<<29)
|
#define INVALID_JOB_ID (-2 & 1<<29)
|
||||||
|
|
||||||
|
|
||||||
typedef enum duration {
|
typedef enum duration {
|
||||||
SHORT_TERM,
|
SHORT_TERM,
|
||||||
PERSISTENT
|
PERSISTENT
|
||||||
} Duration;
|
} Duration;
|
||||||
|
|
||||||
|
|
||||||
typedef enum priority {
|
typedef enum priority {
|
||||||
LOW_PRIORITY,
|
LOW_PRIORITY,
|
||||||
MED_PRIORITY,
|
MED_PRIORITY,
|
||||||
HIGH_PRIORITY
|
HIGH_PRIORITY
|
||||||
} ThreadPriority;
|
} ThreadPriority;
|
||||||
|
|
||||||
|
|
||||||
/*! default priority used by TPJobInit */
|
/*! default priority used by TPJobInit */
|
||||||
#define DEFAULT_PRIORITY MED_PRIORITY
|
#define DEFAULT_PRIORITY MED_PRIORITY
|
||||||
|
|
||||||
|
|
||||||
/*! default minimum used by TPAttrInit */
|
/*! default minimum used by TPAttrInit */
|
||||||
#define DEFAULT_MIN_THREADS 1
|
#define DEFAULT_MIN_THREADS 1
|
||||||
|
|
||||||
|
|
||||||
/*! default max used by TPAttrInit */
|
/*! default max used by TPAttrInit */
|
||||||
#define DEFAULT_MAX_THREADS 10
|
#define DEFAULT_MAX_THREADS 10
|
||||||
|
|
||||||
|
|
||||||
/*! default stack size used by TPAttrInit */
|
/*! default stack size used by TPAttrInit */
|
||||||
#define DEFAULT_STACK_SIZE 0
|
#define DEFAULT_STACK_SIZE 0u
|
||||||
|
|
||||||
|
|
||||||
/*! default jobs per thread used by TPAttrInit */
|
/*! default jobs per thread used by TPAttrInit */
|
||||||
#define DEFAULT_JOBS_PER_THREAD 10
|
#define DEFAULT_JOBS_PER_THREAD 10
|
||||||
|
|
||||||
|
|
||||||
/*! default starvation time used by TPAttrInit */
|
/*! default starvation time used by TPAttrInit */
|
||||||
#define DEFAULT_STARVATION_TIME 500
|
#define DEFAULT_STARVATION_TIME 500
|
||||||
|
|
||||||
|
|
||||||
/*! default idle time used by TPAttrInit */
|
/*! default idle time used by TPAttrInit */
|
||||||
#define DEFAULT_IDLE_TIME 10 * 1000
|
#define DEFAULT_IDLE_TIME 10 * 1000
|
||||||
|
|
||||||
|
|
||||||
/*! default free routine used TPJobInit */
|
/*! default free routine used TPJobInit */
|
||||||
#define DEFAULT_FREE_ROUTINE NULL
|
#define DEFAULT_FREE_ROUTINE NULL
|
||||||
|
|
||||||
|
|
||||||
/*! default max jobs used TPAttrInit */
|
/*! default max jobs used TPAttrInit */
|
||||||
#define DEFAULT_MAX_JOBS_TOTAL 100
|
#define DEFAULT_MAX_JOBS_TOTAL 100
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Statistics.
|
* \brief Statistics.
|
||||||
*
|
*
|
||||||
@@ -146,88 +123,54 @@ typedef enum priority {
|
|||||||
*/
|
*/
|
||||||
#define STATS 1
|
#define STATS 1
|
||||||
|
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define DEBUG 1
|
#define DEBUG 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
typedef int PolicyType;
|
typedef int PolicyType;
|
||||||
|
|
||||||
|
|
||||||
#define DEFAULT_POLICY SCHED_OTHER
|
#define DEFAULT_POLICY SCHED_OTHER
|
||||||
|
|
||||||
|
/*! Function for freeing a thread argument. */
|
||||||
/****************************************************************************
|
|
||||||
* Name: free_routine
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Function for freeing a thread argument
|
|
||||||
*****************************************************************************/
|
|
||||||
typedef void (*free_routine)(void *arg);
|
typedef void (*free_routine)(void *arg);
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
/*! Attributes for thread pool. Used to set and change parameters of thread
|
||||||
* Name: ThreadPoolAttr
|
* pool. */
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Attributes for thread pool. Used to set and change parameters of
|
|
||||||
* thread pool
|
|
||||||
*****************************************************************************/
|
|
||||||
typedef struct THREADPOOLATTR
|
typedef struct THREADPOOLATTR
|
||||||
{
|
{
|
||||||
/* minThreads, ThreadPool will always maintain at least this many threads */
|
/*! ThreadPool will always maintain at least this many threads. */
|
||||||
int minThreads;
|
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;
|
int maxThreads;
|
||||||
|
/*! This is the minimum stack size allocated for each thread. */
|
||||||
/* stackSize (in bytes), this is the minimum stack size allocated for each
|
|
||||||
* thread */
|
|
||||||
size_t stackSize;
|
size_t stackSize;
|
||||||
|
/*! This is the maximum time a thread will
|
||||||
/* maxIdleTime (in milliseconds) this is the maximum time a thread will
|
* remain idle before dying (in milliseconds). */
|
||||||
* remain idle before dying */
|
|
||||||
int maxIdleTime;
|
int maxIdleTime;
|
||||||
|
/*! Jobs per thread to maintain. */
|
||||||
/* jobs per thread to maintain */
|
|
||||||
int jobsPerThread;
|
int jobsPerThread;
|
||||||
|
/*! Maximum number of jobs that can be queued totally. */
|
||||||
/* maximum number of jobs that can be queued totally. */
|
|
||||||
int maxJobsTotal;
|
int maxJobsTotal;
|
||||||
|
/*! the time a low priority or med priority job waits before getting
|
||||||
/* the time a low priority or med priority job waits before getting bumped
|
* bumped up a priority (in milliseconds). */
|
||||||
* up a priority (in milliseconds) */
|
|
||||||
int starvationTime;
|
int starvationTime;
|
||||||
|
/*! scheduling policy to use. */
|
||||||
/* scheduling policy to use */
|
|
||||||
PolicyType schedPolicy;
|
PolicyType schedPolicy;
|
||||||
} ThreadPoolAttr;
|
} ThreadPoolAttr;
|
||||||
|
|
||||||
|
/*! Internal ThreadPool Job. */
|
||||||
/****************************************************************************
|
|
||||||
* Name: ThreadPool
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Internal ThreadPool Job
|
|
||||||
*****************************************************************************/
|
|
||||||
typedef struct THREADPOOLJOB
|
typedef struct THREADPOOLJOB
|
||||||
{
|
{
|
||||||
start_routine func;
|
start_routine func;
|
||||||
void *arg;
|
void *arg;
|
||||||
free_routine free_func;
|
free_routine free_func;
|
||||||
struct timeval requestTime;
|
struct timeval requestTime;
|
||||||
int priority;
|
ThreadPriority priority;
|
||||||
int jobId;
|
int jobId;
|
||||||
} ThreadPoolJob;
|
} ThreadPoolJob;
|
||||||
|
|
||||||
|
/*! Structure to hold statistics. */
|
||||||
/****************************************************************************
|
|
||||||
* Name: ThreadPoolStats
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Structure to hold statistics
|
|
||||||
*****************************************************************************/
|
|
||||||
typedef struct TPOOLSTATS
|
typedef struct TPOOLSTATS
|
||||||
{
|
{
|
||||||
double totalTimeHQ;
|
double totalTimeHQ;
|
||||||
@@ -251,7 +194,6 @@ typedef struct TPOOLSTATS
|
|||||||
int currentJobsMQ;
|
int currentJobsMQ;
|
||||||
} ThreadPoolStats;
|
} ThreadPoolStats;
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief A thread pool similar to the thread pool in the UPnP SDK.
|
* \brief A thread pool similar to the thread pool in the UPnP SDK.
|
||||||
*
|
*
|
||||||
@@ -269,374 +211,326 @@ typedef struct TPOOLSTATS
|
|||||||
*/
|
*/
|
||||||
typedef struct THREADPOOL
|
typedef struct THREADPOOL
|
||||||
{
|
{
|
||||||
ithread_mutex_t mutex; /* mutex to protect job qs */
|
/*! Mutex to protect job qs. */
|
||||||
ithread_cond_t condition; /* condition variable to signal Q */
|
ithread_mutex_t mutex;
|
||||||
ithread_cond_t start_and_shutdown; /* condition variable for start and stop */
|
/*! Condition variable to signal Q. */
|
||||||
int lastJobId; /* ids for jobs */
|
ithread_cond_t condition;
|
||||||
int shutdown; /* whether or not we are shutting down */
|
/*! Condition variable for start and stop. */
|
||||||
int totalThreads; /* total number of threads */
|
ithread_cond_t start_and_shutdown;
|
||||||
int busyThreads; /* number of threads that are currently executing jobs */
|
/*! ids for jobs */
|
||||||
int persistentThreads; /* number of persistent threads */
|
int lastJobId;
|
||||||
FreeList jobFreeList; /* free list of jobs */
|
/*! whether or not we are shutting down */
|
||||||
LinkedList lowJobQ; /* low priority job Q */
|
int shutdown;
|
||||||
LinkedList medJobQ; /* med priority job Q */
|
/*! total number of threads */
|
||||||
LinkedList highJobQ; /* high priority job Q */
|
int totalThreads;
|
||||||
ThreadPoolJob *persistentJob; /* persistent job */
|
/*! flag that's set when waiting for a new worker thread to start */
|
||||||
ThreadPoolAttr attr; /* thread pool attributes */
|
int pendingWorkerThreadStart;
|
||||||
|
/*! number of threads that are currently executing jobs */
|
||||||
/* statistics */
|
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 */
|
||||||
ThreadPoolStats stats;
|
ThreadPoolStats stats;
|
||||||
} ThreadPool;
|
} 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);
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: ThreadPoolInit
|
* \brief Adds a persistent job to the thread pool.
|
||||||
*
|
*
|
||||||
* Description:
|
* Job will be run as soon as possible. Call will block until job is scheduled.
|
||||||
* 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:
|
* \return
|
||||||
*
|
* \li \c 0 on success.
|
||||||
* minWorkerThreads - minimum number of worker threads
|
* \li \c EOUTOFMEM not enough memory to add job.
|
||||||
* thread pool will never have less than this
|
* \li \c EMAXTHREADS not enough threads to add persistent job.
|
||||||
* number of threads.
|
*/
|
||||||
* maxWorkerThreads - maximum number of worker threads
|
int ThreadPoolAddPersistent(
|
||||||
* thread pool will never have more than this
|
/*! Valid thread pool pointer. */
|
||||||
* number of threads.
|
ThreadPool*tp,
|
||||||
* maxIdleTime - maximum time that a worker thread will spend
|
/*! Valid thread pool job. */
|
||||||
* idle. If a worker is idle longer than this
|
ThreadPoolJob *job,
|
||||||
* time and there are more than the min
|
/*! . */
|
||||||
* number of workers running, than the
|
int *jobId);
|
||||||
* 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 Gets the current set of attributes associated with the thread pool.
|
||||||
* Function: ThreadPoolAddPersistent
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return
|
||||||
* Adds a persistent job to the thread pool.
|
* \li \c 0 on success, nonzero on failure.
|
||||||
* Job will be run as soon as possible.
|
*/
|
||||||
* Call will block until job is scheduled.
|
int ThreadPoolGetAttr(
|
||||||
* Parameters:
|
/*! valid thread pool pointer. */
|
||||||
* tp - valid thread pool pointer
|
ThreadPool *tp,
|
||||||
* ThreadPoolJob - valid thread pool job with the following fields:
|
/*! non null pointer to store attributes. */
|
||||||
*
|
ThreadPoolAttr *out);
|
||||||
* 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);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the attributes for the thread pool.
|
||||||
* 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.
|
* Only affects future calculations.
|
||||||
* 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);
|
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Function: ThreadPoolAdd
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return
|
||||||
* Adds a job to the thread pool.
|
* \li \c 0 on success, nonzero on failure.
|
||||||
* Job will be run as soon as possible.
|
* \li \c INVALID_POLICY if policy can not be set.
|
||||||
* Parameters:
|
*/
|
||||||
* tp - valid thread pool pointer
|
int ThreadPoolSetAttr(
|
||||||
* func - ThreadFunction to run
|
/*! valid thread pool pointer. */
|
||||||
* arg - argument to function.
|
ThreadPool *tp,
|
||||||
* priority - priority of job.
|
/*! pointer to attributes, null sets attributes to default. */
|
||||||
* poolid - id of job
|
ThreadPoolAttr *attr);
|
||||||
* 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 Adds a job to the thread pool. Job will be run as soon as possible.
|
||||||
* Function: ThreadPoolRemove
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return
|
||||||
* Removes a job from the thread pool.
|
* \li \c 0 on success, nonzero on failure.
|
||||||
* Can only remove jobs which are not
|
* \li \c EOUTOFMEM if not enough memory to add job.
|
||||||
* currently running.
|
*/
|
||||||
* Parameters:
|
int ThreadPoolAdd(
|
||||||
* tp - valid thread pool pointer
|
/*! valid thread pool pointer. */
|
||||||
* jobid - id of job
|
ThreadPool*tp,
|
||||||
* out - space for removed job.
|
/*! . */
|
||||||
* Returns:
|
ThreadPoolJob *job,
|
||||||
* 0 on success, nonzero on failure.
|
/*! id of job. */
|
||||||
* INVALID_JOB_ID if job not found.
|
int *jobId);
|
||||||
*****************************************************************************/
|
|
||||||
int ThreadPoolRemove(ThreadPool *tp, int jobId, ThreadPoolJob *out);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Removes a job from the thread pool. Can only remove jobs which
|
||||||
/****************************************************************************
|
* are not currently running.
|
||||||
* Function: ThreadPoolShutdown
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return
|
||||||
* Shuts the thread pool down.
|
* \li \c 0 on success, nonzero on failure.
|
||||||
* Waits for all threads to finish.
|
* \li \c INVALID_JOB_ID if job not found.
|
||||||
* May block indefinitely if jobs do not
|
*/
|
||||||
* exit.
|
int ThreadPoolRemove(
|
||||||
* Parameters:
|
/*! valid thread pool pointer. */
|
||||||
* tp - must be valid tp
|
ThreadPool *tp,
|
||||||
* Returns:
|
/*! id of job. */
|
||||||
* 0 on success, nonzero on failure
|
int jobId,
|
||||||
* Always returns 0.
|
/*! space for removed job. */
|
||||||
*****************************************************************************/
|
ThreadPoolJob *out);
|
||||||
int ThreadPoolShutdown(ThreadPool *tp);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Shuts the thread pool down. Waits for all threads to finish.
|
||||||
* Function: TPJobInit
|
* May block indefinitely if jobs do not exit.
|
||||||
*
|
*
|
||||||
* Description:
|
* \return 0 on success, nonzero on failure
|
||||||
* Initializes thread pool job.
|
*/
|
||||||
* Sets the priority to default defined in ThreadPool.h.
|
int ThreadPoolShutdown(
|
||||||
* Sets the free_routine to default defined in ThreadPool.h
|
/*! must be valid tp. */
|
||||||
* Parameters:
|
ThreadPool *tp);
|
||||||
* 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 Initializes thread pool job. Sets the priority to default defined
|
||||||
* Function: TPJobSetPriority
|
* in ThreadPool.h. Sets the free_routine to default defined in ThreadPool.h.
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the max threads for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPJobInit(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* maxThreads - value to set
|
ThreadPoolJob *job,
|
||||||
* Returns:
|
/*! function to run, must be valid. */
|
||||||
* Always returns 0.
|
start_routine func,
|
||||||
*****************************************************************************/
|
/*! argument to pass to function. */
|
||||||
int TPJobSetPriority(ThreadPoolJob *job, ThreadPriority priority);
|
void *arg);
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the max threads for the thread pool attributes.
|
||||||
* Function: TPJobSetFreeFunction
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the max threads for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPJobSetPriority(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* maxThreads - value to set
|
ThreadPoolJob *job,
|
||||||
* Returns:
|
/*! value to set. */
|
||||||
* Always returns 0.
|
ThreadPriority priority);
|
||||||
*****************************************************************************/
|
|
||||||
int TPJobSetFreeFunction(ThreadPoolJob *job, free_routine func);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the max threads for the thread pool attributes.
|
||||||
* Function: TPAttrInit
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Initializes thread pool attributes.
|
*/
|
||||||
* Sets values to defaults defined in ThreadPool.h.
|
int TPJobSetFreeFunction(
|
||||||
* Parameters:
|
/*! must be valid thread pool attributes. */
|
||||||
* attr - must be valid thread pool attributes.
|
ThreadPoolJob *job,
|
||||||
* Returns:
|
/*! value to set. */
|
||||||
* Always returns 0.
|
free_routine func);
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrInit(ThreadPoolAttr *attr);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Initializes thread pool attributes. Sets values to defaults defined
|
||||||
* Function: TPAttrSetMaxThreads
|
* in ThreadPool.h.
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the max threads for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPAttrInit(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* maxThreads - value to set
|
ThreadPoolAttr *attr);
|
||||||
* Returns:
|
|
||||||
* Always returns 0.
|
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrSetMaxThreads(ThreadPoolAttr *attr, int maxThreads);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the max threads for the thread pool attributes.
|
||||||
* Function: TPAttrSetMinThreads
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the min threads for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPAttrSetMaxThreads(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* minThreads - value to set
|
ThreadPoolAttr *attr,
|
||||||
* Returns:
|
/*! value to set. */
|
||||||
* Always returns 0.
|
int maxThreads);
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrSetMinThreads(ThreadPoolAttr *attr, int minThreads);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the min threads for the thread pool attributes.
|
||||||
* Function: TPAttrSetStackSize
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the stack size for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPAttrSetMinThreads(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* stackSize - value to set
|
ThreadPoolAttr *attr,
|
||||||
* Returns:
|
/*! value to set. */
|
||||||
* Always returns 0.
|
int minThreads);
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrSetStackSize(ThreadPoolAttr *attr, size_t stackSize);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the stack size for the thread pool attributes.
|
||||||
* Function: TPAttrSetIdleTime
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the idle time for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPAttrSetStackSize(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* Returns:
|
ThreadPoolAttr *attr,
|
||||||
* Always returns 0.
|
/*! value to set. */
|
||||||
*****************************************************************************/
|
size_t stackSize);
|
||||||
int TPAttrSetIdleTime(ThreadPoolAttr *attr, int idleTime);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the idle time for the thread pool attributes.
|
||||||
* Function: TPAttrSetJobsPerThread
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the jobs per thread ratio
|
*/
|
||||||
* Parameters:
|
int TPAttrSetIdleTime(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* jobsPerThread - number of jobs per thread to maintain
|
ThreadPoolAttr *attr,
|
||||||
* Returns:
|
/*! . */
|
||||||
* Always returns 0.
|
int idleTime);
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrSetJobsPerThread(ThreadPoolAttr *attr, int jobsPerThread);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the jobs per thread ratio
|
||||||
* Function: TPAttrSetStarvationTime
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the starvation time for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPAttrSetJobsPerThread(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* int starvationTime - milliseconds
|
ThreadPoolAttr *attr,
|
||||||
* Returns:
|
/*! number of jobs per thread to maintain. */
|
||||||
* Always returns 0.
|
int jobsPerThread);
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrSetStarvationTime(ThreadPoolAttr *attr, int starvationTime);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the starvation time for the thread pool attributes.
|
||||||
* Function: TPAttrSetSchedPolicy
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the scheduling policy for the thread pool attributes.
|
*/
|
||||||
* Parameters:
|
int TPAttrSetStarvationTime(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* PolicyType schedPolicy - must be a valid policy type.
|
ThreadPoolAttr *attr,
|
||||||
* Returns:
|
/*! milliseconds. */
|
||||||
* Always returns 0.
|
int starvationTime);
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrSetSchedPolicy(ThreadPoolAttr *attr, PolicyType schedPolicy);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the scheduling policy for the thread pool attributes.
|
||||||
* Function: TPAttrSetMaxJobsTotal
|
|
||||||
*
|
*
|
||||||
* Description:
|
* \return Always returns 0.
|
||||||
* Sets the maximum number jobs that can be qeued totally.
|
*/
|
||||||
* Parameters:
|
int TPAttrSetSchedPolicy(
|
||||||
* attr - must be valid thread pool attributes.
|
/*! must be valid thread pool attributes. */
|
||||||
* maxJobsTotal - maximum number of jobs
|
ThreadPoolAttr *attr,
|
||||||
* Returns:
|
/*! must be a valid policy type. */
|
||||||
* Always returns 0.
|
PolicyType schedPolicy);
|
||||||
*****************************************************************************/
|
|
||||||
int TPAttrSetMaxJobsTotal(ThreadPoolAttr *attr, int maxJobsTotal);
|
|
||||||
|
|
||||||
|
/*!
|
||||||
/****************************************************************************
|
* \brief Sets the maximum number jobs that can be qeued totally.
|
||||||
* Function: ThreadPoolGetStats
|
*
|
||||||
|
* \return Always returns 0.
|
||||||
|
*/
|
||||||
|
int TPAttrSetMaxJobsTotal(
|
||||||
|
/*! must be valid thread pool attributes. */
|
||||||
|
ThreadPoolAttr *attr,
|
||||||
|
/*! maximum number of jobs. */
|
||||||
|
int maxJobsTotal);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Returns various statistics about the thread pool.
|
||||||
*
|
*
|
||||||
* Description:
|
|
||||||
* Returns various statistics about the
|
|
||||||
* thread pool.
|
|
||||||
* Only valid if STATS has been defined.
|
* Only valid if STATS has been defined.
|
||||||
* Parameters:
|
*
|
||||||
* ThreadPool *tp - valid initialized threadpool
|
* \return Always returns 0.
|
||||||
* ThreadPoolStats *stats - valid stats, out parameter
|
*/
|
||||||
* Returns:
|
|
||||||
* Always returns 0.
|
|
||||||
*****************************************************************************/
|
|
||||||
#ifdef STATS
|
#ifdef STATS
|
||||||
EXPORT_SPEC int ThreadPoolGetStats(ThreadPool *tp, ThreadPoolStats *stats);
|
EXPORT_SPEC int ThreadPoolGetStats(
|
||||||
|
/*! Valid initialized threadpool. */
|
||||||
EXPORT_SPEC void ThreadPoolPrintStats(ThreadPoolStats *stats);
|
ThreadPool *tp,
|
||||||
|
/*! Valid stats, out parameter. */
|
||||||
|
ThreadPoolStats *stats);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE int ThreadPoolGetStats(ThreadPool *tp, ThreadPoolStats *stats) {}
|
static UPNP_INLINE int ThreadPoolGetStats(
|
||||||
|
/*! Valid initialized threadpool. */
|
||||||
static UPNP_INLINE void ThreadPoolPrintStats(ThreadPoolStats *stats) {}
|
ThreadPool *tp,
|
||||||
|
/*! Valid stats, out parameter. */
|
||||||
|
ThreadPoolStats *stats) {}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief
|
||||||
|
*/
|
||||||
|
#ifdef STATS
|
||||||
|
EXPORT_SPEC void ThreadPoolPrintStats(
|
||||||
|
/*! . */
|
||||||
|
ThreadPoolStats *stats);
|
||||||
|
#else
|
||||||
|
static UPNP_INLINE void ThreadPoolPrintStats(
|
||||||
|
/*! . */
|
||||||
|
ThreadPoolStats *stats) {}
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif /* THREADPOOL_H */
|
#endif /* THREADPOOL_H */
|
||||||
|
|
||||||
|
|||||||
@@ -29,35 +29,31 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef TIMERTHREAD_H
|
#ifndef TIMERTHREAD_H
|
||||||
#define TIMERTHREAD_H
|
#define TIMERTHREAD_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "FreeList.h"
|
#include "FreeList.h"
|
||||||
#include "ithread.h"
|
#include "ithread.h"
|
||||||
#include "LinkedList.h"
|
#include "LinkedList.h"
|
||||||
#include "ThreadPool.h"
|
#include "ThreadPool.h"
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#define INVALID_EVENT_ID (-10 & 1<<29)
|
#define INVALID_EVENT_ID (-10 & 1<<29)
|
||||||
|
|
||||||
|
/*! Timeout Types. */
|
||||||
/* Timeout Types */
|
typedef enum timeoutType {
|
||||||
/* absolute means in seconds from Jan 1, 1970 */
|
/*! seconds from Jan 1, 1970. */
|
||||||
/* relative means in seconds from current time */
|
ABS_SEC,
|
||||||
typedef enum timeoutType {ABS_SEC,REL_SEC} TimeoutType;
|
/*! seconds from current time. */
|
||||||
|
REL_SEC
|
||||||
|
} TimeoutType;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* A timer thread similar to the one in the Upnp SDK that allows
|
* A timer thread similar to the one in the Upnp SDK that allows
|
||||||
@@ -79,7 +75,6 @@ typedef struct TIMERTHREAD
|
|||||||
ThreadPool *tp;
|
ThreadPool *tp;
|
||||||
} TimerThread;
|
} TimerThread;
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Struct to contain information for a timer event.
|
* Struct to contain information for a timer event.
|
||||||
*
|
*
|
||||||
@@ -95,7 +90,6 @@ typedef struct TIMEREVENT
|
|||||||
int id;
|
int id;
|
||||||
} TimerEvent;
|
} TimerEvent;
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Initializes and starts timer thread.
|
* \brief Initializes and starts timer thread.
|
||||||
*
|
*
|
||||||
@@ -109,7 +103,6 @@ int TimerThreadInit(
|
|||||||
* lifetime of timer. Timer must be shutdown BEFORE thread pool. */
|
* lifetime of timer. Timer must be shutdown BEFORE thread pool. */
|
||||||
ThreadPool *tp);
|
ThreadPool *tp);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Schedules an event to run at a specified time.
|
* \brief Schedules an event to run at a specified time.
|
||||||
*
|
*
|
||||||
@@ -132,7 +125,6 @@ int TimerThreadSchedule(
|
|||||||
/*! [in] Id of timer event. (out, can be null). */
|
/*! [in] Id of timer event. (out, can be null). */
|
||||||
int *id);
|
int *id);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Removes an event from the timer Q.
|
* \brief Removes an event from the timer Q.
|
||||||
*
|
*
|
||||||
@@ -148,7 +140,6 @@ int TimerThreadRemove(
|
|||||||
/*! [in] Space for thread pool job. */
|
/*! [in] Space for thread pool job. */
|
||||||
ThreadPoolJob *out);
|
ThreadPoolJob *out);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Shutdown the timer thread.
|
* \brief Shutdown the timer thread.
|
||||||
*
|
*
|
||||||
@@ -162,7 +153,6 @@ int TimerThreadShutdown(
|
|||||||
/*! [in] Valid timer thread pointer. */
|
/*! [in] Valid timer thread pointer. */
|
||||||
TimerThread *timer);
|
TimerThread *timer);
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
#ifndef ITHREAD_H
|
||||||
|
#define ITHREAD_H
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
@@ -29,43 +32,29 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef ITHREAD_H
|
|
||||||
#define ITHREAD_H
|
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#if !defined(WIN32)
|
#if !defined(WIN32)
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#include "UpnpGlobal.h" /* For UPNP_INLINE, EXPORT_SPEC */
|
#include "UpnpGlobal.h" /* For UPNP_INLINE, EXPORT_SPEC */
|
||||||
|
#include "UpnpUniStd.h" /* for close() */
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#ifdef WIN32
|
|
||||||
/* Do not #include <unistd.h> */
|
|
||||||
#else
|
|
||||||
#include <unistd.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#if defined(BSD)
|
#if defined(BSD)
|
||||||
#define PTHREAD_MUTEX_RECURSIVE_NP PTHREAD_MUTEX_RECURSIVE
|
#define PTHREAD_MUTEX_RECURSIVE_NP PTHREAD_MUTEX_RECURSIVE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef PTHREAD_MUTEX_RECURSIVE
|
#if defined(PTHREAD_MUTEX_RECURSIVE) || defined(__DragonFly__)
|
||||||
/* This system has SuS2-compliant mutex attributes.
|
/* This system has SuS2-compliant mutex attributes.
|
||||||
* E.g. on Cygwin, where we don't have the old nonportable (NP) symbols
|
* E.g. on Cygwin, where we don't have the old nonportable (NP) symbols
|
||||||
*/
|
*/
|
||||||
@@ -188,7 +177,10 @@ typedef pthread_rwlockattr_t ithread_rwlockattr_t;
|
|||||||
* Internal Use Only
|
* Internal Use Only
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#if UPNP_USE_RWLOCK
|
#if UPNP_USE_RWLOCK
|
||||||
typedef pthread_rwlock_t ithread_rwlock_t;
|
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 */
|
#endif /* UPNP_USE_RWLOCK */
|
||||||
|
|
||||||
|
|
||||||
@@ -333,11 +325,11 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
* Returns EINVAL if the kind is not supported.
|
* Returns EINVAL if the kind is not supported.
|
||||||
* See man page for pthread_mutexattr_setkind_np
|
* See man page for pthread_mutexattr_setkind_np
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#ifdef PTHREAD_MUTEX_RECURSIVE
|
#if defined(PTHREAD_MUTEX_RECURSIVE) || defined(__DragonFly__)
|
||||||
#define ithread_mutexattr_setkind_np pthread_mutexattr_settype
|
#define ithread_mutexattr_setkind_np pthread_mutexattr_settype
|
||||||
#else
|
#else
|
||||||
#define ithread_mutexattr_setkind_np pthread_mutexattr_setkind_np
|
#define ithread_mutexattr_setkind_np pthread_mutexattr_setkind_np
|
||||||
#endif
|
#endif /* UPNP_USE_RWLOCK */
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Function: ithread_mutexattr_getkind_np
|
* Function: ithread_mutexattr_getkind_np
|
||||||
@@ -358,11 +350,11 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
* Always returns 0.
|
* Always returns 0.
|
||||||
* See man page for pthread_mutexattr_getkind_np
|
* See man page for pthread_mutexattr_getkind_np
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#ifdef PTHREAD_MUTEX_RECURSIVE
|
#if defined(PTHREAD_MUTEX_RECURSIVE) || defined(__DragonFly__)
|
||||||
#define ithread_mutexattr_getkind_np pthread_mutexattr_gettype
|
#define ithread_mutexattr_getkind_np pthread_mutexattr_gettype
|
||||||
#else
|
#else
|
||||||
#define ithread_mutexattr_getkind_np pthread_mutexattr_getkind_np
|
#define ithread_mutexattr_getkind_np pthread_mutexattr_getkind_np
|
||||||
#endif
|
#endif /* UPNP_USE_RWLOCK */
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@@ -536,8 +528,10 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#if UPNP_USE_RWLOCK
|
#if UPNP_USE_RWLOCK
|
||||||
#define ithread_rwlock_init pthread_rwlock_init
|
#define ithread_rwlock_init pthread_rwlock_init
|
||||||
#endif /* UPNP_USE_RWLOCK */
|
#else
|
||||||
|
/* Read-write locks aren't available: use mutex instead. */
|
||||||
|
#define ithread_rwlock_init ithread_mutex_init
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Function: ithread_rwlock_rdlock
|
* Function: ithread_rwlock_rdlock
|
||||||
@@ -555,9 +549,11 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#if UPNP_USE_RWLOCK
|
#if UPNP_USE_RWLOCK
|
||||||
#define ithread_rwlock_rdlock pthread_rwlock_rdlock
|
#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 */
|
#endif /* UPNP_USE_RWLOCK */
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Function: ithread_rwlock_wrlock
|
* Function: ithread_rwlock_wrlock
|
||||||
*
|
*
|
||||||
@@ -574,6 +570,9 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#if UPNP_USE_RWLOCK
|
#if UPNP_USE_RWLOCK
|
||||||
#define ithread_rwlock_wrlock pthread_rwlock_wrlock
|
#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 */
|
#endif /* UPNP_USE_RWLOCK */
|
||||||
|
|
||||||
|
|
||||||
@@ -594,6 +593,9 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#if UPNP_USE_RWLOCK
|
#if UPNP_USE_RWLOCK
|
||||||
#define ithread_rwlock_unlock pthread_rwlock_unlock
|
#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 */
|
#endif /* UPNP_USE_RWLOCK */
|
||||||
|
|
||||||
|
|
||||||
@@ -615,6 +617,9 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#if UPNP_USE_RWLOCK
|
#if UPNP_USE_RWLOCK
|
||||||
#define ithread_rwlock_destroy pthread_rwlock_destroy
|
#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 */
|
#endif /* UPNP_USE_RWLOCK */
|
||||||
|
|
||||||
|
|
||||||
@@ -917,7 +922,8 @@ static UPNP_INLINE int ithread_cleanup_thread(void) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifndef PTHREAD_MUTEX_RECURSIVE
|
#if !defined(PTHREAD_MUTEX_RECURSIVE) && !defined(__DragonFly__) && !defined(UPNP_USE_MSVCPP)
|
||||||
|
/* !defined(UPNP_USE_MSVCPP) should probably also have pthreads version check - but it's not clear if that is possible */
|
||||||
/* NK: Added for satisfying the gcc compiler */
|
/* NK: Added for satisfying the gcc compiler */
|
||||||
EXPORT_SPEC int pthread_mutexattr_setkind_np(pthread_mutexattr_t *attr, int kind);
|
EXPORT_SPEC int pthread_mutexattr_setkind_np(pthread_mutexattr_t *attr, int kind);
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -1,177 +1,111 @@
|
|||||||
///////////////////////////////////////////////////////////////////////////
|
/**************************************************************************
|
||||||
//
|
*
|
||||||
// Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
// All rights reserved.
|
* All rights reserved.
|
||||||
//
|
*
|
||||||
// Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
// modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
//
|
*
|
||||||
// * Redistributions of source code must retain the above copyright notice,
|
* - Redistributions of source code must retain the above copyright notice,
|
||||||
// this list of conditions and the following disclaimer.
|
* this list of conditions and the following disclaimer.
|
||||||
// * Redistributions in binary form must reproduce the above copyright notice,
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
// this list of conditions and the following disclaimer in the documentation
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
// and/or other materials provided with the distribution.
|
* and/or other materials provided with the distribution.
|
||||||
// * Neither name of Intel Corporation nor the names of its contributors
|
* - Neither name of Intel Corporation nor the names of its contributors
|
||||||
// may be used to endorse or promote products derived from this software
|
* may be used to endorse or promote products derived from this software
|
||||||
// without specific prior written permission.
|
* without specific prior written permission.
|
||||||
//
|
*
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
||||||
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
||||||
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
//
|
*
|
||||||
///////////////////////////////////////////////////////////////////////////
|
**************************************************************************/
|
||||||
|
|
||||||
#include "FreeList.h"
|
#include "FreeList.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <stdlib.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 );
|
assert(free_list != NULL);
|
||||||
|
|
||||||
if( free_list == NULL )
|
if (free_list == NULL)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
free_list->element_size = elementSize;
|
free_list->element_size = elementSize;
|
||||||
free_list->maxFreeListLength = maxFreeListLength;
|
free_list->maxFreeListLength = maxFreeListLength;
|
||||||
free_list->head = NULL;
|
free_list->head = NULL;
|
||||||
free_list->freeListLength = 0;
|
free_list->freeListLength = 0;
|
||||||
|
|
||||||
return 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;
|
FreeListNode *ret = NULL;
|
||||||
|
|
||||||
assert( free_list != NULL );
|
assert(free_list != NULL);
|
||||||
|
|
||||||
if( free_list == NULL )
|
if (free_list == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if( free_list->head ) {
|
if (free_list->head) {
|
||||||
ret = free_list->head;
|
ret = free_list->head;
|
||||||
free_list->head = free_list->head->next;
|
free_list->head = free_list->head->next;
|
||||||
free_list->freeListLength--;
|
free_list->freeListLength--;
|
||||||
} else {
|
} else {
|
||||||
ret = malloc( free_list->element_size );
|
ret = malloc(free_list->element_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
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;
|
FreeListNode *temp = NULL;
|
||||||
|
|
||||||
assert( free_list != NULL );
|
assert(free_list != NULL);
|
||||||
|
|
||||||
if( free_list == NULL )
|
if (free_list == NULL)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
if (element != NULL &&
|
||||||
if( ( element != NULL ) &&
|
free_list->freeListLength + 1 < free_list->maxFreeListLength) {
|
||||||
( ( free_list->freeListLength + 1 ) <
|
|
||||||
free_list->maxFreeListLength ) ) {
|
|
||||||
free_list->freeListLength++;
|
free_list->freeListLength++;
|
||||||
temp = ( FreeListNode * ) element;
|
temp = (FreeListNode *)element;
|
||||||
temp->next = free_list->head;
|
temp->next = free_list->head;
|
||||||
free_list->head = temp;
|
free_list->head = temp;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
free(element);
|
||||||
free( element );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
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;
|
FreeListNode *temp = NULL;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
assert( free_list != NULL );
|
assert(free_list != NULL);
|
||||||
|
|
||||||
if( free_list == NULL )
|
if (!free_list)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
while (free_list->head) {
|
||||||
while( free_list->head ) {
|
|
||||||
i++;
|
i++;
|
||||||
temp = free_list->head->next;
|
temp = free_list->head->next;
|
||||||
free( free_list->head );
|
free(free_list->head);
|
||||||
free_list->head = temp;
|
free_list->head = temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
free_list->freeListLength = 0;
|
free_list->freeListLength = 0;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,193 +30,112 @@
|
|||||||
*
|
*
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#include "LinkedList.h"
|
#include "LinkedList.h"
|
||||||
|
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
/* Do not #include <sys/param.h> */
|
/* Do not #include <sys/param.h> */
|
||||||
#else
|
#else
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#if (defined(BSD) && BSD >= 199306) || defined(__OSX__) || defined(__APPLE__)
|
#if (defined(BSD) && BSD >= 199306) || defined(__OSX__) || defined(__APPLE__)
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#else
|
#else
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
static int freeListNode(ListNode *node, LinkedList *list)
|
||||||
static int
|
|
||||||
freeListNode( ListNode * node,
|
|
||||||
LinkedList * list )
|
|
||||||
{
|
{
|
||||||
assert( list != NULL );
|
assert(list != NULL);
|
||||||
|
|
||||||
return FreeListFree( &list->freeNodeList, node );
|
return FreeListFree(&list->freeNodeList, node);
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/*!
|
||||||
* Function: CreateListNode
|
* \brief Dynamically creates a list node.
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Creates a list node. Dynamically.
|
|
||||||
*
|
*
|
||||||
* Parameters:
|
* Parameters:
|
||||||
* void * item - the item to store
|
* void * item - the item to store
|
||||||
* Returns:
|
* Returns:
|
||||||
* The new node, NULL on failure.
|
* The new node, NULL on failure.
|
||||||
*****************************************************************************/
|
*/
|
||||||
static ListNode *
|
static ListNode *CreateListNode(
|
||||||
CreateListNode( void *item,
|
/*! the item to store. */
|
||||||
LinkedList * list )
|
void *item,
|
||||||
|
/*! The list to add it to. */
|
||||||
|
LinkedList *list)
|
||||||
{
|
{
|
||||||
|
|
||||||
ListNode *temp = NULL;
|
ListNode *temp = NULL;
|
||||||
|
|
||||||
assert( list != NULL );
|
assert(list != NULL);
|
||||||
|
|
||||||
temp = ( ListNode * ) FreeListAlloc( &list->freeNodeList );
|
temp = (ListNode *)FreeListAlloc(&list->freeNodeList);
|
||||||
if( temp ) {
|
if (temp) {
|
||||||
temp->prev = NULL;
|
temp->prev = NULL;
|
||||||
temp->next = NULL;
|
temp->next = NULL;
|
||||||
temp->item = item;
|
temp->item = item;
|
||||||
}
|
}
|
||||||
|
|
||||||
return temp;
|
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;
|
int retCode = 0;
|
||||||
|
|
||||||
assert( list != NULL );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( list == NULL )
|
if (!list)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
list->size = 0;
|
list->size = 0;
|
||||||
list->cmp_func = cmp_func;
|
list->cmp_func = cmp_func;
|
||||||
list->free_func = free_func;
|
list->free_func = free_func;
|
||||||
|
retCode = FreeListInit(&list->freeNodeList, sizeof(ListNode), FREELISTSIZE);
|
||||||
|
|
||||||
retCode =
|
assert(retCode == 0);
|
||||||
FreeListInit( &list->freeNodeList, sizeof( ListNode ),
|
|
||||||
FREELISTSIZE );
|
|
||||||
|
|
||||||
assert( retCode == 0 );
|
|
||||||
|
|
||||||
list->head.item = NULL;
|
list->head.item = NULL;
|
||||||
list->head.next = &list->tail;
|
list->head.next = &list->tail;
|
||||||
list->head.prev = NULL;
|
list->head.prev = NULL;
|
||||||
|
|
||||||
list->tail.item = NULL;
|
list->tail.item = NULL;
|
||||||
list->tail.prev = &list->head;
|
list->tail.prev = &list->head;
|
||||||
list->tail.next = NULL;
|
list->tail.next = NULL;
|
||||||
|
|
||||||
return 0;
|
return retCode;
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
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 );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( list == NULL )
|
if (list == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
return ListAddAfter( list, item, &list->head );
|
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 );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( list == NULL )
|
if (!list)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
return ListAddBefore( list, item, &list->tail );
|
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;
|
ListNode *newNode = NULL;
|
||||||
|
|
||||||
assert( list != NULL );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( ( list == NULL ) || ( bnode == NULL ) )
|
if (!list || !bnode)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
newNode = CreateListNode(item, list);
|
||||||
newNode = CreateListNode( item, list );
|
if (newNode) {
|
||||||
if( newNode ) {
|
|
||||||
ListNode *temp = bnode->next;
|
ListNode *temp = bnode->next;
|
||||||
|
|
||||||
bnode->next = newNode;
|
bnode->next = newNode;
|
||||||
@@ -223,41 +143,23 @@ ListAddAfter( LinkedList * list,
|
|||||||
newNode->next = temp;
|
newNode->next = temp;
|
||||||
temp->prev = newNode;
|
temp->prev = newNode;
|
||||||
list->size++;
|
list->size++;
|
||||||
|
|
||||||
return newNode;
|
return newNode;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
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;
|
ListNode *newNode = NULL;
|
||||||
|
|
||||||
assert( list != NULL );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( ( list == NULL ) || ( anode == NULL ) )
|
if (!list || !anode)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
newNode = CreateListNode(item, list);
|
||||||
newNode = CreateListNode( item, list );
|
if (newNode) {
|
||||||
|
|
||||||
if( newNode ) {
|
|
||||||
ListNode *temp = anode->prev;
|
ListNode *temp = anode->prev;
|
||||||
|
|
||||||
anode->prev = newNode;
|
anode->prev = newNode;
|
||||||
@@ -265,281 +167,142 @@ ListAddBefore( LinkedList * list,
|
|||||||
newNode->prev = temp;
|
newNode->prev = temp;
|
||||||
temp->next = newNode;
|
temp->next = newNode;
|
||||||
list->size++;
|
list->size++;
|
||||||
|
|
||||||
return newNode;
|
return newNode;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
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;
|
void *temp;
|
||||||
|
|
||||||
assert( list != NULL );
|
assert(list != NULL);
|
||||||
assert( dnode != &list->head );
|
assert(dnode != &list->head);
|
||||||
assert( dnode != &list->tail );
|
assert(dnode != &list->tail);
|
||||||
|
|
||||||
if( ( list == NULL ) ||
|
if (!list || dnode == &list->head || dnode == &list->tail || !dnode)
|
||||||
( dnode == &list->head ) ||
|
|
||||||
( dnode == &list->tail ) || ( dnode == NULL ) ) {
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
|
||||||
|
|
||||||
temp = dnode->item;
|
temp = dnode->item;
|
||||||
dnode->prev->next = dnode->next;
|
dnode->prev->next = dnode->next;
|
||||||
dnode->next->prev = dnode->prev;
|
dnode->next->prev = dnode->prev;
|
||||||
|
freeListNode(dnode, list);
|
||||||
freeListNode( dnode, list );
|
|
||||||
list->size--;
|
list->size--;
|
||||||
|
if (freeItem && list->free_func) {
|
||||||
if( freeItem && list->free_func ) {
|
list->free_func(temp);
|
||||||
list->free_func( temp );
|
|
||||||
temp = NULL;
|
temp = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return temp;
|
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 *dnode = NULL;
|
||||||
ListNode *temp = NULL;
|
ListNode *temp = NULL;
|
||||||
|
|
||||||
if( list == NULL )
|
if(!list)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
for( dnode = list->head.next; dnode != &list->tail; ) {
|
for (dnode = list->head.next; dnode != &list->tail; ) {
|
||||||
temp = dnode->next;
|
temp = dnode->next;
|
||||||
ListDelNode( list, dnode, freeItem );
|
ListDelNode(list, dnode, freeItem);
|
||||||
dnode = temp;
|
dnode = temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
list->size = 0;
|
list->size = 0;
|
||||||
FreeListDestroy( &list->freeNodeList );
|
FreeListDestroy(&list->freeNodeList);
|
||||||
|
|
||||||
return 0;
|
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 );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( list == NULL )
|
if (!list)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if( list->size == 0 )
|
if (!list->size)
|
||||||
return NULL;
|
return NULL;
|
||||||
else
|
else
|
||||||
return list->head.next;
|
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 );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( list == NULL )
|
if (!list)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if( list->size == 0 )
|
if (!list->size)
|
||||||
return NULL;
|
return NULL;
|
||||||
else
|
else
|
||||||
return list->tail.prev;
|
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(list != NULL);
|
||||||
assert( node != NULL );
|
assert(node != NULL);
|
||||||
|
|
||||||
if( ( list == NULL ) || ( node == NULL ) )
|
if (!list || !node)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
if (node->next == &list->tail)
|
||||||
if( node->next == &list->tail )
|
|
||||||
return NULL;
|
return NULL;
|
||||||
else
|
else
|
||||||
return node->next;
|
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(list != NULL);
|
||||||
assert( node != NULL );
|
assert(node != NULL);
|
||||||
|
|
||||||
if( ( list == NULL ) || ( node == NULL ) )
|
if (!list || !node)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if( node->prev == &list->head )
|
if (node->prev == &list->head)
|
||||||
return NULL;
|
return NULL;
|
||||||
else
|
else
|
||||||
return node->prev;
|
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;
|
ListNode *finger = NULL;
|
||||||
|
|
||||||
if( list == NULL )
|
if (!list)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
if (!start)
|
||||||
if( start == NULL )
|
|
||||||
start = &list->head;
|
start = &list->head;
|
||||||
|
|
||||||
assert( start );
|
assert(start);
|
||||||
|
|
||||||
finger = start->next;
|
finger = start->next;
|
||||||
|
|
||||||
assert( finger );
|
assert(finger);
|
||||||
|
|
||||||
while( finger != &list->tail ) {
|
while (finger != &list->tail) {
|
||||||
if( list->cmp_func ) {
|
if (list->cmp_func) {
|
||||||
if( list->cmp_func( item, finger->item ) )
|
if (list->cmp_func(item, finger->item))
|
||||||
return finger;
|
return finger;
|
||||||
} else {
|
} else {
|
||||||
if( item == finger->item )
|
if (item == finger->item)
|
||||||
return finger;
|
return finger;
|
||||||
}
|
}
|
||||||
finger = finger->next;
|
finger = finger->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
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 );
|
assert(list != NULL);
|
||||||
|
|
||||||
if( list == NULL )
|
if (!list)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
return list->size;
|
return list->size;
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,18 +30,14 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "TimerThread.h"
|
#include "TimerThread.h"
|
||||||
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Deallocates a dynamically allocated TimerEvent.
|
* \brief Deallocates a dynamically allocated TimerEvent.
|
||||||
*/
|
*/
|
||||||
@@ -55,7 +52,6 @@ static void FreeTimerEvent(
|
|||||||
FreeListFree(&timer->freeEvents, event);
|
FreeListFree(&timer->freeEvents, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Implements timer thread.
|
* \brief Implements timer thread.
|
||||||
*
|
*
|
||||||
@@ -67,46 +63,38 @@ static void *TimerThreadWorker(
|
|||||||
{
|
{
|
||||||
TimerThread *timer = ( TimerThread * ) arg;
|
TimerThread *timer = ( TimerThread * ) arg;
|
||||||
ListNode *head = NULL;
|
ListNode *head = NULL;
|
||||||
|
|
||||||
TimerEvent *nextEvent = NULL;
|
TimerEvent *nextEvent = NULL;
|
||||||
|
|
||||||
time_t currentTime = 0;
|
time_t currentTime = 0;
|
||||||
time_t nextEventTime = 0;
|
time_t nextEventTime = 0;
|
||||||
struct timespec timeToWait;
|
struct timespec timeToWait;
|
||||||
|
|
||||||
int tempId;
|
int tempId;
|
||||||
|
|
||||||
assert( timer != NULL );
|
assert( timer != NULL );
|
||||||
|
|
||||||
ithread_mutex_lock( &timer->mutex );
|
ithread_mutex_lock( &timer->mutex );
|
||||||
|
while (1) {
|
||||||
while( 1 )
|
/* mutex should always be locked at top of loop */
|
||||||
{
|
/* Check for shutdown. */
|
||||||
//mutex should always be locked at top of loop
|
if (timer->shutdown) {
|
||||||
//Check for shutdown
|
|
||||||
if( timer->shutdown )
|
|
||||||
{
|
|
||||||
timer->shutdown = 0;
|
timer->shutdown = 0;
|
||||||
ithread_cond_signal( &timer->condition );
|
ithread_cond_signal( &timer->condition );
|
||||||
ithread_mutex_unlock( &timer->mutex );
|
ithread_mutex_unlock( &timer->mutex );
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
nextEvent = NULL;
|
nextEvent = NULL;
|
||||||
|
/* Get the next event if possible. */
|
||||||
//Get the next event if possible
|
if (timer->eventQ.size > 0) {
|
||||||
if( timer->eventQ.size > 0 )
|
|
||||||
{
|
|
||||||
head = ListHead( &timer->eventQ );
|
head = ListHead( &timer->eventQ );
|
||||||
|
if (head == NULL) {
|
||||||
|
ithread_mutex_unlock( &timer->mutex );
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
nextEvent = ( TimerEvent * ) head->item;
|
nextEvent = ( TimerEvent * ) head->item;
|
||||||
nextEventTime = nextEvent->eventTime;
|
nextEventTime = nextEvent->eventTime;
|
||||||
}
|
}
|
||||||
|
currentTime = time(NULL);
|
||||||
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 ) {
|
if( nextEvent->persistent ) {
|
||||||
ThreadPoolAddPersistent( timer->tp, &nextEvent->job,
|
ThreadPoolAddPersistent( timer->tp, &nextEvent->job,
|
||||||
&tempId );
|
&tempId );
|
||||||
@@ -117,8 +105,7 @@ static void *TimerThreadWorker(
|
|||||||
FreeTimerEvent( timer, nextEvent );
|
FreeTimerEvent( timer, nextEvent );
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (nextEvent) {
|
||||||
if( nextEvent != NULL ) {
|
|
||||||
timeToWait.tv_nsec = 0;
|
timeToWait.tv_nsec = 0;
|
||||||
timeToWait.tv_sec = nextEvent->eventTime;
|
timeToWait.tv_sec = nextEvent->eventTime;
|
||||||
ithread_cond_timedwait( &timer->condition, &timer->mutex,
|
ithread_cond_timedwait( &timer->condition, &timer->mutex,
|
||||||
@@ -146,16 +133,16 @@ static int CalculateEventTime(
|
|||||||
|
|
||||||
assert( timeout != NULL );
|
assert( timeout != NULL );
|
||||||
|
|
||||||
if( type == ABS_SEC )
|
switch (type) {
|
||||||
|
case ABS_SEC:
|
||||||
return 0;
|
return 0;
|
||||||
else if( type == REL_SEC ) {
|
default: /* REL_SEC) */
|
||||||
time( &now );
|
time(&now);
|
||||||
( *timeout ) += now;
|
( *timeout ) += now;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@@ -246,10 +233,8 @@ int TimerThreadInit(TimerThread *timer, ThreadPool *tp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int TimerThreadSchedule(
|
int TimerThreadSchedule(
|
||||||
TimerThread *timer,
|
TimerThread *timer,
|
||||||
time_t timeout,
|
time_t timeout,
|
||||||
@@ -258,7 +243,6 @@ int TimerThreadSchedule(
|
|||||||
Duration duration,
|
Duration duration,
|
||||||
int *id)
|
int *id)
|
||||||
{
|
{
|
||||||
|
|
||||||
int rc = EOUTOFMEM;
|
int rc = EOUTOFMEM;
|
||||||
int found = 0;
|
int found = 0;
|
||||||
int tempId = 0;
|
int tempId = 0;
|
||||||
@@ -291,35 +275,25 @@ int TimerThreadSchedule(
|
|||||||
}
|
}
|
||||||
|
|
||||||
tempNode = ListHead( &timer->eventQ );
|
tempNode = ListHead( &timer->eventQ );
|
||||||
//add job to Q
|
/* add job to Q. Q is ordered by eventTime with the head of the Q being
|
||||||
//Q is ordered by eventTime
|
* the next event. */
|
||||||
//with the head of the Q being the next event
|
|
||||||
|
|
||||||
while( tempNode != NULL ) {
|
while( tempNode != NULL ) {
|
||||||
temp = ( TimerEvent * ) tempNode->item;
|
temp = ( TimerEvent * ) tempNode->item;
|
||||||
if( temp->eventTime >= timeout )
|
if( temp->eventTime >= timeout ) {
|
||||||
{
|
if (ListAddBefore( &timer->eventQ, newEvent, tempNode))
|
||||||
|
|
||||||
if( ListAddBefore( &timer->eventQ, newEvent, tempNode ) !=
|
|
||||||
NULL )
|
|
||||||
rc = 0;
|
rc = 0;
|
||||||
found = 1;
|
found = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
tempNode = ListNext( &timer->eventQ, tempNode );
|
tempNode = ListNext( &timer->eventQ, tempNode );
|
||||||
}
|
}
|
||||||
|
/* add to the end of Q. */
|
||||||
//add to the end of Q
|
if (!found) {
|
||||||
if( !found ) {
|
|
||||||
|
|
||||||
if( ListAddTail( &timer->eventQ, newEvent ) != NULL )
|
if( ListAddTail( &timer->eventQ, newEvent ) != NULL )
|
||||||
rc = 0;
|
rc = 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
//signal change in Q
|
/* signal change in Q. */
|
||||||
if( rc == 0 ) {
|
if( rc == 0 ) {
|
||||||
|
|
||||||
ithread_cond_signal( &timer->condition );
|
ithread_cond_signal( &timer->condition );
|
||||||
} else {
|
} else {
|
||||||
FreeTimerEvent( timer, newEvent );
|
FreeTimerEvent( timer, newEvent );
|
||||||
@@ -330,7 +304,6 @@ int TimerThreadSchedule(
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int TimerThreadRemove(
|
int TimerThreadRemove(
|
||||||
TimerThread *timer,
|
TimerThread *timer,
|
||||||
int id,
|
int id,
|
||||||
@@ -369,7 +342,6 @@ int TimerThreadRemove(
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int TimerThreadShutdown(TimerThread *timer)
|
int TimerThreadShutdown(TimerThread *timer)
|
||||||
{
|
{
|
||||||
ListNode *tempNode2 = NULL;
|
ListNode *tempNode2 = NULL;
|
||||||
@@ -386,9 +358,7 @@ int TimerThreadShutdown(TimerThread *timer)
|
|||||||
timer->shutdown = 1;
|
timer->shutdown = 1;
|
||||||
tempNode = ListHead( &timer->eventQ );
|
tempNode = ListHead( &timer->eventQ );
|
||||||
|
|
||||||
//Delete nodes in Q
|
/* Delete nodes in Q. Call registered free function on argument. */
|
||||||
//call registered free function
|
|
||||||
//on argument
|
|
||||||
while( tempNode != NULL ) {
|
while( tempNode != NULL ) {
|
||||||
TimerEvent *temp = ( TimerEvent * ) tempNode->item;
|
TimerEvent *temp = ( TimerEvent * ) tempNode->item;
|
||||||
|
|
||||||
@@ -406,19 +376,17 @@ int TimerThreadShutdown(TimerThread *timer)
|
|||||||
|
|
||||||
ithread_cond_broadcast( &timer->condition );
|
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_cond_wait( &timer->condition, &timer->mutex );
|
||||||
}
|
}
|
||||||
|
ithread_mutex_unlock(&timer->mutex);
|
||||||
|
|
||||||
ithread_mutex_unlock( &timer->mutex );
|
/* destroy condition. */
|
||||||
|
while(ithread_cond_destroy(&timer->condition) != 0) {
|
||||||
//destroy condition
|
|
||||||
while( ithread_cond_destroy( &timer->condition ) != 0 ) {
|
|
||||||
}
|
}
|
||||||
|
/* destroy mutex. */
|
||||||
//destroy mutex
|
while (ithread_mutex_destroy(&timer->mutex) != 0) {
|
||||||
while( ithread_mutex_destroy( &timer->mutex ) != 0 ) {
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -23,7 +23,10 @@ upnpinclude_HEADERS = \
|
|||||||
inc/upnp.h \
|
inc/upnp.h \
|
||||||
inc/upnpdebug.h \
|
inc/upnpdebug.h \
|
||||||
inc/UpnpGlobal.h \
|
inc/UpnpGlobal.h \
|
||||||
inc/UpnpInet.h
|
inc/UpnpInet.h \
|
||||||
|
inc/UpnpIntTypes.h \
|
||||||
|
inc/UpnpStdInt.h \
|
||||||
|
inc/UpnpUniStd.h
|
||||||
|
|
||||||
nodist_upnpinclude_HEADERS = inc/upnpconfig.h
|
nodist_upnpinclude_HEADERS = inc/upnpconfig.h
|
||||||
if ENABLE_TOOLS
|
if ENABLE_TOOLS
|
||||||
@@ -70,23 +73,27 @@ libupnp_la_SOURCES = \
|
|||||||
src/inc/upnp_timeout.h \
|
src/inc/upnp_timeout.h \
|
||||||
src/inc/uri.h \
|
src/inc/uri.h \
|
||||||
src/inc/urlconfig.h \
|
src/inc/urlconfig.h \
|
||||||
src/inc/util.h \
|
src/inc/upnputil.h \
|
||||||
src/inc/utilall.h \
|
|
||||||
src/inc/uuid.h \
|
src/inc/uuid.h \
|
||||||
src/inc/VirtualDir.h \
|
src/inc/VirtualDir.h \
|
||||||
src/inc/webserver.h
|
src/inc/webserver.h
|
||||||
|
|
||||||
# ssdp
|
# ssdp
|
||||||
|
if ENABLE_SSDP
|
||||||
libupnp_la_SOURCES += \
|
libupnp_la_SOURCES += \
|
||||||
|
src/ssdp/ssdp_ResultData.h \
|
||||||
src/ssdp/ssdp_device.c \
|
src/ssdp/ssdp_device.c \
|
||||||
src/ssdp/ssdp_ctrlpt.c \
|
src/ssdp/ssdp_ctrlpt.c \
|
||||||
src/ssdp/ssdp_server.c
|
src/ssdp/ssdp_server.c
|
||||||
|
endif
|
||||||
|
|
||||||
# soap
|
# soap
|
||||||
|
if ENABLE_SOAP
|
||||||
libupnp_la_SOURCES += \
|
libupnp_la_SOURCES += \
|
||||||
src/soap/soap_device.c \
|
src/soap/soap_device.c \
|
||||||
src/soap/soap_ctrlpt.c \
|
src/soap/soap_ctrlpt.c \
|
||||||
src/soap/soap_common.c
|
src/soap/soap_common.c
|
||||||
|
endif
|
||||||
|
|
||||||
# genlib
|
# genlib
|
||||||
libupnp_la_SOURCES += \
|
libupnp_la_SOURCES += \
|
||||||
@@ -106,10 +113,12 @@ libupnp_la_SOURCES += \
|
|||||||
src/genlib/net/uri/uri.c
|
src/genlib/net/uri/uri.c
|
||||||
|
|
||||||
# gena
|
# gena
|
||||||
|
if ENABLE_GENA
|
||||||
libupnp_la_SOURCES += \
|
libupnp_la_SOURCES += \
|
||||||
src/gena/gena_device.c \
|
src/gena/gena_device.c \
|
||||||
src/gena/gena_ctrlpt.c \
|
src/gena/gena_ctrlpt.c \
|
||||||
src/gena/gena_callback2.c
|
src/gena/gena_callback2.c
|
||||||
|
endif
|
||||||
|
|
||||||
# api
|
# api
|
||||||
libupnp_la_SOURCES += \
|
libupnp_la_SOURCES += \
|
||||||
@@ -126,10 +135,12 @@ endif
|
|||||||
|
|
||||||
|
|
||||||
# uuid
|
# uuid
|
||||||
|
if ENABLE_UUID
|
||||||
libupnp_la_SOURCES += \
|
libupnp_la_SOURCES += \
|
||||||
src/uuid/md5.c \
|
src/uuid/md5.c \
|
||||||
src/uuid/sysdep.c \
|
src/uuid/sysdep.c \
|
||||||
src/uuid/uuid.c
|
src/uuid/uuid.c
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
# urlconfig
|
# urlconfig
|
||||||
|
|||||||
@@ -1,16 +1,12 @@
|
|||||||
|
|
||||||
|
|
||||||
#ifndef UPNPGLOBAL_H
|
#ifndef UPNPGLOBAL_H
|
||||||
#define UPNPGLOBAL_H
|
#define UPNPGLOBAL_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*
|
*
|
||||||
* \brief Defines constants that for some reason are not defined on some systems.
|
* \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 MYLIB_LARGEFILE_SENSITIVE && _FILE_OFFSET_BITS+0 != 64
|
||||||
#if defined __GNUC__
|
#if defined __GNUC__
|
||||||
#warning libupnp requires largefile mode - use AC_SYS_LARGEFILE
|
#warning libupnp requires largefile mode - use AC_SYS_LARGEFILE
|
||||||
@@ -19,7 +15,6 @@
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
/*
|
/*
|
||||||
* EXPORT_SPEC
|
* EXPORT_SPEC
|
||||||
@@ -36,21 +31,23 @@
|
|||||||
#endif /* LIBUPNP_EXPORTS */
|
#endif /* LIBUPNP_EXPORTS */
|
||||||
#endif /* UPNP_STATIC_LIB */
|
#endif /* UPNP_STATIC_LIB */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* UPNP_INLINE
|
* UPNP_INLINE
|
||||||
* PRId64
|
* PRId64
|
||||||
|
* PRIzd
|
||||||
* PRIzu
|
* PRIzu
|
||||||
|
* PRIzx
|
||||||
*/
|
*/
|
||||||
#ifdef UPNP_USE_MSVCPP
|
#ifdef UPNP_USE_MSVCPP
|
||||||
/* define some things the M$ VC++ doesn't know */
|
/* define some things the M$ VC++ doesn't know */
|
||||||
#define UPNP_INLINE
|
#define UPNP_INLINE _inline
|
||||||
typedef __int64 int64_t;
|
typedef __int64 int64_t;
|
||||||
#define PRId64 "I64d"
|
#define PRId64 "I64d"
|
||||||
|
#define PRIzd "ld"
|
||||||
#define PRIzu "lu"
|
#define PRIzu "lu"
|
||||||
|
#define PRIzx "lx"
|
||||||
#endif /* UPNP_USE_MSVCPP */
|
#endif /* UPNP_USE_MSVCPP */
|
||||||
|
|
||||||
|
|
||||||
#ifdef UPNP_USE_BCBPP
|
#ifdef UPNP_USE_BCBPP
|
||||||
/* define some things Borland Builder doesn't know */
|
/* define some things Borland Builder doesn't know */
|
||||||
#define UPNP_INLINE inline
|
#define UPNP_INLINE inline
|
||||||
@@ -58,18 +55,20 @@
|
|||||||
#warning The Borland C compiler is probably broken on PRId64,
|
#warning The Borland C compiler is probably broken on PRId64,
|
||||||
#warning please someone provide a proper fix here
|
#warning please someone provide a proper fix here
|
||||||
#define PRId64 "I64d"
|
#define PRId64 "I64d"
|
||||||
|
#define PRIzd "zd"
|
||||||
#define PRIzu "zu"
|
#define PRIzu "zu"
|
||||||
|
#define PRIzx "zx"
|
||||||
#endif /* UPNP_USE_BCBPP */
|
#endif /* UPNP_USE_BCBPP */
|
||||||
|
|
||||||
|
|
||||||
#ifdef __GNUC__
|
#ifdef __GNUC__
|
||||||
#define UPNP_INLINE inline
|
#define UPNP_INLINE inline
|
||||||
|
|
||||||
/* Note with PRIzu that in the case of Mingw32, it's the MS C
|
/* Note with PRIzu that in the case of Mingw32, it's the MS C
|
||||||
* runtime printf which ends up getting called, not the glibc
|
* runtime printf which ends up getting called, not the glibc
|
||||||
* printf, so it genuinely doesn't have "zu"
|
* printf, so it genuinely doesn't have "zu"
|
||||||
*/
|
*/
|
||||||
|
#define PRIzd "ld"
|
||||||
#define PRIzu "lu"
|
#define PRIzu "lu"
|
||||||
|
#define PRIzx "lx"
|
||||||
#endif /* __GNUC__ */
|
#endif /* __GNUC__ */
|
||||||
#else
|
#else
|
||||||
/*!
|
/*!
|
||||||
@@ -88,7 +87,11 @@
|
|||||||
* inline keyword. This definition makes the use of this keyword
|
* inline keyword. This definition makes the use of this keyword
|
||||||
* portable to these systems.
|
* portable to these systems.
|
||||||
*/
|
*/
|
||||||
|
#ifdef __STRICT_ANSI__
|
||||||
|
#define UPNP_INLINE __inline__
|
||||||
|
#else
|
||||||
#define UPNP_INLINE inline
|
#define UPNP_INLINE inline
|
||||||
|
#endif
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Supply the PRId64 printf() macro.
|
* \brief Supply the PRId64 printf() macro.
|
||||||
@@ -98,16 +101,17 @@
|
|||||||
/* #define PRId64 PRId64 */
|
/* #define PRId64 PRId64 */
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Supply the PRIzu printf() macro.
|
* \brief Supply the PRIz* printf() macros.
|
||||||
*
|
*
|
||||||
* This macro was invented so that we can live a little longer with
|
* These macros were invented so that we can live a little longer with
|
||||||
* MSVC lack of C99. "z" is the correct printf() size specifier for
|
* MSVC lack of C99. "z" is the correct printf() size specifier for
|
||||||
* the size_t type.
|
* the size_t type.
|
||||||
*/
|
*/
|
||||||
|
#define PRIzd "zd"
|
||||||
#define PRIzu "zu"
|
#define PRIzu "zu"
|
||||||
|
#define PRIzx "zx"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Defining this macro here gives some interesting information about unused
|
* Defining this macro here gives some interesting information about unused
|
||||||
* functions in the code. Of course, this should never go uncommented on a
|
* functions in the code. Of course, this should never go uncommented on a
|
||||||
@@ -115,6 +119,4 @@
|
|||||||
*/
|
*/
|
||||||
/*#define inline*/
|
/*#define inline*/
|
||||||
|
|
||||||
|
|
||||||
#endif /* UPNPGLOBAL_H */
|
#endif /* UPNPGLOBAL_H */
|
||||||
|
|
||||||
|
|||||||
@@ -1,38 +1,67 @@
|
|||||||
|
|
||||||
|
|
||||||
#ifndef UPNPINET_H
|
#ifndef UPNPINET_H
|
||||||
#define UPNPINET_H
|
#define UPNPINET_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
* \addtogroup Sock
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
* \file
|
* \file
|
||||||
*
|
*
|
||||||
* \brief Provides a platform independent way to include TCP/IP types and functions.
|
* \brief Provides a platform independent way to include TCP/IP types and functions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "UpnpUniStd.h" /* for close() */
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
#include <iphlpapi.h>
|
#include <stdarg.h>
|
||||||
|
#ifndef UPNP_USE_MSVCPP
|
||||||
|
/* Removed: not required (and cause compilation issues) */
|
||||||
|
#include <winbase.h>
|
||||||
|
#include <windef.h>
|
||||||
|
#endif
|
||||||
#include <winsock2.h>
|
#include <winsock2.h>
|
||||||
#include <Ws2tcpip.h>
|
#include <iphlpapi.h>
|
||||||
|
#include <ws2tcpip.h>
|
||||||
|
|
||||||
#define UpnpCloseSocket closesocket
|
#define UpnpCloseSocket closesocket
|
||||||
#else
|
|
||||||
|
#if(_WIN32_WINNT < 0x0600)
|
||||||
|
typedef short sa_family_t;
|
||||||
|
#else
|
||||||
|
typedef ADDRESS_FAMILY sa_family_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else /* WIN32 */
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#if (defined(BSD) && BSD >= 199306) || defined (__FreeBSD_kernel__)
|
#if defined(__sun)
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <sys/sockio.h>
|
||||||
|
#elif (defined(BSD) && BSD >= 199306) || defined (__FreeBSD_kernel__)
|
||||||
#include <ifaddrs.h>
|
#include <ifaddrs.h>
|
||||||
/* Do not move or remove the include below for "sys/socket"!
|
/* Do not move or remove the include below for "sys/socket"!
|
||||||
* Will break FreeBSD builds. */
|
* Will break FreeBSD builds. */
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#endif
|
#endif
|
||||||
|
#include <arpa/inet.h> /* for inet_pton() */
|
||||||
|
#include <net/if.h>
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
|
|
||||||
#include <unistd.h> /* for close(). Do not include in WIN32. */
|
/*! This typedef makes the code slightly more WIN32 tolerant.
|
||||||
#define SOCKET int
|
* On WIN32 systems, SOCKET is unsigned and is not a file
|
||||||
#define INVALID_SOCKET ((SOCKET)(-1))
|
* descriptor. */
|
||||||
#define UpnpCloseSocket close
|
typedef int SOCKET;
|
||||||
#endif
|
|
||||||
|
|
||||||
|
/*! INVALID_SOCKET is unsigned on win32. */
|
||||||
|
#define INVALID_SOCKET (-1)
|
||||||
|
|
||||||
|
/*! select() returns SOCKET_ERROR on win32. */
|
||||||
|
#define SOCKET_ERROR (-1)
|
||||||
|
|
||||||
|
/*! Alias to close() to make code more WIN32 tolerant. */
|
||||||
|
#define UpnpCloseSocket close
|
||||||
|
#endif /* WIN32 */
|
||||||
|
|
||||||
|
/* @} Sock */
|
||||||
|
|
||||||
#endif /* UPNPINET_H */
|
#endif /* UPNPINET_H */
|
||||||
|
|
||||||
|
|||||||
11
upnp/inc/UpnpIntTypes.h
Normal file
11
upnp/inc/UpnpIntTypes.h
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
#ifndef UPNPINTTYPES_H
|
||||||
|
#define UPNPINTTYPES_H
|
||||||
|
|
||||||
|
#if !defined(UPNP_USE_BCBPP)
|
||||||
|
|
||||||
|
/* Printf format for integers. */
|
||||||
|
#include <inttypes.h>
|
||||||
|
|
||||||
|
#endif /* !defined(UPNP_USE_BCBPP) */
|
||||||
|
|
||||||
|
#endif /* UPNPINTTYPES_H */
|
||||||
20
upnp/inc/UpnpStdInt.h
Normal file
20
upnp/inc/UpnpStdInt.h
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
#ifndef UPNPSTDINT_H
|
||||||
|
#define UPNPSTDINT_H
|
||||||
|
|
||||||
|
#if !defined(UPNP_USE_BCBPP)
|
||||||
|
|
||||||
|
/* Sized integer types. */
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#ifdef UPNP_USE_MSVCPP
|
||||||
|
/* no ssize_t defined for VC */
|
||||||
|
#ifdef _WIN64
|
||||||
|
typedef int64_t ssize_t;
|
||||||
|
#else
|
||||||
|
typedef int32_t ssize_t;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* !defined(UPNP_USE_BCBPP) */
|
||||||
|
|
||||||
|
#endif /* UPNPSTDINT_H */
|
||||||
@@ -17,7 +17,7 @@
|
|||||||
*
|
*
|
||||||
* \file
|
* \file
|
||||||
*
|
*
|
||||||
* \brief UpnpString object declarartion.
|
* \brief UpnpString object declaration.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
10
upnp/inc/UpnpUniStd.h
Normal file
10
upnp/inc/UpnpUniStd.h
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
#ifndef UPNPUNISTD_H
|
||||||
|
#define UPNPUNISTD_H
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
/* Do not #include <unistd.h> on WIN32. */
|
||||||
|
#else /* WIN32 */
|
||||||
|
#include <unistd.h> /* for close() */
|
||||||
|
#endif /* WIN32 */
|
||||||
|
|
||||||
|
#endif /* UPNPUNISTD_H */
|
||||||
284
upnp/inc/upnp.h
284
upnp/inc/upnp.h
@@ -1,7 +1,11 @@
|
|||||||
|
#ifndef UPNP_H
|
||||||
|
#define UPNP_H
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (C) 2011-2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,48 +33,36 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef UPNP_H
|
|
||||||
#define UPNP_H
|
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
|
||||||
*
|
|
||||||
* \defgroup UPnPAPI UPnP API
|
* \defgroup UPnPAPI UPnP API
|
||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
|
*
|
||||||
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "ixml.h"
|
#include "ixml.h"
|
||||||
#include "upnpconfig.h"
|
#include "upnpconfig.h"
|
||||||
#include "UpnpGlobal.h"
|
#include "UpnpGlobal.h"
|
||||||
#include "UpnpInet.h"
|
#include "UpnpInet.h"
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* \todo Document the exact reason of these include files and solve this
|
* \todo Document the exact reason of these include files and solve this
|
||||||
* include mess in an include file like UpnpTime.h
|
* include mess in an include file like UpnpTime.h
|
||||||
*/
|
*/
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
#ifdef UPNP_USE_MSVCPP
|
||||||
|
#include <sys/types.h> /* needed for off_t */
|
||||||
|
#endif
|
||||||
#elif (defined(BSD) && BSD >= 199306)
|
#elif (defined(BSD) && BSD >= 199306)
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#else
|
#else
|
||||||
/* Other systems ??? */
|
/* Other systems ??? */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define LINE_SIZE (size_t)180
|
||||||
#ifdef WIN32
|
#define NAME_SIZE (size_t)256
|
||||||
/* Do not #include <sys/param.h> */
|
|
||||||
#else
|
|
||||||
#include <sys/param.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#define LINE_SIZE 180
|
|
||||||
#define NAME_SIZE 256
|
|
||||||
#define MNFT_NAME_SIZE 64
|
#define MNFT_NAME_SIZE 64
|
||||||
#define MODL_NAME_SIZE 32
|
#define MODL_NAME_SIZE 32
|
||||||
#define SERL_NUMR_SIZE 64
|
#define SERL_NUMR_SIZE 64
|
||||||
@@ -79,7 +71,6 @@
|
|||||||
#define UPNP_USING_CHUNKED -3
|
#define UPNP_USING_CHUNKED -3
|
||||||
#define UPNP_UNTIL_CLOSE -4
|
#define UPNP_UNTIL_CLOSE -4
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \name Error codes
|
* \name Error codes
|
||||||
*
|
*
|
||||||
@@ -141,8 +132,9 @@
|
|||||||
#define UPNP_E_BUFFER_TOO_SMALL -106
|
#define UPNP_E_BUFFER_TOO_SMALL -106
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief The description document passed to \b UpnpRegisterRootDevice or
|
* \brief The description document passed to \b UpnpRegisterRootDevice,
|
||||||
* \b UpnpRegisterRootDevice2 is invalid.
|
* \b UpnpRegisterRootDevice2 \b UpnpRegisterRootDevice3 or
|
||||||
|
* \b UpnpRegisterRootDevice4 is invalid.
|
||||||
*/
|
*/
|
||||||
#define UPNP_E_INVALID_DESC -107
|
#define UPNP_E_INVALID_DESC -107
|
||||||
|
|
||||||
@@ -388,19 +380,6 @@
|
|||||||
|
|
||||||
/* @} ErrorCodes */
|
/* @} ErrorCodes */
|
||||||
|
|
||||||
#ifndef OUT
|
|
||||||
#define OUT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef IN
|
|
||||||
#define IN
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef INOUT
|
|
||||||
#define INOUT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#if UPNP_VERSION >= 10800
|
#if UPNP_VERSION >= 10800
|
||||||
/*
|
/*
|
||||||
* Opaque data structures. The following includes are data structures that
|
* Opaque data structures. The following includes are data structures that
|
||||||
@@ -423,7 +402,6 @@
|
|||||||
#include "SubscriptionRequest.h"
|
#include "SubscriptionRequest.h"
|
||||||
#endif /* UPNP_VERSION >= 10800 */
|
#endif /* UPNP_VERSION >= 10800 */
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \name Constants and Types
|
* \name Constants and Types
|
||||||
*
|
*
|
||||||
@@ -447,7 +425,8 @@ typedef int UpnpClient_Handle;
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returned when a device application registers with
|
* \brief Returned when a device application registers with
|
||||||
* \b UpnpRegisterRootDevice or \b UpnpRegisterRootDevice2.
|
* \b UpnpRegisterRootDevice, \b UpnpRegisterRootDevice2,
|
||||||
|
* \b UpnpRegisterRootDevice3 or \b UpnpRegisterRootDevice4.
|
||||||
*
|
*
|
||||||
* Device handles can only be used with functions that operate with a device
|
* Device handles can only be used with functions that operate with a device
|
||||||
* handle.
|
* handle.
|
||||||
@@ -620,7 +599,6 @@ enum Upnp_DescType_e {
|
|||||||
|
|
||||||
typedef enum Upnp_DescType_e Upnp_DescType;
|
typedef enum Upnp_DescType_e Upnp_DescType;
|
||||||
|
|
||||||
|
|
||||||
#if UPNP_VERSION < 10800
|
#if UPNP_VERSION < 10800
|
||||||
/** Returned as part of a {\bf UPNP_CONTROL_ACTION_COMPLETE} callback. */
|
/** Returned as part of a {\bf UPNP_CONTROL_ACTION_COMPLETE} callback. */
|
||||||
|
|
||||||
@@ -778,7 +756,7 @@ struct Upnp_Discovery
|
|||||||
char Ext[LINE_SIZE];
|
char Ext[LINE_SIZE];
|
||||||
|
|
||||||
/** The host address of the device responding to the search. */
|
/** The host address of the device responding to the search. */
|
||||||
struct sockaddr_in DestAddr;
|
struct sockaddr_storage DestAddr;
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Returned along with a {\bf UPNP_EVENT_SUBSCRIBE_COMPLETE} or {\bf
|
/** Returned along with a {\bf UPNP_EVENT_SUBSCRIBE_COMPLETE} or {\bf
|
||||||
@@ -821,7 +799,6 @@ struct Upnp_Subscription_Request
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
struct File_Info
|
struct File_Info
|
||||||
{
|
{
|
||||||
/** The length of the file. A length less than 0 indicates the size
|
/** The length of the file. A length less than 0 indicates the size
|
||||||
@@ -848,7 +825,6 @@ struct File_Info
|
|||||||
};
|
};
|
||||||
#endif /* UPNP_VERSION < 10800 */
|
#endif /* UPNP_VERSION < 10800 */
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* All callback functions share the same prototype, documented below.
|
* All callback functions share the same prototype, documented below.
|
||||||
* Note that any memory passed to the callback function
|
* Note that any memory passed to the callback function
|
||||||
@@ -884,19 +860,16 @@ typedef int (*Upnp_FunPtr)(
|
|||||||
|
|
||||||
/* @} Constants and Types */
|
/* @} Constants and Types */
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \name Initialization and Registration
|
* \name Initialization and Registration
|
||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Initializes the Linux SDK for UPnP Devices (IPv4 only).
|
* \brief Initializes the Linux SDK for UPnP Devices (IPv4 only).
|
||||||
*
|
*
|
||||||
@@ -938,7 +911,6 @@ EXPORT_SPEC int UpnpInit(
|
|||||||
* \c NULL will pick an arbitrary free port. */
|
* \c NULL will pick an arbitrary free port. */
|
||||||
unsigned short DestPort);
|
unsigned short DestPort);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Initializes the Linux SDK for UPnP Devices (IPv4 or IPv6).
|
* \brief Initializes the Linux SDK for UPnP Devices (IPv4 or IPv6).
|
||||||
*
|
*
|
||||||
@@ -982,7 +954,6 @@ EXPORT_SPEC int UpnpInit2(
|
|||||||
unsigned short DestPort);
|
unsigned short DestPort);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Terminates the Linux SDK for UPnP Devices.
|
* \brief Terminates the Linux SDK for UPnP Devices.
|
||||||
*
|
*
|
||||||
@@ -1004,7 +975,6 @@ EXPORT_SPEC int UpnpInit2(
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpFinish(void);
|
EXPORT_SPEC int UpnpFinish(void);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns the internal server IPv4 UPnP listening port.
|
* \brief Returns the internal server IPv4 UPnP listening port.
|
||||||
*
|
*
|
||||||
@@ -1018,7 +988,6 @@ EXPORT_SPEC int UpnpFinish(void);
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC unsigned short UpnpGetServerPort(void);
|
EXPORT_SPEC unsigned short UpnpGetServerPort(void);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns the internal server IPv6 UPnP listening port.
|
* \brief Returns the internal server IPv6 UPnP listening port.
|
||||||
*
|
*
|
||||||
@@ -1046,7 +1015,6 @@ EXPORT_SPEC unsigned short UpnpGetServerPort6(void);
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC char *UpnpGetServerIpAddress(void);
|
EXPORT_SPEC char *UpnpGetServerIpAddress(void);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns the local IPv6 listening ip address.
|
* \brief Returns the local IPv6 listening ip address.
|
||||||
*
|
*
|
||||||
@@ -1198,7 +1166,6 @@ EXPORT_SPEC int UpnpRegisterRootDevice2(
|
|||||||
/*! [out] Pointer to a variable to store the new device handle. */
|
/*! [out] Pointer to a variable to store the new device handle. */
|
||||||
UpnpDevice_Handle* Hnd);
|
UpnpDevice_Handle* Hnd);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Registers a device application for a specific address family with
|
* \brief Registers a device application for a specific address family with
|
||||||
* the UPnP library.
|
* the UPnP library.
|
||||||
@@ -1246,12 +1213,65 @@ EXPORT_SPEC int UpnpRegisterRootDevice3(
|
|||||||
UpnpDevice_Handle *Hnd,
|
UpnpDevice_Handle *Hnd,
|
||||||
/*! [in] Address family of this device. Can be AF_INET for an IPv4 device, or
|
/*! [in] Address family of this device. Can be AF_INET for an IPv4 device, or
|
||||||
* AF_INET6 for an IPv6 device. Defaults to AF_INET. */
|
* AF_INET6 for an IPv6 device. Defaults to AF_INET. */
|
||||||
const int AddressFamily);
|
int AddressFamily);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Unregisters a root device registered with \b UpnpRegisterRootDevice or
|
* \brief Registers a device application for a specific address family with
|
||||||
* \b UpnpRegisterRootDevice2.
|
* the UPnP library. This function can also be used to specify a dedicated
|
||||||
|
* description URL to be returned for legacy CPs.
|
||||||
|
*
|
||||||
|
* A device application cannot make any other API calls until it registers
|
||||||
|
* using this function. Device applications can also register as control
|
||||||
|
* points (see \b UpnpRegisterClient to get a control point handle to perform
|
||||||
|
* control point functionality).
|
||||||
|
*
|
||||||
|
* This is synchronous and does not generate any callbacks. Callbacks can occur
|
||||||
|
* as soon as this function returns.
|
||||||
|
*
|
||||||
|
* \return An integer representing one of the following:
|
||||||
|
* \li \c UPNP_E_SUCCESS: The operation completed successfully.
|
||||||
|
* \li \c UPNP_E_FINISH: The SDK is already terminated or
|
||||||
|
* is not initialized.
|
||||||
|
* \li \c UPNP_E_INVALID_DESC: The description document was not
|
||||||
|
* a valid device description.
|
||||||
|
* \li \c UPNP_E_INVALID_URL: The URL for the description document
|
||||||
|
* is not valid.
|
||||||
|
* \li \c UPNP_E_INVALID_PARAM: Either \b Callback or \b Hnd
|
||||||
|
* is not a valid pointer or \b DescURL is \c NULL.
|
||||||
|
* \li \c UPNP_E_NETWORK_ERROR: A network error occurred.
|
||||||
|
* \li \c UPNP_E_SOCKET_WRITE: An error or timeout occurred writing
|
||||||
|
* to a socket.
|
||||||
|
* \li \c UPNP_E_SOCKET_READ: An error or timeout occurred reading
|
||||||
|
* from a socket.
|
||||||
|
* \li \c UPNP_E_SOCKET_BIND: An error occurred binding a socket.
|
||||||
|
* \li \c UPNP_E_SOCKET_CONNECT: An error occurred connecting the
|
||||||
|
* socket.
|
||||||
|
* \li \c UPNP_E_OUTOF_SOCKET: Too many sockets are currently
|
||||||
|
* allocated.
|
||||||
|
* \li \c UPNP_E_OUTOF_MEMORY: There are insufficient resources to
|
||||||
|
* register this root device.
|
||||||
|
*/
|
||||||
|
EXPORT_SPEC int UpnpRegisterRootDevice4(
|
||||||
|
/*! [in] Pointer to a string containing the description URL for this root
|
||||||
|
* device instance. */
|
||||||
|
const char *DescUrl,
|
||||||
|
/*! [in] Pointer to the callback function for receiving asynchronous events. */
|
||||||
|
Upnp_FunPtr Callback,
|
||||||
|
/*! [in] Pointer to user data returned with the callback function when invoked. */
|
||||||
|
const void *Cookie,
|
||||||
|
/*! [out] Pointer to a variable to store the new device handle. */
|
||||||
|
UpnpDevice_Handle *Hnd,
|
||||||
|
/*! [in] Address family of this device. Can be AF_INET for an IPv4 device, or
|
||||||
|
* AF_INET6 for an IPv6 device. Defaults to AF_INET. */
|
||||||
|
int AddressFamily,
|
||||||
|
/*! [in] Pointer to a string containing the description URL to be returned for
|
||||||
|
* legacy CPs for this root device instance. */
|
||||||
|
const char *LowerDescUrl);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Unregisters a root device registered with \b UpnpRegisterRootDevice,
|
||||||
|
* \b UpnpRegisterRootDevice2, \b UpnpRegisterRootDevice3 or
|
||||||
|
* \b UpnpRegisterRootDevice4.
|
||||||
*
|
*
|
||||||
* After this call, the \b UpnpDevice_Handle is no longer valid. For all
|
* After this call, the \b UpnpDevice_Handle is no longer valid. For all
|
||||||
* advertisements that have not yet expired, the SDK sends a device unavailable
|
* advertisements that have not yet expired, the SDK sends a device unavailable
|
||||||
@@ -1268,6 +1288,34 @@ EXPORT_SPEC int UpnpUnRegisterRootDevice(
|
|||||||
/*! [in] The handle of the root device instance to unregister. */
|
/*! [in] The handle of the root device instance to unregister. */
|
||||||
UpnpDevice_Handle Hnd);
|
UpnpDevice_Handle Hnd);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Unregisters a root device registered with \b UpnpRegisterRootDevice,
|
||||||
|
* \b UpnpRegisterRootDevice2, \b UpnpRegisterRootDevice3 or
|
||||||
|
* \b UpnpRegisterRootDevice4.
|
||||||
|
*
|
||||||
|
* After this call, the \b UpnpDevice_Handle is no longer valid. For all
|
||||||
|
* advertisements that have not yet expired, the SDK sends a device unavailable
|
||||||
|
* message automatically.
|
||||||
|
*
|
||||||
|
* This is a synchronous call and generates no callbacks. Once this call
|
||||||
|
* returns, the SDK will no longer generate callbacks to the application.
|
||||||
|
*
|
||||||
|
* This function allow a device to specify the SSDP extensions defined by UPnP
|
||||||
|
* Low Power.
|
||||||
|
*
|
||||||
|
* \return An integer representing one of the following:
|
||||||
|
* \li \c UPNP_E_SUCCESS: The operation completed successfully.
|
||||||
|
* \li \c UPNP_E_INVALID_HANDLE: The handle is not a valid device handle.
|
||||||
|
*/
|
||||||
|
EXPORT_SPEC int UpnpUnRegisterRootDeviceLowPower(
|
||||||
|
/*! [in] The handle of the root device instance to unregister. */
|
||||||
|
UpnpDevice_Handle Hnd,
|
||||||
|
/*! PowerState as defined by UPnP Low Power. */
|
||||||
|
int PowerState,
|
||||||
|
/*! SleepPeriod as defined by UPnP Low Power. */
|
||||||
|
int SleepPeriod,
|
||||||
|
/*! RegistrationState as defined by UPnP Low Power. */
|
||||||
|
int RegistrationState);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Registers a control point application with the UPnP Library.
|
* \brief Registers a control point application with the UPnP Library.
|
||||||
@@ -1295,7 +1343,6 @@ EXPORT_SPEC int UpnpRegisterClient(
|
|||||||
/*! [out] Pointer to a variable to store the new control point handle. */
|
/*! [out] Pointer to a variable to store the new control point handle. */
|
||||||
UpnpClient_Handle *Hnd);
|
UpnpClient_Handle *Hnd);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Unregisters a control point application, unsubscribing all active
|
* \brief Unregisters a control point application, unsubscribing all active
|
||||||
* subscriptions.
|
* subscriptions.
|
||||||
@@ -1316,7 +1363,6 @@ EXPORT_SPEC int UpnpUnRegisterClient(
|
|||||||
/*! [in] The handle of the control point instance to unregister. */
|
/*! [in] The handle of the control point instance to unregister. */
|
||||||
UpnpClient_Handle Hnd);
|
UpnpClient_Handle Hnd);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \deprecated Use \b UpnpSetMaxContentLength instead.
|
* \deprecated Use \b UpnpSetMaxContentLength instead.
|
||||||
*
|
*
|
||||||
@@ -1328,8 +1374,7 @@ EXPORT_SPEC int UpnpSetContentLength(
|
|||||||
* length needs to be set. */
|
* length needs to be set. */
|
||||||
UpnpClient_Handle Hnd,
|
UpnpClient_Handle Hnd,
|
||||||
/*! [in] Permissible content length */
|
/*! [in] Permissible content length */
|
||||||
int contentLength);
|
size_t contentLength);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the maximum content-length that the SDK will process on an
|
* \brief Sets the maximum content-length that the SDK will process on an
|
||||||
@@ -1352,10 +1397,8 @@ EXPORT_SPEC int UpnpSetMaxContentLength(
|
|||||||
* in bytes. */
|
* in bytes. */
|
||||||
size_t contentLength);
|
size_t contentLength);
|
||||||
|
|
||||||
|
|
||||||
/* @} Initialization and Registration */
|
/* @} Initialization and Registration */
|
||||||
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
* *
|
* *
|
||||||
@@ -1364,14 +1407,12 @@ EXPORT_SPEC int UpnpSetMaxContentLength(
|
|||||||
******************************************************************************
|
******************************************************************************
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \name Discovery
|
* \name Discovery
|
||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Searches for devices matching the given search target.
|
* \brief Searches for devices matching the given search target.
|
||||||
*
|
*
|
||||||
@@ -1430,10 +1471,38 @@ EXPORT_SPEC int UpnpSendAdvertisement(
|
|||||||
/*! The expiration age, in seconds, of the announcements. */
|
/*! The expiration age, in seconds, of the announcements. */
|
||||||
int Exp);
|
int Exp);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Sends out the discovery announcements for all devices and services
|
||||||
|
* for a device.
|
||||||
|
*
|
||||||
|
* Each announcement is made with the same expiration time.
|
||||||
|
*
|
||||||
|
* This is a synchronous call.
|
||||||
|
*
|
||||||
|
* This function allow a device to specify the SSDP extensions defined by UPnP
|
||||||
|
* Low Power.
|
||||||
|
*
|
||||||
|
* \return An integer representing one of the following:
|
||||||
|
* \li \c UPNP_E_SUCCESS: The operation completed successfully.
|
||||||
|
* \li \c UPNP_E_INVALID_HANDLE: The handle is not a valid
|
||||||
|
* device handle.
|
||||||
|
* \li \c UPNP_E_OUTOF_MEMORY: There are insufficient resources to
|
||||||
|
* send future advertisements.
|
||||||
|
*/
|
||||||
|
EXPORT_SPEC int UpnpSendAdvertisementLowPower(
|
||||||
|
/*! The device handle for which to send out the announcements. */
|
||||||
|
UpnpDevice_Handle Hnd,
|
||||||
|
/*! The expiration age, in seconds, of the announcements. */
|
||||||
|
int Exp,
|
||||||
|
/*! PowerState as defined by UPnP Low Power. */
|
||||||
|
int PowerState,
|
||||||
|
/*! SleepPeriod as defined by UPnP Low Power. */
|
||||||
|
int SleepPeriod,
|
||||||
|
/*! RegistrationState as defined by UPnP Low Power. */
|
||||||
|
int RegistrationState);
|
||||||
|
|
||||||
/* @} Discovery */
|
/* @} Discovery */
|
||||||
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
* *
|
* *
|
||||||
@@ -1442,14 +1511,12 @@ EXPORT_SPEC int UpnpSendAdvertisement(
|
|||||||
******************************************************************************
|
******************************************************************************
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \name Control
|
* \name Control
|
||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Queries the state of a state variable of a service on another device.
|
* \brief Queries the state of a state variable of a service on another device.
|
||||||
*
|
*
|
||||||
@@ -1487,7 +1554,6 @@ EXPORT_SPEC int UpnpGetServiceVarStatus(
|
|||||||
* \b ixmlFreeDOMString. */
|
* \b ixmlFreeDOMString. */
|
||||||
DOMString *StVarVal);
|
DOMString *StVarVal);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Queries the state of a variable of a service, generating a callback
|
* \brief Queries the state of a variable of a service, generating a callback
|
||||||
* when the operation is complete.
|
* when the operation is complete.
|
||||||
@@ -1518,7 +1584,6 @@ EXPORT_SPEC int UpnpGetServiceVarStatusAsync(
|
|||||||
/*! [in] Pointer to user data to pass to the callback function when invoked. */
|
/*! [in] Pointer to user data to pass to the callback function when invoked. */
|
||||||
const void *Cookie);
|
const void *Cookie);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends a message to change a state variable in a service.
|
* \brief Sends a message to change a state variable in a service.
|
||||||
*
|
*
|
||||||
@@ -1557,7 +1622,6 @@ EXPORT_SPEC int UpnpSendAction(
|
|||||||
* this document and the caller needs to free it. */
|
* this document and the caller needs to free it. */
|
||||||
IXML_Document **RespNode);
|
IXML_Document **RespNode);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends a message to change a state variable in a service.
|
* \brief Sends a message to change a state variable in a service.
|
||||||
*
|
*
|
||||||
@@ -1599,7 +1663,6 @@ EXPORT_SPEC int UpnpSendActionEx(
|
|||||||
* this document and the caller needs to free it. */
|
* this document and the caller needs to free it. */
|
||||||
IXML_Document **RespNode);
|
IXML_Document **RespNode);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends a message to change a state variable in a service, generating a
|
* \brief Sends a message to change a state variable in a service, generating a
|
||||||
* callback when the operation is complete.
|
* callback when the operation is complete.
|
||||||
@@ -1639,7 +1702,6 @@ EXPORT_SPEC int UpnpSendActionAsync(
|
|||||||
* invoked. */
|
* invoked. */
|
||||||
const void *Cookie);
|
const void *Cookie);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends a message to change a state variable in a service, generating a
|
* \brief Sends a message to change a state variable in a service, generating a
|
||||||
* callback when the operation is complete.
|
* callback when the operation is complete.
|
||||||
@@ -1682,10 +1744,8 @@ EXPORT_SPEC int UpnpSendActionExAsync(
|
|||||||
* invoked. */
|
* invoked. */
|
||||||
const void *Cookie);
|
const void *Cookie);
|
||||||
|
|
||||||
|
|
||||||
/*! @} Control */
|
/*! @} Control */
|
||||||
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
* *
|
* *
|
||||||
@@ -1694,14 +1754,12 @@ EXPORT_SPEC int UpnpSendActionExAsync(
|
|||||||
******************************************************************************
|
******************************************************************************
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \name Eventing
|
* \name Eventing
|
||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Accepts a subscription request and sends out the current state of the
|
* \brief Accepts a subscription request and sends out the current state of the
|
||||||
* eventable variables for a service.
|
* eventable variables for a service.
|
||||||
@@ -1743,7 +1801,6 @@ EXPORT_SPEC int UpnpAcceptSubscription(
|
|||||||
/*! [in] The subscription ID of the newly registered control point. */
|
/*! [in] The subscription ID of the newly registered control point. */
|
||||||
const Upnp_SID SubsId);
|
const Upnp_SID SubsId);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Similar to \b UpnpAcceptSubscription() except that it takes a DOM
|
* \brief Similar to \b UpnpAcceptSubscription() except that it takes a DOM
|
||||||
* document for the variables to event rather than an array of strings.
|
* document for the variables to event rather than an array of strings.
|
||||||
@@ -1780,7 +1837,6 @@ EXPORT_SPEC int UpnpAcceptSubscriptionExt(
|
|||||||
/*! [in] The subscription ID of the newly registered control point. */
|
/*! [in] The subscription ID of the newly registered control point. */
|
||||||
Upnp_SID SubsId);
|
Upnp_SID SubsId);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends out an event change notification to all control points
|
* \brief Sends out an event change notification to all control points
|
||||||
* subscribed to a particular service.
|
* subscribed to a particular service.
|
||||||
@@ -1816,7 +1872,6 @@ EXPORT_SPEC int UpnpNotify(
|
|||||||
/*! [in] The count of variables included in this notification. */
|
/*! [in] The count of variables included in this notification. */
|
||||||
int cVariables);
|
int cVariables);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Similar to \b UpnpNotify except that it takes a DOM document for the
|
* \brief Similar to \b UpnpNotify except that it takes a DOM document for the
|
||||||
* event rather than an array of strings.
|
* event rather than an array of strings.
|
||||||
@@ -1850,7 +1905,6 @@ EXPORT_SPEC int UpnpNotifyExt(
|
|||||||
* Plug and Play Device Architecture specification. */
|
* Plug and Play Device Architecture specification. */
|
||||||
IXML_Document *PropSet);
|
IXML_Document *PropSet);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Renews a subscription that is about to expire.
|
* \brief Renews a subscription that is about to expire.
|
||||||
*
|
*
|
||||||
@@ -1888,7 +1942,6 @@ EXPORT_SPEC int UpnpRenewSubscription(
|
|||||||
/*! [in] The ID for the subscription to renew. */
|
/*! [in] The ID for the subscription to renew. */
|
||||||
const Upnp_SID SubsId);
|
const Upnp_SID SubsId);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Renews a subscription that is about to expire, generating a callback
|
* \brief Renews a subscription that is about to expire, generating a callback
|
||||||
* when the operation is complete.
|
* when the operation is complete.
|
||||||
@@ -1950,7 +2003,6 @@ EXPORT_SPEC int UpnpRenewSubscriptionAsync(
|
|||||||
/*! [in] Pointer to user data passed to the callback function when invoked. */
|
/*! [in] Pointer to user data passed to the callback function when invoked. */
|
||||||
const void *Cookie);
|
const void *Cookie);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the maximum number of subscriptions accepted per service.
|
* \brief Sets the maximum number of subscriptions accepted per service.
|
||||||
*
|
*
|
||||||
@@ -1971,7 +2023,6 @@ EXPORT_SPEC int UpnpSetMaxSubscriptions(
|
|||||||
/*! The maximum number of subscriptions to be allowed per service. */
|
/*! The maximum number of subscriptions to be allowed per service. */
|
||||||
int MaxSubscriptions);
|
int MaxSubscriptions);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the maximum time-out accepted for a subscription request or
|
* \brief Sets the maximum time-out accepted for a subscription request or
|
||||||
* renewal.
|
* renewal.
|
||||||
@@ -1993,7 +2044,6 @@ EXPORT_SPEC int UpnpSetMaxSubscriptionTimeOut(
|
|||||||
/*! The maximum subscription time-out to be accepted. */
|
/*! The maximum subscription time-out to be accepted. */
|
||||||
int MaxSubscriptionTimeOut);
|
int MaxSubscriptionTimeOut);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Registers a control point to receive event notifications from another
|
* \brief Registers a control point to receive event notifications from another
|
||||||
* device.
|
* device.
|
||||||
@@ -2035,7 +2085,6 @@ EXPORT_SPEC int UpnpSubscribe(
|
|||||||
/*! [out] Pointer to a variable to receive the subscription ID (SID). */
|
/*! [out] Pointer to a variable to receive the subscription ID (SID). */
|
||||||
Upnp_SID SubsId);
|
Upnp_SID SubsId);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Performs the same operation as \b UpnpSubscribe, but returns
|
* \brief Performs the same operation as \b UpnpSubscribe, but returns
|
||||||
* immediately and calls the registered callback function when the operation
|
* immediately and calls the registered callback function when the operation
|
||||||
@@ -2097,7 +2146,6 @@ EXPORT_SPEC int UpnpSubscribeAsync(
|
|||||||
/*! A user data value passed to the callback function when invoked. */
|
/*! A user data value passed to the callback function when invoked. */
|
||||||
const void *Cookie);
|
const void *Cookie);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Removes the subscription of a control point from a service previously
|
* \brief Removes the subscription of a control point from a service previously
|
||||||
* subscribed to using \b UpnpSubscribe or \b UpnpSubscribeAsync.
|
* subscribed to using \b UpnpSubscribe or \b UpnpSubscribeAsync.
|
||||||
@@ -2133,7 +2181,6 @@ EXPORT_SPEC int UpnpUnSubscribe(
|
|||||||
/*! [in] The ID returned when the control point subscribed to the service. */
|
/*! [in] The ID returned when the control point subscribed to the service. */
|
||||||
const Upnp_SID SubsId);
|
const Upnp_SID SubsId);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Removes a subscription of a control point from a service previously
|
* \brief Removes a subscription of a control point from a service previously
|
||||||
* subscribed to using \b UpnpSubscribe or \b UpnpSubscribeAsync, generating
|
* subscribed to using \b UpnpSubscribe or \b UpnpSubscribeAsync, generating
|
||||||
@@ -2191,11 +2238,9 @@ EXPORT_SPEC int UpnpUnSubscribeAsync(
|
|||||||
/*! [in] Pointer to user data to pass to the callback function when invoked. */
|
/*! [in] Pointer to user data to pass to the callback function when invoked. */
|
||||||
const void *Cookie);
|
const void *Cookie);
|
||||||
|
|
||||||
|
|
||||||
/*! @} Eventing */
|
/*! @} Eventing */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
* *
|
* *
|
||||||
@@ -2245,7 +2290,6 @@ EXPORT_SPEC int UpnpDownloadUrlItem(
|
|||||||
* \c LINE_SIZE bytes in size. */
|
* \c LINE_SIZE bytes in size. */
|
||||||
char *contentType);
|
char *contentType);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Gets a file specified in a URL.
|
* \brief Gets a file specified in a URL.
|
||||||
*
|
*
|
||||||
@@ -2290,7 +2334,6 @@ EXPORT_SPEC int UpnpOpenHttpGet(
|
|||||||
* back to the user. */
|
* back to the user. */
|
||||||
int timeout);
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Gets a file specified in a URL through the specified proxy.
|
* \brief Gets a file specified in a URL through the specified proxy.
|
||||||
*
|
*
|
||||||
@@ -2337,7 +2380,6 @@ EXPORT_SPEC int UpnpOpenHttpGetProxy(
|
|||||||
* back to the user. */
|
* back to the user. */
|
||||||
int timeout);
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Gets specified number of bytes from a file specified in the URL.
|
* \brief Gets specified number of bytes from a file specified in the URL.
|
||||||
*
|
*
|
||||||
@@ -2388,7 +2430,6 @@ EXPORT_SPEC int UpnpOpenHttpGetEx(
|
|||||||
* to the user. */
|
* to the user. */
|
||||||
int timeout);
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Gets specified number of bytes from a file specified in a URL.
|
* \brief Gets specified number of bytes from a file specified in a URL.
|
||||||
*
|
*
|
||||||
@@ -2412,13 +2453,12 @@ EXPORT_SPEC int UpnpReadHttpGet(
|
|||||||
/*! [in,out] The buffer to store the read item. */
|
/*! [in,out] The buffer to store the read item. */
|
||||||
char *buf,
|
char *buf,
|
||||||
/*! [in,out] The size of the buffer to be read. */
|
/*! [in,out] The size of the buffer to be read. */
|
||||||
unsigned int *size,
|
size_t *size,
|
||||||
/*! [in] The time out value sent with the request during which a response is
|
/*! [in] The time out value sent with the request during which a response is
|
||||||
* expected from the server, failing which, an error is reported back to
|
* expected from the server, failing which, an error is reported back to
|
||||||
* the user. */
|
* the user. */
|
||||||
int timeout);
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Retrieve progress information of a http-get transfer.
|
* \brief Retrieve progress information of a http-get transfer.
|
||||||
*
|
*
|
||||||
@@ -2431,10 +2471,9 @@ EXPORT_SPEC int UpnpHttpGetProgress(
|
|||||||
/*! [in] The token created by the call to \b UpnpOpenHttpGet. */
|
/*! [in] The token created by the call to \b UpnpOpenHttpGet. */
|
||||||
void *handle,
|
void *handle,
|
||||||
/*! [out] The number of bytes received. */
|
/*! [out] The number of bytes received. */
|
||||||
unsigned int *length,
|
size_t *length,
|
||||||
/*! [out] The content length. */
|
/*! [out] The content length. */
|
||||||
unsigned int *total);
|
size_t *total);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Set the cancel flag of the \b handle parameter.
|
* \brief Set the cancel flag of the \b handle parameter.
|
||||||
@@ -2461,7 +2500,6 @@ EXPORT_SPEC int UpnpCloseHttpGet(
|
|||||||
* \b UpnpOpenHttpGet. */
|
* \b UpnpOpenHttpGet. */
|
||||||
void *handle);
|
void *handle);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Makes an HTTP POST request message, opens a connection to the server
|
* \brief Makes an HTTP POST request message, opens a connection to the server
|
||||||
* and sends the POST request to the server if the connection to the server
|
* and sends the POST request to the server if the connection to the server
|
||||||
@@ -2501,7 +2539,6 @@ EXPORT_SPEC int UpnpOpenHttpPost(
|
|||||||
* is expected from the receiver, failing which, an error is reported. */
|
* is expected from the receiver, failing which, an error is reported. */
|
||||||
int timeout);
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends a request to a server to copy the contents of a buffer to the
|
* \brief Sends a request to a server to copy the contents of a buffer to the
|
||||||
* URI specified in the \b UpnpOpenHttpPost call.
|
* URI specified in the \b UpnpOpenHttpPost call.
|
||||||
@@ -2522,12 +2559,11 @@ EXPORT_SPEC int UpnpWriteHttpPost(
|
|||||||
/*! [in] The buffer to be posted. */
|
/*! [in] The buffer to be posted. */
|
||||||
char *buf,
|
char *buf,
|
||||||
/*! [in] The size, in bytes of \b buf. */
|
/*! [in] The size, in bytes of \b buf. */
|
||||||
unsigned int *size,
|
size_t *size,
|
||||||
/*! [in] A timeout value sent with the request during which a response is
|
/*! [in] A timeout value sent with the request during which a response is
|
||||||
* expected from the server, failing which, an error is reported. */
|
* expected from the server, failing which, an error is reported. */
|
||||||
int timeout);
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends and receives any pending data, closes the connection with the
|
* \brief Sends and receives any pending data, closes the connection with the
|
||||||
* server, and frees memory allocated during the \b UpnpOpenHttpPost call.
|
* server, and frees memory allocated during the \b UpnpOpenHttpPost call.
|
||||||
@@ -2551,7 +2587,6 @@ EXPORT_SPEC int UpnpCloseHttpPost(
|
|||||||
* expected from the server, failing which, an error is reported. */
|
* expected from the server, failing which, an error is reported. */
|
||||||
int timeout);
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Downloads an XML document specified in a URL.
|
* \brief Downloads an XML document specified in a URL.
|
||||||
*
|
*
|
||||||
@@ -2585,7 +2620,6 @@ EXPORT_SPEC int UpnpDownloadXmlDoc(
|
|||||||
/*! [out] A pointer in which to store the XML document. */
|
/*! [out] A pointer in which to store the XML document. */
|
||||||
IXML_Document **xmlDoc);
|
IXML_Document **xmlDoc);
|
||||||
|
|
||||||
|
|
||||||
/*! @} Control Point HTTP API */
|
/*! @} Control Point HTTP API */
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
@@ -2622,13 +2656,11 @@ EXPORT_SPEC int UpnpSetWebServerRootDir(
|
|||||||
/*! [in] Path of the root directory of the web server. */
|
/*! [in] Path of the root directory of the web server. */
|
||||||
const char *rootDir);
|
const char *rootDir);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief The type of handle returned by the web server for open requests.
|
* \brief The type of handle returned by the web server for open requests.
|
||||||
*/
|
*/
|
||||||
typedef void *UpnpWebFileHandle;
|
typedef void *UpnpWebFileHandle;
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Get-info callback function prototype.
|
* \brief Get-info callback function prototype.
|
||||||
*/
|
*/
|
||||||
@@ -2643,7 +2675,6 @@ typedef int (*VDCallback_GetInfo)(
|
|||||||
#endif /* UPNP_VERSION < 10800 */
|
#endif /* UPNP_VERSION < 10800 */
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the get_info callback function to be used to access a virtual
|
* \brief Sets the get_info callback function to be used to access a virtual
|
||||||
* directory.
|
* directory.
|
||||||
@@ -2654,7 +2685,6 @@ typedef int (*VDCallback_GetInfo)(
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpVirtualDir_set_GetInfoCallback(VDCallback_GetInfo callback);
|
EXPORT_SPEC int UpnpVirtualDir_set_GetInfoCallback(VDCallback_GetInfo callback);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Open callback function prototype.
|
* \brief Open callback function prototype.
|
||||||
*/
|
*/
|
||||||
@@ -2665,7 +2695,6 @@ typedef UpnpWebFileHandle (*VDCallback_Open)(
|
|||||||
* Valid values are \c UPNP_READ or \c UPNP_WRITE. */
|
* Valid values are \c UPNP_READ or \c UPNP_WRITE. */
|
||||||
enum UpnpOpenFileMode Mode);
|
enum UpnpOpenFileMode Mode);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the open callback function to be used to access a virtual
|
* \brief Sets the open callback function to be used to access a virtual
|
||||||
* directory.
|
* directory.
|
||||||
@@ -2676,7 +2705,6 @@ typedef UpnpWebFileHandle (*VDCallback_Open)(
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpVirtualDir_set_OpenCallback(VDCallback_Open callback);
|
EXPORT_SPEC int UpnpVirtualDir_set_OpenCallback(VDCallback_Open callback);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Read callback function prototype.
|
* \brief Read callback function prototype.
|
||||||
*/
|
*/
|
||||||
@@ -2688,7 +2716,6 @@ typedef int (*VDCallback_Read)(
|
|||||||
/*! [in] The size of the buffer (i.e. the number of bytes to read). */
|
/*! [in] The size of the buffer (i.e. the number of bytes to read). */
|
||||||
size_t buflen);
|
size_t buflen);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the read callback function to be used to access a virtual
|
* \brief Sets the read callback function to be used to access a virtual
|
||||||
* directory.
|
* directory.
|
||||||
@@ -2699,7 +2726,6 @@ typedef int (*VDCallback_Read)(
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpVirtualDir_set_ReadCallback(VDCallback_Read callback);
|
EXPORT_SPEC int UpnpVirtualDir_set_ReadCallback(VDCallback_Read callback);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Write callback function prototype.
|
* \brief Write callback function prototype.
|
||||||
*/
|
*/
|
||||||
@@ -2711,7 +2737,6 @@ typedef int (*VDCallback_Write)(
|
|||||||
/*! [in] The number of bytes to write. */
|
/*! [in] The number of bytes to write. */
|
||||||
size_t buflen);
|
size_t buflen);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the write callback function to be used to access a virtual
|
* \brief Sets the write callback function to be used to access a virtual
|
||||||
* directory.
|
* directory.
|
||||||
@@ -2722,7 +2747,6 @@ typedef int (*VDCallback_Write)(
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpVirtualDir_set_WriteCallback(VDCallback_Write callback);
|
EXPORT_SPEC int UpnpVirtualDir_set_WriteCallback(VDCallback_Write callback);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Seek callback function prototype.
|
* \brief Seek callback function prototype.
|
||||||
*/
|
*/
|
||||||
@@ -2739,7 +2763,6 @@ typedef int (*VDCallback_Seek) (
|
|||||||
* specify an absolute offset. */
|
* specify an absolute offset. */
|
||||||
int origin);
|
int origin);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the seek callback function to be used to access a virtual
|
* \brief Sets the seek callback function to be used to access a virtual
|
||||||
* directory.
|
* directory.
|
||||||
@@ -2750,7 +2773,6 @@ typedef int (*VDCallback_Seek) (
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpVirtualDir_set_SeekCallback(VDCallback_Seek callback);
|
EXPORT_SPEC int UpnpVirtualDir_set_SeekCallback(VDCallback_Seek callback);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Close callback function prototype.
|
* \brief Close callback function prototype.
|
||||||
*/
|
*/
|
||||||
@@ -2758,7 +2780,6 @@ typedef int (*VDCallback_Close)(
|
|||||||
/*! [in] The handle of the file to close. */
|
/*! [in] The handle of the file to close. */
|
||||||
UpnpWebFileHandle fileHnd);
|
UpnpWebFileHandle fileHnd);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sets the close callback function to be used to access a virtual
|
* \brief Sets the close callback function to be used to access a virtual
|
||||||
* directory.
|
* directory.
|
||||||
@@ -2769,6 +2790,20 @@ typedef int (*VDCallback_Close)(
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpVirtualDir_set_CloseCallback(VDCallback_Close callback);
|
EXPORT_SPEC int UpnpVirtualDir_set_CloseCallback(VDCallback_Close callback);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The {\bf UpnpVirtualDirCallbacks} structure contains the pointers to
|
||||||
|
* file-related callback functions a device application can register to
|
||||||
|
* virtualize URLs.
|
||||||
|
*/
|
||||||
|
struct UpnpVirtualDirCallbacks
|
||||||
|
{
|
||||||
|
VDCallback_GetInfo get_info;
|
||||||
|
VDCallback_Open open;
|
||||||
|
VDCallback_Read read;
|
||||||
|
VDCallback_Write write;
|
||||||
|
VDCallback_Seek seek;
|
||||||
|
VDCallback_Close close;
|
||||||
|
};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Enables or disables the webserver.
|
* \brief Enables or disables the webserver.
|
||||||
@@ -2781,7 +2816,6 @@ EXPORT_SPEC int UpnpEnableWebserver(
|
|||||||
/*! [in] \c TRUE to enable, \c FALSE to disable. */
|
/*! [in] \c TRUE to enable, \c FALSE to disable. */
|
||||||
int enable);
|
int enable);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns \c TRUE if the webserver is enabled, or \c FALSE if it is not.
|
* \brief Returns \c TRUE if the webserver is enabled, or \c FALSE if it is not.
|
||||||
*
|
*
|
||||||
@@ -2791,6 +2825,16 @@ EXPORT_SPEC int UpnpEnableWebserver(
|
|||||||
*/
|
*/
|
||||||
EXPORT_SPEC int UpnpIsWebserverEnabled(void);
|
EXPORT_SPEC int UpnpIsWebserverEnabled(void);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Sets the callback functions to be used to access a virtual directory.
|
||||||
|
*
|
||||||
|
* \return An integer representing one of the following:
|
||||||
|
* \li \c UPNP_E_SUCCESS: The operation completed successfully.
|
||||||
|
* \li \c UPNP_E_INVALID_PARAM: one of the callbacks is not valid.
|
||||||
|
*/
|
||||||
|
EXPORT_SPEC int UpnpSetVirtualDirCallbacks(
|
||||||
|
/*! [in] A structure that contains the callback functions. */
|
||||||
|
struct UpnpVirtualDirCallbacks *callbacks );
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Adds a virtual directory mapping.
|
* \brief Adds a virtual directory mapping.
|
||||||
@@ -2810,7 +2854,6 @@ EXPORT_SPEC int UpnpAddVirtualDir(
|
|||||||
/*! [in] The name of the new directory mapping to add. */
|
/*! [in] The name of the new directory mapping to add. */
|
||||||
const char *dirName);
|
const char *dirName);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Removes a virtual directory mapping made with \b UpnpAddVirtualDir.
|
* \brief Removes a virtual directory mapping made with \b UpnpAddVirtualDir.
|
||||||
*
|
*
|
||||||
@@ -2822,24 +2865,17 @@ EXPORT_SPEC int UpnpRemoveVirtualDir(
|
|||||||
/*! [in] The name of the virtual directory mapping to remove. */
|
/*! [in] The name of the virtual directory mapping to remove. */
|
||||||
const char *dirName);
|
const char *dirName);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Removes all virtual directory mappings.
|
* \brief Removes all virtual directory mappings.
|
||||||
*/
|
*/
|
||||||
EXPORT_SPEC void UpnpRemoveAllVirtualDirs(void);
|
EXPORT_SPEC void UpnpRemoveAllVirtualDirs(void);
|
||||||
|
|
||||||
|
|
||||||
/* @} Web Server API */
|
/* @} Web Server API */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
|
||||||
/* @} UPnPAPI UPnP API */
|
/* @} UPnPAPI UPnP API */
|
||||||
|
|
||||||
|
|
||||||
#endif /* UPNP_H */
|
#endif /* UPNP_H */
|
||||||
|
|
||||||
|
|||||||
@@ -56,6 +56,19 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Large file support
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
/** File Offset size */
|
||||||
|
#undef _FILE_OFFSET_BITS
|
||||||
|
|
||||||
|
/** Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */
|
||||||
|
#undef _LARGEFILE_SOURCE
|
||||||
|
|
||||||
|
/** Large files support */
|
||||||
|
#undef _LARGE_FILE_SOURCE
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* Library optional features
|
* Library optional features
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
@@ -86,6 +99,26 @@
|
|||||||
#undef UPNP_HAVE_WEBSERVER
|
#undef UPNP_HAVE_WEBSERVER
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with the SSDP part enabled
|
||||||
|
* (i.e. configure --enable-ssdp) */
|
||||||
|
#undef UPNP_HAVE_SSDP
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with optional SSDP headers
|
||||||
|
* support (i.e. configure --enable-optssdp) */
|
||||||
|
#undef UPNP_HAVE_OPTSSDP
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with the SOAP part enabled
|
||||||
|
* (i.e. configure --enable-soap) */
|
||||||
|
#undef UPNP_HAVE_SOAP
|
||||||
|
|
||||||
|
|
||||||
|
/** Defined to 1 if the library has been compiled with the GENA part enabled
|
||||||
|
* (i.e. configure --enable-gena) */
|
||||||
|
#undef UPNP_HAVE_GENA
|
||||||
|
|
||||||
|
|
||||||
/** Defined to 1 if the library has been compiled with helper API
|
/** Defined to 1 if the library has been compiled with helper API
|
||||||
* (i.e. configure --enable-tools) : <upnp/upnptools.h> file is available */
|
* (i.e. configure --enable-tools) : <upnp/upnptools.h> file is available */
|
||||||
#undef UPNP_HAVE_TOOLS
|
#undef UPNP_HAVE_TOOLS
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* Copyright (c) 2006 R<EFBFBD>mi Turboult <r3mi@users.sourceforge.net>
|
* Copyright (c) 2006 Rémi Turboult <r3mi@users.sourceforge.net>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@@ -33,32 +33,27 @@
|
|||||||
#ifndef UPNP_DEBUG_H
|
#ifndef UPNP_DEBUG_H
|
||||||
#define UPNP_DEBUG_H
|
#define UPNP_DEBUG_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "ThreadPool.h"
|
#include "ThreadPool.h"
|
||||||
#include "upnpconfig.h"
|
#include "upnpconfig.h"
|
||||||
#include "UpnpGlobal.h" /* for UPNP_INLINE */
|
#include "UpnpGlobal.h" /* for UPNP_INLINE */
|
||||||
|
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*! \name Other debugging features
|
||||||
/** \name Other debugging features
|
|
||||||
*
|
*
|
||||||
* The UPnP SDK contains other features to aid in debugging.
|
* The UPnP SDK contains other features to aid in debugging.
|
||||||
*/
|
*/
|
||||||
/*@{*/
|
/*@{*/
|
||||||
|
|
||||||
/** \name Upnp_LogLevel
|
/*! \name Upnp_LogLevel
|
||||||
* The user has the option to select 4 different types of debugging levels,
|
* The user has the option to select 4 different types of debugging levels,
|
||||||
* see \c UpnpSetLogLevel.
|
* see \c UpnpSetLogLevel.
|
||||||
* The critical level will show only those messages
|
* The critical level will show only those messages
|
||||||
@@ -85,7 +80,6 @@ typedef enum Upnp_Module {
|
|||||||
HTTP
|
HTTP
|
||||||
} Dbg_Module;
|
} Dbg_Module;
|
||||||
|
|
||||||
|
|
||||||
/*@{*/
|
/*@{*/
|
||||||
typedef enum Upnp_LogLevel_e {
|
typedef enum Upnp_LogLevel_e {
|
||||||
UPNP_CRITICAL,
|
UPNP_CRITICAL,
|
||||||
@@ -95,14 +89,11 @@ typedef enum Upnp_LogLevel_e {
|
|||||||
} Upnp_LogLevel;
|
} Upnp_LogLevel;
|
||||||
/*@}*/
|
/*@}*/
|
||||||
|
|
||||||
|
/*!
|
||||||
/**
|
|
||||||
* Default log level : see \c Upnp_LogLevel
|
* Default log level : see \c Upnp_LogLevel
|
||||||
*/
|
*/
|
||||||
#define UPNP_DEFAULT_LOG_LEVEL UPNP_ALL
|
#define UPNP_DEFAULT_LOG_LEVEL UPNP_ALL
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Initialize the log files.
|
* \brief Initialize the log files.
|
||||||
*
|
*
|
||||||
@@ -116,8 +107,6 @@ static UPNP_INLINE int UpnpInitLog(void)
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Set the log level (see \c Upnp_LogLevel).
|
* \brief Set the log level (see \c Upnp_LogLevel).
|
||||||
*/
|
*/
|
||||||
@@ -126,20 +115,24 @@ void UpnpSetLogLevel(
|
|||||||
/*! [in] Log level. */
|
/*! [in] Log level. */
|
||||||
Upnp_LogLevel log_level);
|
Upnp_LogLevel log_level);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE void UpnpSetLogLevel(Upnp_LogLevel log_level) {}
|
static UPNP_INLINE void UpnpSetLogLevel(Upnp_LogLevel log_level)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
log_level = log_level;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Closes the log files.
|
* \brief Closes the log files.
|
||||||
*/
|
*/
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
void UpnpCloseLog(void);
|
void UpnpCloseLog(void);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE void UpnpCloseLog(void) {}
|
static UPNP_INLINE void UpnpCloseLog(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Set the name for error and information files, respectively.
|
* \brief Set the name for error and information files, respectively.
|
||||||
*/
|
*/
|
||||||
@@ -150,12 +143,15 @@ void UpnpSetLogFileNames(
|
|||||||
/*! [in] Name of the information file. */
|
/*! [in] Name of the information file. */
|
||||||
const char *InfoFileName);
|
const char *InfoFileName);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE void UpnpSetLogFileNames(
|
static UPNP_INLINE void UpnpSetLogFileNames(const char *ErrFileName,
|
||||||
const char *ErrFileName,
|
const char *InfoFileName)
|
||||||
const char *InfoFileName) {}
|
{
|
||||||
|
return;
|
||||||
|
ErrFileName = ErrFileName;
|
||||||
|
InfoFileName = InfoFileName;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Check if the module is turned on for debug and returns the file
|
* \brief Check if the module is turned on for debug and returns the file
|
||||||
* descriptor corresponding to the debug level
|
* descriptor corresponding to the debug level
|
||||||
@@ -174,10 +170,11 @@ FILE *UpnpGetDebugFile(
|
|||||||
static UPNP_INLINE FILE *UpnpGetDebugFile(Upnp_LogLevel level, Dbg_Module module)
|
static UPNP_INLINE FILE *UpnpGetDebugFile(Upnp_LogLevel level, Dbg_Module module)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
|
level = level;
|
||||||
|
module = module;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns true if debug output should be done in this module.
|
* \brief Returns true if debug output should be done in this module.
|
||||||
*
|
*
|
||||||
@@ -191,15 +188,14 @@ int DebugAtThisLevel(
|
|||||||
/*! [in] Debug will go in the name of this module. */
|
/*! [in] Debug will go in the name of this module. */
|
||||||
Dbg_Module Module);
|
Dbg_Module Module);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE int DebugAtThisLevel(
|
static UPNP_INLINE int DebugAtThisLevel(Upnp_LogLevel DLevel, Dbg_Module Module)
|
||||||
Upnp_LogLevel DLevel,
|
|
||||||
Dbg_Module Module)
|
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
|
DLevel = DLevel;
|
||||||
|
Module = Module;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Prints the debug statement either on the standard output or log file
|
* \brief Prints the debug statement either on the standard output or log file
|
||||||
* along with the information from where this debug statement is coming.
|
* along with the information from where this debug statement is coming.
|
||||||
@@ -212,98 +208,81 @@ void UpnpPrintf(
|
|||||||
/*! [in] debug will go in the name of this module. */
|
/*! [in] debug will go in the name of this module. */
|
||||||
Dbg_Module Module,
|
Dbg_Module Module,
|
||||||
/*! [in] Name of the file from where debug statement is coming. */
|
/*! [in] Name of the file from where debug statement is coming. */
|
||||||
const char* DbgFileName,
|
const char *DbgFileName,
|
||||||
/*! [in] Line number of the file from where debug statement is coming. */
|
/*! [in] Line number of the file from where debug statement is coming. */
|
||||||
int DbgLineNo,
|
int DbgLineNo,
|
||||||
/*! [in] Printf like format specification. */
|
/*! [in] Printf like format specification. */
|
||||||
const char* FmtStr,
|
const char *FmtStr,
|
||||||
/*! [in] Printf like Variable number of arguments that will go in the debug
|
/*! [in] Printf like Variable number of arguments that will go in the
|
||||||
* statement. */
|
* debug statement. */
|
||||||
...)
|
...)
|
||||||
#if (__GNUC__ >= 3)
|
#if (__GNUC__ >= 3)
|
||||||
/* This enables printf like format checking by the compiler */
|
/* This enables printf like format checking by the compiler. */
|
||||||
__attribute__((format (__printf__, 5, 6)))
|
__attribute__ ((format(__printf__, 5, 6)))
|
||||||
#endif
|
#endif
|
||||||
;
|
;
|
||||||
#else /* DEBUG */
|
#else /* DEBUG */
|
||||||
static UPNP_INLINE void UpnpPrintf(
|
static UPNP_INLINE void UpnpPrintf(Upnp_LogLevel DLevel, Dbg_Module Module,
|
||||||
Upnp_LogLevel DLevel,
|
const char *DbgFileName, int DbgLineNo, const char *FmtStr, ...)
|
||||||
Dbg_Module Module,
|
|
||||||
const char* DbgFileName,
|
|
||||||
int DbgLineNo,
|
|
||||||
const char* FmtStr,
|
|
||||||
...)
|
|
||||||
{
|
{
|
||||||
|
return;
|
||||||
|
DLevel = DLevel;
|
||||||
|
Module = Module;
|
||||||
|
DbgFileName = DbgFileName;
|
||||||
|
DbgLineNo = DbgLineNo;
|
||||||
|
FmtStr = FmtStr;
|
||||||
}
|
}
|
||||||
#endif /* DEBUG */
|
#endif /* DEBUG */
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Writes the file name and file number from where debug statement is
|
* \brief Writes the file name and file number from where debug statement is
|
||||||
* coming to the log file.
|
* coming to the log file.
|
||||||
*/
|
*/
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
void UpnpDisplayFileAndLine(
|
void UpnpDisplayFileAndLine(
|
||||||
/*! [in] File descriptor where line number and file name will be written. */
|
/*! [in] File descriptor where line number and file name will be
|
||||||
FILE *fd,
|
* written. */
|
||||||
|
FILE * fd,
|
||||||
/*! [in] Name of the file. */
|
/*! [in] Name of the file. */
|
||||||
const char *DbgFileName,
|
const char *DbgFileName,
|
||||||
/*! [in] Line number of the file. */
|
/*! [in] Line number of the file. */
|
||||||
int DbgLineNo);
|
int DbgLineNo);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE void UpnpDisplayFileAndLine(
|
static UPNP_INLINE void UpnpDisplayFileAndLine(FILE *fd,
|
||||||
FILE *fd,
|
const char *DbgFileName, int DbgLineNo)
|
||||||
const char *DbgFileName,
|
{
|
||||||
int DbgLineNo) {}
|
return;
|
||||||
|
fd = fd;
|
||||||
|
DbgFileName = DbgFileName;
|
||||||
|
DbgLineNo = DbgLineNo;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Writes the buffer in the file as per the requested banner
|
* \brief Writes the buffer in the file as per the requested banner
|
||||||
*/
|
*/
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
void UpnpDisplayBanner(
|
void UpnpDisplayBanner(
|
||||||
/*! [in] file descriptor where the banner will be written. */
|
/*! [in] file descriptor where the banner will be written. */
|
||||||
FILE *fd,
|
FILE * fd,
|
||||||
/*! [in] The buffer that will be written. */
|
/*! [in] The buffer that will be written. */
|
||||||
const char **lines,
|
const char **lines,
|
||||||
/*! [in] Size of the buffer. */
|
/*! [in] Size of the buffer. */
|
||||||
size_t size,
|
size_t size,
|
||||||
/*! [in] This parameter provides the width of the banner. */
|
/*! [in] This parameter provides the width of the banner. */
|
||||||
int starlength);
|
size_t starlength);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE void UpnpDisplayBanner(
|
static UPNP_INLINE void UpnpDisplayBanner(FILE *fd, const char **lines,
|
||||||
FILE *fd,
|
size_t size, int starlength)
|
||||||
const char **lines,
|
|
||||||
size_t size,
|
|
||||||
int starlength) {}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* \brief Prints thread pool statistics.
|
|
||||||
*/
|
|
||||||
#ifdef DEBUG
|
|
||||||
void PrintThreadPoolStats(
|
|
||||||
/*! [in] The thread pool. */
|
|
||||||
ThreadPool *tp,
|
|
||||||
/*! [in] The file name that called this function, use the macro __FILE__. */
|
|
||||||
const char *DbgFileName,
|
|
||||||
/*! [in] The line number that the function was called, use the macro __LINE__. */
|
|
||||||
int DbgLineNo,
|
|
||||||
/*! [in] The message. */
|
|
||||||
const char *msg);
|
|
||||||
#else
|
|
||||||
static UPNP_INLINE void PrintThreadPoolStats(
|
|
||||||
ThreadPool *tp,
|
|
||||||
const char *DbgFileName,
|
|
||||||
int DbgLineNo,
|
|
||||||
const char *msg)
|
|
||||||
{
|
{
|
||||||
|
return;
|
||||||
|
fd = fd;
|
||||||
|
lines = lines;
|
||||||
|
size = size;
|
||||||
|
starlength = starlength;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*@}*/
|
/*@}*/
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
@@ -311,4 +290,3 @@ static UPNP_INLINE void PrintThreadPoolStats(
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* UPNP_DEBUG_H */
|
#endif /* UPNP_DEBUG_H */
|
||||||
|
|
||||||
|
|||||||
@@ -50,6 +50,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#include "ixml.h" /* for IXML_Document */
|
#include "ixml.h" /* for IXML_Document */
|
||||||
|
#include "upnpconfig.h" /* for UPNP_HAVE_TOOLS */
|
||||||
|
|
||||||
|
|
||||||
/* Function declarations only if tools compiled into the library */
|
/* Function declarations only if tools compiled into the library */
|
||||||
@@ -96,6 +97,30 @@ EXPORT_SPEC int UpnpResolveURL(
|
|||||||
char *AbsURL);
|
char *AbsURL);
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Combines a base URL and a relative URL into a single absolute URL.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
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
|
* \brief Creates an action request packet based on its input parameters
|
||||||
* (status variable name and value pair).
|
* (status variable name and value pair).
|
||||||
|
|||||||
@@ -14,67 +14,62 @@ LDADD = \
|
|||||||
$(top_builddir)/threadutil/libthreadutil.la \
|
$(top_builddir)/threadutil/libthreadutil.la \
|
||||||
$(top_builddir)/ixml/libixml.la
|
$(top_builddir)/ixml/libixml.la
|
||||||
|
|
||||||
|
|
||||||
# samples
|
# samples
|
||||||
noinst_PROGRAMS =
|
noinst_PROGRAMS =
|
||||||
if ENABLE_SAMPLES
|
if ENABLE_SAMPLES
|
||||||
if ENABLE_CLIENT
|
if ENABLE_CLIENT
|
||||||
noinst_PROGRAMS += upnp_tv_ctrlpt
|
noinst_PROGRAMS += tv_ctrlpt
|
||||||
upnp_tv_ctrlpt_CPPFLAGS = \
|
tv_ctrlpt_CPPFLAGS = \
|
||||||
$(AM_CPPFLAGS) \
|
$(AM_CPPFLAGS) \
|
||||||
-I$(srcdir)/common/ \
|
-I$(srcdir)/common/ \
|
||||||
-I$(srcdir)/tvctrlpt
|
-I$(srcdir)/tvctrlpt
|
||||||
if ENABLE_DEVICE
|
if ENABLE_DEVICE
|
||||||
noinst_PROGRAMS += upnp_tv_combo
|
noinst_PROGRAMS += tv_combo
|
||||||
upnp_tv_combo_CPPFLAGS = $(AM_CPPFLAGS) \
|
tv_combo_CPPFLAGS = $(AM_CPPFLAGS) \
|
||||||
-I$(srcdir)/common/ \
|
-I$(srcdir)/common/ \
|
||||||
-I$(srcdir)/tvcombo
|
-I$(srcdir)/tvcombo
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
if ENABLE_DEVICE
|
if ENABLE_DEVICE
|
||||||
noinst_PROGRAMS += upnp_tv_device
|
noinst_PROGRAMS += tv_device
|
||||||
upnp_tv_device_CPPFLAGS = \
|
tv_device_CPPFLAGS = \
|
||||||
$(AM_CPPFLAGS) \
|
$(AM_CPPFLAGS) \
|
||||||
-I$(srcdir)/common/ \
|
-I$(srcdir)/common/ \
|
||||||
-I$(srcdir)/tvdevice
|
-I$(srcdir)/tvdevice
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
tv_device_SOURCES = \
|
||||||
upnp_tv_device_SOURCES = \
|
|
||||||
common/sample_util.c \
|
common/sample_util.c \
|
||||||
common/sample_util.h \
|
common/sample_util.h \
|
||||||
tvdevice/upnp_tv_device.c \
|
common/tv_device.c \
|
||||||
tvdevice/upnp_tv_device.h \
|
common/tv_device.h \
|
||||||
tvdevice/linux/upnp_tv_device_main.c
|
linux/tv_device_main.c
|
||||||
|
|
||||||
|
tv_ctrlpt_SOURCES = \
|
||||||
upnp_tv_ctrlpt_SOURCES = \
|
|
||||||
common/sample_util.c \
|
common/sample_util.c \
|
||||||
common/sample_util.h \
|
common/sample_util.h \
|
||||||
tvctrlpt/upnp_tv_ctrlpt.c \
|
common/tv_ctrlpt.c \
|
||||||
tvctrlpt/upnp_tv_ctrlpt.h \
|
common/tv_ctrlpt.h \
|
||||||
tvctrlpt/linux/upnp_tv_ctrlpt_main.c
|
linux/tv_ctrlpt_main.c
|
||||||
|
|
||||||
upnp_tv_combo_SOURCES = \
|
tv_combo_SOURCES = \
|
||||||
common/sample_util.c \
|
common/sample_util.c \
|
||||||
common/sample_util.h \
|
common/sample_util.h \
|
||||||
tvcombo/upnp_tv_ctrlpt.c \
|
common/tv_ctrlpt.c \
|
||||||
tvcombo/upnp_tv_ctrlpt.h \
|
common/tv_ctrlpt.h \
|
||||||
tvcombo/upnp_tv_device.c \
|
common/tv_device.c \
|
||||||
tvcombo/upnp_tv_device.h \
|
common/tv_device.h \
|
||||||
tvcombo/linux/upnp_tv_combo_main.c
|
linux/tv_combo_main.c
|
||||||
|
|
||||||
|
|
||||||
if WITH_DOCUMENTATION
|
if WITH_DOCUMENTATION
|
||||||
examplesdir = $(docdir)/examples
|
examplesdir = $(docdir)/examples
|
||||||
examples_DATA = \
|
examples_DATA = \
|
||||||
$(sort \
|
$(sort \
|
||||||
$(upnp_tv_ctrlpt_SOURCES) \
|
$(tv_ctrlpt_SOURCES) \
|
||||||
$(upnp_tv_device_SOURCES))
|
$(tv_device_SOURCES))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
web/tvcombodesc.xml \
|
web/tvcombodesc.xml \
|
||||||
web/tvcontrolSCPD.xml \
|
web/tvcontrolSCPD.xml \
|
||||||
|
|||||||
@@ -29,20 +29,25 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \addtogroup UpnpSamples
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* \file
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define SAMPLE_UTIL_C
|
||||||
|
|
||||||
#include "sample_util.h"
|
#include "sample_util.h"
|
||||||
|
|
||||||
|
|
||||||
#include <assert.h>
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
|
||||||
#if !UPNP_HAVE_TOOLS
|
#if !UPNP_HAVE_TOOLS
|
||||||
# error "Need upnptools.h to compile samples ; try ./configure --enable-tools"
|
# error "Need upnptools.h to compile samples ; try ./configure --enable-tools"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
static int initialize_init = 1;
|
static int initialize_init = 1;
|
||||||
static int initialize_register = 1;
|
static int initialize_register = 1;
|
||||||
|
|
||||||
@@ -54,18 +59,6 @@ state_update gStateUpdateFun = NULL;
|
|||||||
/*! mutex to control displaying of events */
|
/*! mutex to control displaying of events */
|
||||||
ithread_mutex_t display_mutex;
|
ithread_mutex_t display_mutex;
|
||||||
|
|
||||||
/*******************************************************************************
|
|
||||||
* SampleUtil_Initialize
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Initializes the sample util. Must be called before any sample util
|
|
||||||
* functions. May be called multiple times.
|
|
||||||
* But the initialization is done only once.
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
* print_function - print function to use in SampleUtil_Print
|
|
||||||
*
|
|
||||||
******************************************************************************/
|
|
||||||
int SampleUtil_Initialize(print_string print_function)
|
int SampleUtil_Initialize(print_string print_function)
|
||||||
{
|
{
|
||||||
if (initialize_init) {
|
if (initialize_init) {
|
||||||
@@ -75,29 +68,17 @@ int SampleUtil_Initialize(print_string print_function)
|
|||||||
ithread_mutexattr_setkind_np(&attr, ITHREAD_MUTEX_RECURSIVE_NP);
|
ithread_mutexattr_setkind_np(&attr, ITHREAD_MUTEX_RECURSIVE_NP);
|
||||||
ithread_mutex_init(&display_mutex, &attr);
|
ithread_mutex_init(&display_mutex, &attr);
|
||||||
ithread_mutexattr_destroy(&attr);
|
ithread_mutexattr_destroy(&attr);
|
||||||
|
|
||||||
/* To shut up valgrind mutex warning. */
|
/* To shut up valgrind mutex warning. */
|
||||||
ithread_mutex_lock(&display_mutex);
|
ithread_mutex_lock(&display_mutex);
|
||||||
gPrintFun = print_function;
|
gPrintFun = print_function;
|
||||||
ithread_mutex_unlock(&display_mutex);
|
ithread_mutex_unlock(&display_mutex);
|
||||||
|
/* Finished initializing. */
|
||||||
initialize_init = 0;
|
initialize_init = 0;
|
||||||
} else {
|
|
||||||
SampleUtil_Print("***** SampleUtil_Initialize was called multiple times!\n");
|
|
||||||
abort();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
|
||||||
* SampleUtil_RegisterUpdateFunction
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
*
|
|
||||||
******************************************************************************/
|
|
||||||
int SampleUtil_RegisterUpdateFunction(state_update update_function)
|
int SampleUtil_RegisterUpdateFunction(state_update update_function)
|
||||||
{
|
{
|
||||||
if (initialize_register) {
|
if (initialize_register) {
|
||||||
@@ -108,15 +89,6 @@ int SampleUtil_RegisterUpdateFunction(state_update update_function)
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
|
||||||
* SampleUtil_Finish
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Releases Resources held by sample util.
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
*
|
|
||||||
******************************************************************************/
|
|
||||||
int SampleUtil_Finish()
|
int SampleUtil_Finish()
|
||||||
{
|
{
|
||||||
ithread_mutex_destroy(&display_mutex);
|
ithread_mutex_destroy(&display_mutex);
|
||||||
@@ -128,90 +100,64 @@ int SampleUtil_Finish()
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
char *SampleUtil_GetElementValue(IXML_Element *element)
|
||||||
* 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)
|
|
||||||
{
|
{
|
||||||
IXML_Node *child = ixmlNode_getFirstChild((IXML_Node *)element);
|
IXML_Node *child = ixmlNode_getFirstChild((IXML_Node *)element);
|
||||||
char *temp = NULL;
|
char *temp = NULL;
|
||||||
|
|
||||||
if (child != 0 && ixmlNode_getNodeType(child) == eTEXT_NODE) {
|
if (child != 0 && ixmlNode_getNodeType(child) == eTEXT_NODE)
|
||||||
temp = strdup(ixmlNode_getNodeValue(child));
|
temp = strdup(ixmlNode_getNodeValue(child));
|
||||||
}
|
|
||||||
|
|
||||||
return temp;
|
return temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
IXML_NodeList *SampleUtil_GetFirstServiceList(IXML_Document *doc)
|
||||||
* 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.
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
* node -- The DOM node from which to extract the service list
|
|
||||||
*
|
|
||||||
******************************************************************************/
|
|
||||||
IXML_NodeList *SampleUtil_GetFirstServiceList(IN IXML_Document *doc)
|
|
||||||
{
|
{
|
||||||
IXML_NodeList *ServiceList = NULL;
|
IXML_NodeList *ServiceList = NULL;
|
||||||
IXML_NodeList *servlistnodelist = NULL;
|
IXML_NodeList *servlistnodelist = NULL;
|
||||||
IXML_Node *servlistnode = NULL;
|
IXML_Node *servlistnode = NULL;
|
||||||
|
|
||||||
servlistnodelist =
|
servlistnodelist =
|
||||||
ixmlDocument_getElementsByTagName( doc, "serviceList" );
|
ixmlDocument_getElementsByTagName(doc, "serviceList");
|
||||||
if (servlistnodelist && ixmlNodeList_length(servlistnodelist)) {
|
if (servlistnodelist && ixmlNodeList_length(servlistnodelist)) {
|
||||||
/* we only care about the first service list, from the root
|
/* we only care about the first service list, from the root
|
||||||
* device */
|
* device */
|
||||||
servlistnode = ixmlNodeList_item(servlistnodelist, 0);
|
servlistnode = ixmlNodeList_item(servlistnodelist, 0);
|
||||||
|
|
||||||
/* create as list of DOM nodes */
|
/* create as list of DOM nodes */
|
||||||
ServiceList = ixmlElement_getElementsByTagName(
|
ServiceList = ixmlElement_getElementsByTagName(
|
||||||
(IXML_Element *)servlistnode, "service");
|
(IXML_Element *)servlistnode, "service");
|
||||||
}
|
}
|
||||||
if (servlistnodelist) {
|
if (servlistnodelist)
|
||||||
ixmlNodeList_free(servlistnodelist);
|
ixmlNodeList_free(servlistnodelist);
|
||||||
}
|
|
||||||
|
|
||||||
return ServiceList;
|
return ServiceList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define OLD_FIND_SERVICE_CODE
|
||||||
|
#ifdef OLD_FIND_SERVICE_CODE
|
||||||
|
#else
|
||||||
/*
|
/*
|
||||||
* Obtain the service list
|
* Obtain the service list
|
||||||
* n == 0 the first
|
* n == 0 the first
|
||||||
* n == 1 the next in the device list, etc..
|
* n == 1 the next in the device list, etc..
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
IXML_NodeList *SampleUtil_GetNthServiceList(IN IXML_Document *doc , int n)
|
static IXML_NodeList *SampleUtil_GetNthServiceList(
|
||||||
|
/*! [in] . */
|
||||||
|
IXML_Document *doc,
|
||||||
|
/*! [in] . */
|
||||||
|
unsigned int n)
|
||||||
{
|
{
|
||||||
IXML_NodeList *ServiceList = NULL;
|
IXML_NodeList *ServiceList = NULL;
|
||||||
IXML_NodeList *servlistnodelist = NULL;
|
IXML_NodeList *servlistnodelist = NULL;
|
||||||
IXML_Node *servlistnode = NULL;
|
IXML_Node *servlistnode = NULL;
|
||||||
|
|
||||||
/*
|
/* ixmlDocument_getElementsByTagName()
|
||||||
* ixmlDocument_getElementsByTagName()
|
|
||||||
* Returns a NodeList of all Elements that match the given
|
* Returns a NodeList of all Elements that match the given
|
||||||
* tag name in the order in which they were encountered in a preorder
|
* tag name in the order in which they were encountered in a preorder
|
||||||
* traversal of the Document tree.
|
* traversal of the Document tree.
|
||||||
*
|
*
|
||||||
* return (NodeList*) A pointer to a NodeList containing the
|
* return (NodeList*) A pointer to a NodeList containing the
|
||||||
* matching items or NULL on an error.
|
* matching items or NULL on an error. */
|
||||||
*/
|
|
||||||
SampleUtil_Print("SampleUtil_GetNthServiceList called : n = %d\n", n);
|
SampleUtil_Print("SampleUtil_GetNthServiceList called : n = %d\n", n);
|
||||||
servlistnodelist =
|
servlistnodelist =
|
||||||
ixmlDocument_getElementsByTagName(doc, "serviceList");
|
ixmlDocument_getElementsByTagName(doc, "serviceList");
|
||||||
@@ -226,38 +172,24 @@ IXML_NodeList *SampleUtil_GetNthServiceList(IN IXML_Document *doc , int n)
|
|||||||
* numerical index.
|
* numerical index.
|
||||||
*
|
*
|
||||||
* return (Node*) A pointer to a Node or NULL if there was an
|
* return (Node*) A pointer to a Node or NULL if there was an
|
||||||
* error.
|
* error. */
|
||||||
*/
|
|
||||||
servlistnode = ixmlNodeList_item(servlistnodelist, n);
|
servlistnode = ixmlNodeList_item(servlistnodelist, n);
|
||||||
|
if (!servlistnode) {
|
||||||
assert(servlistnode != 0);
|
|
||||||
|
|
||||||
/* create as list of DOM nodes */
|
/* create as list of DOM nodes */
|
||||||
ServiceList = ixmlElement_getElementsByTagName(
|
ServiceList = ixmlElement_getElementsByTagName(
|
||||||
(IXML_Element *)servlistnode, "service");
|
(IXML_Element *)servlistnode, "service");
|
||||||
|
} else
|
||||||
|
SampleUtil_Print("%s(%d): ixmlNodeList_item(nodeList, n) returned NULL\n",
|
||||||
|
__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
if (servlistnodelist)
|
||||||
if (servlistnodelist) {
|
|
||||||
ixmlNodeList_free(servlistnodelist);
|
ixmlNodeList_free(servlistnodelist);
|
||||||
}
|
|
||||||
|
|
||||||
return ServiceList;
|
return ServiceList;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*******************************************************************************
|
char *SampleUtil_GetFirstDocumentItem(IXML_Document *doc, const char *item)
|
||||||
* 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.
|
|
||||||
* 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)
|
|
||||||
{
|
{
|
||||||
IXML_NodeList *nodeList = NULL;
|
IXML_NodeList *nodeList = NULL;
|
||||||
IXML_Node *textNode = NULL;
|
IXML_Node *textNode = NULL;
|
||||||
@@ -270,52 +202,32 @@ char *SampleUtil_GetFirstDocumentItem(
|
|||||||
if (tmpNode) {
|
if (tmpNode) {
|
||||||
textNode = ixmlNode_getFirstChild(tmpNode);
|
textNode = ixmlNode_getFirstChild(tmpNode);
|
||||||
if (!textNode) {
|
if (!textNode) {
|
||||||
SampleUtil_Print("sample_util.c: (bug) "
|
SampleUtil_Print("%s(%d): (BUG) ixmlNode_getFirstChild(tmpNode) returned NULL\n",
|
||||||
"ixmlNode_getFirstChild(tmpNode) "
|
__FILE__, __LINE__);
|
||||||
"returned NULL\n");
|
|
||||||
ret = strdup("");
|
ret = strdup("");
|
||||||
goto epilogue;
|
goto epilogue;
|
||||||
}
|
}
|
||||||
if (!ixmlNode_getNodeValue(textNode)) {
|
|
||||||
SampleUtil_Print("ixmlNode_getNodeValue "
|
|
||||||
"returned NULL\n");
|
|
||||||
ret = strdup("");
|
|
||||||
goto epilogue;
|
|
||||||
} else {
|
|
||||||
ret = strdup(ixmlNode_getNodeValue(textNode));
|
ret = strdup(ixmlNode_getNodeValue(textNode));
|
||||||
|
if (!ret) {
|
||||||
|
SampleUtil_Print("%s(%d): ixmlNode_getNodeValue returned NULL\n",
|
||||||
|
__FILE__, __LINE__);
|
||||||
|
ret = strdup("");
|
||||||
}
|
}
|
||||||
} else {
|
} else
|
||||||
SampleUtil_Print("ixmlNode_getFirstChild(tmpNode) "
|
SampleUtil_Print("%s(%d): ixmlNodeList_item(nodeList, 0) returned NULL\n",
|
||||||
"returned NULL\n");
|
__FILE__, __LINE__);
|
||||||
goto epilogue;
|
} else
|
||||||
}
|
SampleUtil_Print("%s(%d): Error finding %s in XML Node\n",
|
||||||
} else {
|
__FILE__, __LINE__, item);
|
||||||
SampleUtil_Print("Error finding %s in XML Node\n", item);
|
|
||||||
goto epilogue;
|
|
||||||
}
|
|
||||||
|
|
||||||
epilogue:
|
epilogue:
|
||||||
if (nodeList) {
|
if (nodeList)
|
||||||
ixmlNodeList_free(nodeList);
|
ixmlNodeList_free(nodeList);
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
char *SampleUtil_GetFirstElementItem(IXML_Element *element, const char *item)
|
||||||
* 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.
|
|
||||||
* 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)
|
|
||||||
{
|
{
|
||||||
IXML_NodeList *nodeList = NULL;
|
IXML_NodeList *nodeList = NULL;
|
||||||
IXML_Node *textNode = NULL;
|
IXML_Node *textNode = NULL;
|
||||||
@@ -324,24 +236,23 @@ char *SampleUtil_GetFirstElementItem(
|
|||||||
|
|
||||||
nodeList = ixmlElement_getElementsByTagName(element, (char *)item);
|
nodeList = ixmlElement_getElementsByTagName(element, (char *)item);
|
||||||
if (nodeList == NULL) {
|
if (nodeList == NULL) {
|
||||||
SampleUtil_Print( "Error finding %s in XML Node\n", item);
|
SampleUtil_Print("%s(%d): Error finding %s in XML Node\n",
|
||||||
|
__FILE__, __LINE__, item);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
tmpNode = ixmlNodeList_item(nodeList, 0);
|
tmpNode = ixmlNodeList_item(nodeList, 0);
|
||||||
if (tmpNode) {
|
if (!tmpNode) {
|
||||||
SampleUtil_Print("Error finding %s value in XML Node\n", item);
|
SampleUtil_Print("%s(%d): Error finding %s value in XML Node\n",
|
||||||
|
__FILE__, __LINE__, item);
|
||||||
ixmlNodeList_free(nodeList);
|
ixmlNodeList_free(nodeList);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
textNode = ixmlNode_getFirstChild(tmpNode);
|
textNode = ixmlNode_getFirstChild(tmpNode);
|
||||||
ret = strdup(ixmlNode_getNodeValue(textNode));
|
ret = strdup(ixmlNode_getNodeValue(textNode));
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
SampleUtil_Print("Error allocating memory for %s in XML Node\n",
|
SampleUtil_Print("%s(%d): Error allocating memory for %s in XML Node\n",
|
||||||
item);
|
__FILE__, __LINE__, item);
|
||||||
ixmlNodeList_free(nodeList);
|
ixmlNodeList_free(nodeList);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
ixmlNodeList_free(nodeList);
|
ixmlNodeList_free(nodeList);
|
||||||
@@ -349,17 +260,7 @@ char *SampleUtil_GetFirstElementItem(
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
void SampleUtil_PrintEventType(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)
|
|
||||||
{
|
{
|
||||||
switch (S) {
|
switch (S) {
|
||||||
/* Discovery */
|
/* Discovery */
|
||||||
@@ -413,18 +314,7 @@ void SampleUtil_PrintEventType(IN Upnp_EventType S)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
int SampleUtil_PrintEvent(Upnp_EventType EventType, 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)
|
|
||||||
{
|
{
|
||||||
ithread_mutex_lock(&display_mutex);
|
ithread_mutex_lock(&display_mutex);
|
||||||
|
|
||||||
@@ -542,7 +432,6 @@ int SampleUtil_PrintEvent(IN Upnp_EventType EventType, IN void *Event)
|
|||||||
SampleUtil_Print("CurrentVal = %s\n", sv_event->CurrentVal);
|
SampleUtil_Print("CurrentVal = %s\n", sv_event->CurrentVal);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* GENA */
|
/* GENA */
|
||||||
case UPNP_EVENT_SUBSCRIPTION_REQUEST: {
|
case UPNP_EVENT_SUBSCRIPTION_REQUEST: {
|
||||||
struct Upnp_Subscription_Request *sr_event =
|
struct Upnp_Subscription_Request *sr_event =
|
||||||
@@ -610,31 +499,17 @@ int SampleUtil_PrintEvent(IN Upnp_EventType EventType, IN void *Event)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
int SampleUtil_FindAndParseService(IXML_Document *DescDoc, const char *location,
|
||||||
* SampleUtil_FindAndParseService
|
const char *serviceType, char **serviceId, char **eventURL, char **controlURL)
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* This routine finds the first occurance of a service in a DOM representation
|
|
||||||
* of a description document and parses it.
|
|
||||||
*
|
|
||||||
* 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 IXML_Document *DescDoc, IN const char *location, IN char *serviceType,
|
|
||||||
OUT char **serviceId, OUT char **eventURL, OUT char **controlURL)
|
|
||||||
{
|
{
|
||||||
int i;
|
unsigned int i;
|
||||||
int length;
|
unsigned long length;
|
||||||
int found = 0;
|
int found = 0;
|
||||||
int ret;
|
int ret;
|
||||||
int sindex = 0;
|
#ifdef OLD_FIND_SERVICE_CODE
|
||||||
|
#else /* OLD_FIND_SERVICE_CODE */
|
||||||
|
unsigned int sindex = 0;
|
||||||
|
#endif /* OLD_FIND_SERVICE_CODE */
|
||||||
char *tempServiceType = NULL;
|
char *tempServiceType = NULL;
|
||||||
char *baseURL = NULL;
|
char *baseURL = NULL;
|
||||||
const char *base = NULL;
|
const char *base = NULL;
|
||||||
@@ -644,54 +519,46 @@ int SampleUtil_FindAndParseService(
|
|||||||
IXML_Element *service = NULL;
|
IXML_Element *service = NULL;
|
||||||
|
|
||||||
baseURL = SampleUtil_GetFirstDocumentItem(DescDoc, "URLBase");
|
baseURL = SampleUtil_GetFirstDocumentItem(DescDoc, "URLBase");
|
||||||
if (baseURL) {
|
if (baseURL)
|
||||||
base = baseURL;
|
base = baseURL;
|
||||||
} else {
|
else
|
||||||
base = location;
|
base = location;
|
||||||
}
|
#ifdef OLD_FIND_SERVICE_CODE
|
||||||
|
serviceList = SampleUtil_GetFirstServiceList(DescDoc);
|
||||||
/* Top level */
|
#else /* OLD_FIND_SERVICE_CODE */
|
||||||
for (sindex = 0;
|
for (sindex = 0;
|
||||||
(serviceList = SampleUtil_GetNthServiceList(DescDoc , sindex)) != NULL;
|
(serviceList = SampleUtil_GetNthServiceList(DescDoc , sindex)) != NULL;
|
||||||
sindex ++) {
|
sindex++) {
|
||||||
tempServiceType = NULL;
|
tempServiceType = NULL;
|
||||||
relcontrolURL = NULL;
|
relcontrolURL = NULL;
|
||||||
releventURL = NULL;
|
releventURL = NULL;
|
||||||
service = NULL;
|
service = NULL;
|
||||||
|
#endif /* OLD_FIND_SERVICE_CODE */
|
||||||
/* serviceList = SampleUtil_GetFirstServiceList( DescDoc ); */
|
|
||||||
length = ixmlNodeList_length(serviceList);
|
length = ixmlNodeList_length(serviceList);
|
||||||
for (i = 0; i < length; i++) {
|
for (i = 0; i < length; i++) {
|
||||||
service = (IXML_Element *)ixmlNodeList_item(serviceList, i);
|
service = (IXML_Element *)ixmlNodeList_item(serviceList, i);
|
||||||
tempServiceType =
|
tempServiceType = SampleUtil_GetFirstElementItem(
|
||||||
SampleUtil_GetFirstElementItem(
|
|
||||||
(IXML_Element *)service, "serviceType");
|
(IXML_Element *)service, "serviceType");
|
||||||
if (strcmp(tempServiceType, serviceType) == 0) {
|
if (tempServiceType && strcmp(tempServiceType, serviceType) == 0) {
|
||||||
SampleUtil_Print("Found service: %s\n", serviceType);
|
SampleUtil_Print("Found service: %s\n", serviceType);
|
||||||
*serviceId =
|
*serviceId = SampleUtil_GetFirstElementItem(service, "serviceId");
|
||||||
SampleUtil_GetFirstElementItem(service, "serviceId");
|
|
||||||
SampleUtil_Print("serviceId: %s\n", *serviceId);
|
SampleUtil_Print("serviceId: %s\n", *serviceId);
|
||||||
relcontrolURL =
|
relcontrolURL = SampleUtil_GetFirstElementItem(service, "controlURL");
|
||||||
SampleUtil_GetFirstElementItem(service, "controlURL");
|
releventURL = SampleUtil_GetFirstElementItem(service, "eventSubURL");
|
||||||
releventURL =
|
*controlURL = malloc(strlen(base) + strlen(relcontrolURL) + 1);
|
||||||
SampleUtil_GetFirstElementItem(service, "eventSubURL");
|
|
||||||
*controlURL =
|
|
||||||
malloc(strlen(base) + strlen(relcontrolURL)+1);
|
|
||||||
if (*controlURL) {
|
if (*controlURL) {
|
||||||
ret = UpnpResolveURL(base, relcontrolURL, *controlURL);
|
ret = UpnpResolveURL(base, relcontrolURL, *controlURL);
|
||||||
if (ret != UPNP_E_SUCCESS) {
|
if (ret != UPNP_E_SUCCESS)
|
||||||
SampleUtil_Print("Error generating controlURL from %s + %s\n",
|
SampleUtil_Print("Error generating controlURL from %s + %s\n",
|
||||||
base, relcontrolURL);
|
base, relcontrolURL);
|
||||||
}
|
}
|
||||||
}
|
*eventURL = malloc(strlen(base) + strlen(releventURL) + 1);
|
||||||
*eventURL = malloc(strlen(base) + strlen(releventURL)+1);
|
|
||||||
if (*eventURL) {
|
if (*eventURL) {
|
||||||
ret = UpnpResolveURL(base, releventURL, *eventURL);
|
ret = UpnpResolveURL(base, releventURL, *eventURL);
|
||||||
if (ret != UPNP_E_SUCCESS) {
|
if (ret != UPNP_E_SUCCESS)
|
||||||
SampleUtil_Print("Error generating eventURL from %s + %s\n",
|
SampleUtil_Print("Error generating eventURL from %s + %s\n",
|
||||||
base, releventURL);
|
base, releventURL);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
free(relcontrolURL);
|
free(relcontrolURL);
|
||||||
free(releventURL);
|
free(releventURL);
|
||||||
relcontrolURL = NULL;
|
relcontrolURL = NULL;
|
||||||
@@ -704,30 +571,19 @@ int SampleUtil_FindAndParseService(
|
|||||||
}
|
}
|
||||||
free(tempServiceType);
|
free(tempServiceType);
|
||||||
tempServiceType = NULL;
|
tempServiceType = NULL;
|
||||||
if (serviceList) {
|
if (serviceList)
|
||||||
ixmlNodeList_free(serviceList);
|
ixmlNodeList_free(serviceList);
|
||||||
}
|
|
||||||
serviceList = NULL;
|
serviceList = NULL;
|
||||||
|
#ifdef OLD_FIND_SERVICE_CODE
|
||||||
|
#else /* OLD_FIND_SERVICE_CODE */
|
||||||
}
|
}
|
||||||
|
#endif /* OLD_FIND_SERVICE_CODE */
|
||||||
free(baseURL);
|
free(baseURL);
|
||||||
|
|
||||||
return found;
|
return found;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
int SampleUtil_Print(const char *fmt, ...)
|
||||||
* SampleUtil_Print
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* 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:
|
|
||||||
* Same as printf()
|
|
||||||
*
|
|
||||||
******************************************************************************/
|
|
||||||
int SampleUtil_Print(char *fmt, ...)
|
|
||||||
{
|
{
|
||||||
#define MAX_BUF (8 * 1024)
|
#define MAX_BUF (8 * 1024)
|
||||||
va_list ap;
|
va_list ap;
|
||||||
@@ -740,30 +596,33 @@ int SampleUtil_Print(char *fmt, ...)
|
|||||||
va_start(ap, fmt);
|
va_start(ap, fmt);
|
||||||
rc = vsnprintf(buf, MAX_BUF, fmt, ap);
|
rc = vsnprintf(buf, MAX_BUF, fmt, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
|
if (gPrintFun)
|
||||||
if (gPrintFun) {
|
gPrintFun("%s", buf);
|
||||||
gPrintFun(buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
ithread_mutex_unlock(&display_mutex);
|
ithread_mutex_unlock(&display_mutex);
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
|
||||||
* SampleUtil_StateUpdate
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
*
|
|
||||||
******************************************************************************/
|
|
||||||
void SampleUtil_StateUpdate(const char *varName, const char *varValue,
|
void SampleUtil_StateUpdate(const char *varName, const char *varValue,
|
||||||
const char *UDN, eventType type)
|
const char *UDN, eventType type)
|
||||||
{
|
{
|
||||||
/* TBD: Add mutex here? */
|
/* TBD: Add mutex here? */
|
||||||
if (gStateUpdateFun) {
|
if (gStateUpdateFun)
|
||||||
gStateUpdateFun(varName, varValue, UDN, type);
|
gStateUpdateFun(varName, varValue, UDN, type);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Prints a string to standard out.
|
||||||
|
*/
|
||||||
|
void linux_print(const char *format, ...)
|
||||||
|
{
|
||||||
|
va_list argList;
|
||||||
|
|
||||||
|
va_start(argList, format);
|
||||||
|
vfprintf(stdout, format, argList);
|
||||||
|
fflush(stdout);
|
||||||
|
va_end(argList);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! @} UpnpSamples */
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
#ifndef SAMPLE_UTIL_H
|
||||||
|
#define SAMPLE_UTIL_H
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
@@ -29,30 +32,39 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
/*!
|
||||||
#ifndef SAMPLE_UTIL_H
|
* \defgroup UpnpSamples Sample Code
|
||||||
#define SAMPLE_UTIL_H
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* \file
|
||||||
|
*/
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
|
||||||
#include "ithread.h"
|
#include "ithread.h"
|
||||||
#include "ixml.h" /* for IXML_Document, IXML_Element */
|
#include "ixml.h" /* for IXML_Document, IXML_Element */
|
||||||
#include "upnp.h" /* for Upnp_EventType */
|
#include "upnp.h" /* for Upnp_EventType */
|
||||||
#include "upnptools.h"
|
#include "upnptools.h"
|
||||||
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.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 */
|
||||||
|
|
||||||
/* mutex to control displaying of events */
|
/* mutex to control displaying of events */
|
||||||
extern ithread_mutex_t display_mutex;
|
extern ithread_mutex_t display_mutex;
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
STATE_UPDATE = 0,
|
STATE_UPDATE = 0,
|
||||||
DEVICE_ADDED = 1,
|
DEVICE_ADDED = 1,
|
||||||
@@ -60,233 +72,198 @@ typedef enum {
|
|||||||
GET_VAR_COMPLETE = 3
|
GET_VAR_COMPLETE = 3
|
||||||
} eventType;
|
} eventType;
|
||||||
|
|
||||||
|
/*!
|
||||||
/********************************************************************************
|
* \brief Given a DOM node such as <Channel>11</Channel>, this routine
|
||||||
* 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
|
* extracts the value (e.g., 11) from the node and returns it as
|
||||||
* a string. The string must be freed by the caller using
|
* a string. The string must be freed by the caller using free.
|
||||||
* free.
|
|
||||||
*
|
*
|
||||||
* Parameters:
|
* \return The DOM node as a string.
|
||||||
* node -- The DOM node from which to extract the value
|
*/
|
||||||
*
|
char *SampleUtil_GetElementValue(
|
||||||
********************************************************************************/
|
/*! [in] The DOM node from which to extract the value. */
|
||||||
char *SampleUtil_GetElementValue(IN IXML_Element *element);
|
IXML_Element *element);
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_GetFirstServiceList
|
* \brief Given a DOM node representing a UPnP Device Description Document,
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Given a DOM node representing a UPnP Device Description Document,
|
|
||||||
* this routine parses the document and finds the first service list
|
* this routine parses the document and finds the first service list
|
||||||
* (i.e., the service list for the root device). The 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
|
* is returned as a DOM node list. The NodeList must be freed using
|
||||||
* NodeList_free.
|
* NodeList_free.
|
||||||
*
|
*
|
||||||
* Parameters:
|
* \return The service list is returned as a DOM node list.
|
||||||
* node -- The DOM node from which to extract the service list
|
*/
|
||||||
*
|
IXML_NodeList *SampleUtil_GetFirstServiceList(
|
||||||
********************************************************************************/
|
/*! [in] The DOM node from which to extract the service list. */
|
||||||
|
IXML_Document *doc);
|
||||||
|
|
||||||
IXML_NodeList *SampleUtil_GetFirstServiceList(IN IXML_Document *doc);
|
/*!
|
||||||
|
* \brief Given a document node, this routine searches for the first element
|
||||||
|
|
||||||
/********************************************************************************
|
|
||||||
* 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.
|
* named by the input string item, and returns its value as a string.
|
||||||
* String must be freed by caller using free.
|
* String must be freed by caller using free.
|
||||||
* Parameters:
|
*/
|
||||||
* doc -- The DOM document from which to extract the value
|
char *SampleUtil_GetFirstDocumentItem(
|
||||||
* item -- The item to search for
|
/*! [in] The DOM document from which to extract the value. */
|
||||||
*
|
IXML_Document *doc,
|
||||||
********************************************************************************/
|
/*! [in] The item to search for. */
|
||||||
char *SampleUtil_GetFirstDocumentItem(IN IXML_Document *doc, IN const char *item);
|
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.
|
* named by the input string item, and returns its value as a string.
|
||||||
* The string must be freed using free.
|
* The string must be freed using free.
|
||||||
* Parameters:
|
*/
|
||||||
* node -- The DOM element from which to extract the value
|
char *SampleUtil_GetFirstElementItem(
|
||||||
* item -- The item to search for
|
/*! [in] The DOM element from which to extract the value. */
|
||||||
*
|
IXML_Element *element,
|
||||||
********************************************************************************/
|
/*! [in] The item to search for. */
|
||||||
char *SampleUtil_GetFirstElementItem(IN IXML_Element *element, IN const char *item);
|
const char *item);
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_PrintEventType
|
* \brief Prints a callback event type as a string.
|
||||||
*
|
*/
|
||||||
* Description:
|
void SampleUtil_PrintEventType(
|
||||||
* Prints a callback event type as a string.
|
/*! [in] The callback event. */
|
||||||
*
|
Upnp_EventType S);
|
||||||
* Parameters:
|
|
||||||
* S -- The callback event
|
|
||||||
*
|
|
||||||
********************************************************************************/
|
|
||||||
void SampleUtil_PrintEventType(IN Upnp_EventType S);
|
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_PrintEvent
|
* \brief Prints callback event structure details.
|
||||||
*
|
*/
|
||||||
* Description:
|
int SampleUtil_PrintEvent(
|
||||||
* Prints callback event structure details.
|
/*! [in] The type of callback event. */
|
||||||
*
|
Upnp_EventType EventType,
|
||||||
* Parameters:
|
/*! [in] The callback event structure. */
|
||||||
* EventType -- The type of callback event
|
void *Event);
|
||||||
* Event -- The callback event structure
|
|
||||||
*
|
|
||||||
********************************************************************************/
|
|
||||||
int SampleUtil_PrintEvent(IN Upnp_EventType EventType,
|
|
||||||
IN void *Event);
|
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_FindAndParseService
|
* \brief This routine finds the first occurance of a service in a DOM
|
||||||
*
|
* representation of a description document and parses it. Note that this
|
||||||
* Description:
|
* function currently assumes that the eventURL and controlURL values in
|
||||||
* This routine finds the first occurance of a service in a DOM representation
|
* the service definitions are full URLs. Relative URLs are not handled here.
|
||||||
* 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 (
|
int SampleUtil_FindAndParseService (
|
||||||
IN IXML_Document *DescDoc,
|
/*! [in] The DOM description document. */
|
||||||
IN const char* location,
|
IXML_Document *DescDoc,
|
||||||
IN char *serviceType,
|
/*! [in] The location of the description document. */
|
||||||
OUT char **serviceId,
|
const char *location,
|
||||||
OUT char **eventURL,
|
/*! [in] The type of service to search for. */
|
||||||
OUT char **controlURL);
|
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);
|
||||||
|
|
||||||
|
/*!
|
||||||
/********************************************************************************
|
* \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
|
* control point, and sample util, ultimately use this to display strings
|
||||||
* to the user.
|
* to the user.
|
||||||
*
|
*/
|
||||||
* Parameters:
|
typedef void (*print_string)(
|
||||||
* const char * string.
|
/*! [in] Format. */
|
||||||
*
|
const char *string,
|
||||||
********************************************************************************/
|
/*! [in] Arguments. */
|
||||||
typedef void (*print_string)(const char *string);
|
...)
|
||||||
|
#if (__GNUC__ >= 3)
|
||||||
|
/* This enables printf like format checking by the compiler */
|
||||||
|
__attribute__((format (__printf__, 1, 2)))
|
||||||
|
#endif
|
||||||
|
;
|
||||||
|
|
||||||
//global print function used by sample util
|
/*! global print function used by sample util */
|
||||||
extern print_string gPrintFun;
|
extern print_string gPrintFun;
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* state_update
|
* \brief Prototype for passing back state changes.
|
||||||
*
|
*/
|
||||||
* Description:
|
|
||||||
* Prototype for passing back state changes
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
* const char * varName
|
|
||||||
* const char * varValue
|
|
||||||
* const char * UDN
|
|
||||||
* int newDevice
|
|
||||||
********************************************************************************/
|
|
||||||
typedef void (*state_update)(
|
typedef void (*state_update)(
|
||||||
|
/*! [in] . */
|
||||||
const char *varName,
|
const char *varName,
|
||||||
|
/*! [in] . */
|
||||||
const char *varValue,
|
const char *varValue,
|
||||||
|
/*! [in] . */
|
||||||
const char *UDN,
|
const char *UDN,
|
||||||
|
/*! [in] . */
|
||||||
eventType type);
|
eventType type);
|
||||||
|
|
||||||
//global state update function used by smaple util
|
/*! global state update function used by smaple util */
|
||||||
extern state_update gStateUpdateFun;
|
extern state_update gStateUpdateFun;
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_Initialize
|
* \brief Initializes the sample util. Must be called before any sample util
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Initializes the sample util. Must be called before any sample util
|
|
||||||
* functions. May be called multiple times.
|
* functions. May be called multiple times.
|
||||||
*
|
*/
|
||||||
* Parameters:
|
int SampleUtil_Initialize(
|
||||||
* print_function - print function to use in SampleUtil_Print
|
/*! [in] Print function to use in SampleUtil_Print. */
|
||||||
*
|
print_string print_function);
|
||||||
********************************************************************************/
|
|
||||||
int SampleUtil_Initialize(print_string print_function);
|
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_Finish
|
* \brief Releases Resources held by sample util.
|
||||||
*
|
*/
|
||||||
* Description:
|
|
||||||
* Releases Resources held by sample util.
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
*
|
|
||||||
********************************************************************************/
|
|
||||||
int SampleUtil_Finish();
|
int SampleUtil_Finish();
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_Print
|
* \brief Function emulating printf that ultimately calls the registered print
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Function emulating printf that ultimately calls the registered print
|
|
||||||
* function with the formatted string.
|
* function with the formatted string.
|
||||||
*
|
*
|
||||||
* Parameters:
|
* Provides platform-specific print functionality. This function should be
|
||||||
* fmt - format (see printf)
|
* called when you want to print content suitable for console output (i.e.,
|
||||||
* . . . - variable number of args. (see printf)
|
* in a large text box or on a screen). If your device/operating system is
|
||||||
|
* not supported here, you should add a port.
|
||||||
*
|
*
|
||||||
********************************************************************************/
|
* \return The same as printf.
|
||||||
int SampleUtil_Print(char *fmt, ...);
|
*/
|
||||||
|
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
|
||||||
|
;
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_RegisterUpdateFunction
|
* \brief
|
||||||
*
|
*/
|
||||||
* Description:
|
int SampleUtil_RegisterUpdateFunction(
|
||||||
*
|
/*! [in] . */
|
||||||
* Parameters:
|
state_update update_function);
|
||||||
*
|
|
||||||
********************************************************************************/
|
|
||||||
int SampleUtil_RegisterUpdateFunction(state_update update_function);
|
|
||||||
|
|
||||||
/********************************************************************************
|
/*!
|
||||||
* SampleUtil_StateUpdate
|
* \brief
|
||||||
*
|
*/
|
||||||
* Description:
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
*
|
|
||||||
********************************************************************************/
|
|
||||||
void SampleUtil_StateUpdate(
|
void SampleUtil_StateUpdate(
|
||||||
|
/*! [in] . */
|
||||||
const char *varName,
|
const char *varName,
|
||||||
|
/*! [in] . */
|
||||||
const char *varValue,
|
const char *varValue,
|
||||||
|
/*! [in] . */
|
||||||
const char *UDN,
|
const char *UDN,
|
||||||
|
/*! [in] . */
|
||||||
eventType type);
|
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
|
#ifdef __cplusplus
|
||||||
};
|
};
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
#define snprintf _snprintf
|
#define snprintf _snprintf
|
||||||
#define strcasecmp stricmp
|
#define strcasecmp stricmp
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*! @} UpnpSamples */
|
||||||
|
|
||||||
#endif /* SAMPLE_UTIL_H */
|
#endif /* SAMPLE_UTIL_H */
|
||||||
|
|
||||||
|
|||||||
1585
upnp/sample/common/tv_ctrlpt.c
Normal file
1585
upnp/sample/common/tv_ctrlpt.c
Normal file
File diff suppressed because it is too large
Load Diff
@@ -1,3 +1,6 @@
|
|||||||
|
#ifndef UPNP_TV_CTRLPT_H
|
||||||
|
#define UPNP_TV_CTRLPT_H
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
@@ -29,38 +32,31 @@
|
|||||||
*
|
*
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
|
/*!
|
||||||
#ifndef UPNP_TV_CTRLPT_H
|
* \addtogroup UpnpSamples
|
||||||
#define UPNP_TV_CTRLPT_H
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* \name Contro Point Sample API
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* \file
|
||||||
|
*/
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#include "sample_util.h"
|
#include "sample_util.h"
|
||||||
|
|
||||||
|
|
||||||
#include "ithread.h"
|
|
||||||
#include "upnp.h"
|
#include "upnp.h"
|
||||||
#include "UpnpString.h"
|
#include "UpnpString.h"
|
||||||
#include "upnptools.h"
|
#include "upnptools.h"
|
||||||
|
|
||||||
|
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdio.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_SERVCOUNT 2
|
||||||
#define TV_SERVICE_CONTROL 0
|
#define TV_SERVICE_CONTROL 0
|
||||||
@@ -86,10 +82,8 @@ extern "C" {
|
|||||||
/* This should be the maximum VARCOUNT from above */
|
/* This should be the maximum VARCOUNT from above */
|
||||||
#define TV_MAXVARS TV_PICTURE_VARCOUNT
|
#define TV_MAXVARS TV_PICTURE_VARCOUNT
|
||||||
|
|
||||||
extern char TvDeviceType[];
|
extern const char *TvServiceName[];
|
||||||
extern char *TvServiceType[];
|
extern const char *TvVarName[TV_SERVICE_SERVCOUNT][TV_MAXVARS];
|
||||||
extern char *TvServiceName[];
|
|
||||||
extern char *TvVarName[TV_SERVICE_SERVCOUNT][TV_MAXVARS];
|
|
||||||
extern char TvVarCount[];
|
extern char TvVarCount[];
|
||||||
|
|
||||||
struct tv_service {
|
struct tv_service {
|
||||||
@@ -127,9 +121,8 @@ int TvCtrlPointRemoveDevice(const char *);
|
|||||||
int TvCtrlPointRemoveAll(void);
|
int TvCtrlPointRemoveAll(void);
|
||||||
int TvCtrlPointRefresh(void);
|
int TvCtrlPointRefresh(void);
|
||||||
|
|
||||||
|
int TvCtrlPointSendAction(int, int, const char *, const char **, char **, int);
|
||||||
int TvCtrlPointSendAction(int, int, char *, char **, char **, int);
|
int TvCtrlPointSendActionNumericArg(int devnum, int service, const char *actionName, const char *paramName, int paramValue);
|
||||||
int TvCtrlPointSendActionNumericArg(int devnum, int service, char *actionName, char *paramName, int paramValue);
|
|
||||||
int TvCtrlPointSendPowerOn(int devnum);
|
int TvCtrlPointSendPowerOn(int devnum);
|
||||||
int TvCtrlPointSendPowerOff(int devnum);
|
int TvCtrlPointSendPowerOff(int devnum);
|
||||||
int TvCtrlPointSendSetChannel(int, int);
|
int TvCtrlPointSendSetChannel(int, int);
|
||||||
@@ -139,7 +132,7 @@ int TvCtrlPointSendSetTint(int, int);
|
|||||||
int TvCtrlPointSendSetContrast(int, int);
|
int TvCtrlPointSendSetContrast(int, int);
|
||||||
int TvCtrlPointSendSetBrightness(int, int);
|
int TvCtrlPointSendSetBrightness(int, int);
|
||||||
|
|
||||||
int TvCtrlPointGetVar(int, int, char*);
|
int TvCtrlPointGetVar(int, int, const char *);
|
||||||
int TvCtrlPointGetPower(int devnum);
|
int TvCtrlPointGetPower(int devnum);
|
||||||
int TvCtrlPointGetChannel(int);
|
int TvCtrlPointGetChannel(int);
|
||||||
int TvCtrlPointGetVolume(int);
|
int TvCtrlPointGetVolume(int);
|
||||||
@@ -153,19 +146,80 @@ int TvCtrlPointPrintList(void);
|
|||||||
int TvCtrlPointPrintDevice(int);
|
int TvCtrlPointPrintDevice(int);
|
||||||
void TvCtrlPointAddDevice(IXML_Document *, const char *, int);
|
void TvCtrlPointAddDevice(IXML_Document *, const char *, int);
|
||||||
void TvCtrlPointHandleGetVar(const char *, const char *, const DOMString);
|
void TvCtrlPointHandleGetVar(const char *, const char *, const DOMString);
|
||||||
void TvStateUpdate(char*,int, IXML_Document * , char **);
|
|
||||||
|
/*!
|
||||||
|
* \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 TvCtrlPointHandleEvent(const char *, int, IXML_Document *);
|
||||||
void TvCtrlPointHandleSubscribeUpdate(const char *, const Upnp_SID, int);
|
void TvCtrlPointHandleSubscribeUpdate(const char *, const Upnp_SID, int);
|
||||||
int TvCtrlPointCallbackEventHandler(Upnp_EventType, void *, void *);
|
int TvCtrlPointCallbackEventHandler(Upnp_EventType, void *, void *);
|
||||||
void TvCtrlPointVerifyTimeouts(int);
|
|
||||||
|
/*!
|
||||||
|
* \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 TvCtrlPointPrintCommands(void);
|
||||||
void* TvCtrlPointCommandLoop(void *);
|
void* TvCtrlPointCommandLoop(void *);
|
||||||
int TvCtrlPointStart(print_string printFunctionPtr, state_update updateFunctionPtr);
|
int TvCtrlPointStart(print_string printFunctionPtr, state_update updateFunctionPtr, int combo);
|
||||||
int TvCtrlPointStop(void);
|
int TvCtrlPointStop(void);
|
||||||
int TvCtrlPointProcessCommand(char *cmdline);
|
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
|
#ifdef __cplusplus
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif //UPNP_TV_CTRLPT_H
|
|
||||||
|
/*! @} Device Sample */
|
||||||
|
|
||||||
|
/*! @} UpnpSamples */
|
||||||
|
|
||||||
|
#endif /* UPNP_TV_CTRLPT_H */
|
||||||
1463
upnp/sample/common/tv_device.c
Normal file
1463
upnp/sample/common/tv_device.c
Normal file
File diff suppressed because it is too large
Load Diff
571
upnp/sample/common/tv_device.h
Normal file
571
upnp/sample/common/tv_device.h
Normal file
@@ -0,0 +1,571 @@
|
|||||||
|
#ifndef UPNP_TV_DEVICE_H
|
||||||
|
#define UPNP_TV_DEVICE_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.
|
||||||
|
*
|
||||||
|
**************************************************************************/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \addtogroup UpnpSamples
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* \name Device Sample API
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* \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>
|
||||||
|
|
||||||
|
/*! 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
|
||||||
|
|
||||||
|
/*! @} Control Point Sample API */
|
||||||
|
|
||||||
|
/*! @} UpnpSamples */
|
||||||
|
|
||||||
|
#endif /* UPNP_TV_DEVICE_H */
|
||||||
72
upnp/sample/linux/tv_combo_main.c
Normal file
72
upnp/sample/linux/tv_combo_main.c
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
/*******************************************************************************
|
||||||
|
*
|
||||||
|
* 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;
|
||||||
|
}
|
||||||
|
|
||||||
72
upnp/sample/linux/tv_ctrlpt_main.c
Normal file
72
upnp/sample/linux/tv_ctrlpt_main.c
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
/*******************************************************************************
|
||||||
|
*
|
||||||
|
* 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;
|
||||||
|
}
|
||||||
|
|
||||||
69
upnp/sample/linux/tv_device_main.c
Normal file
69
upnp/sample/linux/tv_device_main.c
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
/*******************************************************************************
|
||||||
|
*
|
||||||
|
* 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;
|
||||||
|
|
||||||
|
rc = device_main(argc, argv);
|
||||||
|
if (rc != UPNP_E_SUCCESS) {
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 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;
|
||||||
|
}
|
||||||
|
|
||||||
@@ -1,491 +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 "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, described in the tvdevicedesc.xml description document." );
|
|
||||||
SampleUtil_Print( "It also registers itself as a tv device." );
|
|
||||||
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;
|
|
||||||
#ifdef WIN32
|
|
||||||
#else
|
|
||||||
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 );
|
|
||||||
|
|
||||||
#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;
|
|
||||||
}
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,171 +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
|
|
||||||
|
|
||||||
|
|
||||||
#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 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(const 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 *, const char *, int);
|
|
||||||
void TvCtrlPointHandleGetVar(const char *, const char *, const DOMString);
|
|
||||||
void TvStateUpdate(char*,int, IXML_Document * , char **);
|
|
||||||
void TvCtrlPointHandleEvent(const char *, int, IXML_Document *);
|
|
||||||
void TvCtrlPointHandleSubscribeUpdate(const char *, const 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
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,632 +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
|
|
||||||
|
|
||||||
|
|
||||||
#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
|
|
||||||
|
|
||||||
|
|
||||||
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(void);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
@@ -1,441 +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 "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;
|
|
||||||
#ifdef WIN32
|
|
||||||
#else
|
|
||||||
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 );
|
|
||||||
|
|
||||||
#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;
|
|
||||||
}
|
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,198 +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 "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;
|
|
||||||
#ifdef WIN32
|
|
||||||
#else
|
|
||||||
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 );
|
|
||||||
|
|
||||||
#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;
|
|
||||||
}
|
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,632 +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
|
|
||||||
|
|
||||||
|
|
||||||
#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
|
|
||||||
|
|
||||||
|
|
||||||
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(void);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
@@ -1,5 +1,3 @@
|
|||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \addtogroup UpnpString
|
* \addtogroup UpnpString
|
||||||
*
|
*
|
||||||
@@ -17,29 +15,50 @@
|
|||||||
* \brief UpnpString object implementation.
|
* \brief UpnpString object implementation.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
|
|
||||||
#include "UpnpString.h"
|
#include "UpnpString.h"
|
||||||
|
|
||||||
|
|
||||||
#include <stdlib.h> /* for calloc(), free() */
|
#include <stdlib.h> /* for calloc(), free() */
|
||||||
#include <string.h> /* for strlen(), strdup() */
|
#include <string.h> /* for strlen(), strdup() */
|
||||||
|
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
#define strcasecmp stricmp
|
#define strcasecmp stricmp
|
||||||
#else
|
#else
|
||||||
/* Other systems have strncasecmp */
|
/* Other systems have strncasecmp */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef UPNP_USE_MSVCPP
|
||||||
|
/* VC has strnlen which is already included but with (potentially) different linkage */
|
||||||
|
/* strnlen() is a GNU extension. */
|
||||||
|
#if HAVE_STRNLEN
|
||||||
|
extern size_t strnlen(const char *s, size_t maxlen);
|
||||||
|
#else /* HAVE_STRNLEN */
|
||||||
|
static size_t strnlen(const char *s, size_t n)
|
||||||
|
{
|
||||||
|
const char *p = (const char *)memchr(s, 0, n);
|
||||||
|
return p ? p - s : n;
|
||||||
|
}
|
||||||
|
#endif /* HAVE_STRNLEN */
|
||||||
|
#endif /* WIN32 */
|
||||||
|
|
||||||
/* strndup() is a GNU extension. Other systems must fix it with elif's. */
|
/* strndup() is a GNU extension. */
|
||||||
#ifdef __GNUC__
|
#if HAVE_STRNDUP && !defined(WIN32)
|
||||||
extern char *strndup(__const char *__string, size_t __n);
|
extern char *strndup(__const char *__string, size_t __n);
|
||||||
#endif
|
#else /* HAVE_STRNDUP && !defined(WIN32) */
|
||||||
|
static char *strndup(const char *__string, size_t __n)
|
||||||
|
{
|
||||||
|
size_t strsize = strnlen(__string, __n);
|
||||||
|
char *newstr = (char *)malloc(strsize + 1);
|
||||||
|
if (newstr == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
strncpy(newstr, __string, strsize);
|
||||||
|
newstr[strsize] = 0;
|
||||||
|
|
||||||
|
return newstr;
|
||||||
|
}
|
||||||
|
#endif /* HAVE_STRNDUP && !defined(WIN32) */
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Internal implementation of the class UpnpString.
|
* \brief Internal implementation of the class UpnpString.
|
||||||
@@ -49,17 +68,16 @@ extern char *strndup(__const char *__string, size_t __n);
|
|||||||
struct SUpnpString
|
struct SUpnpString
|
||||||
{
|
{
|
||||||
/*! \brief Length of the string. */
|
/*! \brief Length of the string. */
|
||||||
int m_length;
|
size_t m_length;
|
||||||
/*! \brief Pointer to a dynamically allocated area that holds the NULL
|
/*! \brief Pointer to a dynamically allocated area that holds the NULL
|
||||||
* terminated string. */
|
* terminated string. */
|
||||||
char *m_string;
|
char *m_string;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
UpnpString *UpnpString_new()
|
UpnpString *UpnpString_new()
|
||||||
{
|
{
|
||||||
// All bytes are zero, and so is the length of the string.
|
/* All bytes are zero, and so is the length of the string. */
|
||||||
struct SUpnpString *p = calloc(1, sizeof (struct SUpnpString));
|
struct SUpnpString *p = calloc((size_t)1, sizeof (struct SUpnpString));
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
goto error_handler1;
|
goto error_handler1;
|
||||||
}
|
}
|
||||||
@@ -67,29 +85,28 @@ UpnpString *UpnpString_new()
|
|||||||
p->m_length = 0;
|
p->m_length = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// This byte is zero, calloc does initialize it.
|
/* This byte is zero, calloc does initialize it. */
|
||||||
p->m_string = calloc(1, 1);
|
p->m_string = calloc((size_t)1, (size_t)1);
|
||||||
if (p->m_string == NULL) {
|
if (p->m_string == NULL) {
|
||||||
goto error_handler2;
|
goto error_handler2;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (UpnpString *)p;
|
return (UpnpString *)p;
|
||||||
|
|
||||||
//free(p->m_string);
|
/*free(p->m_string); */
|
||||||
error_handler2:
|
error_handler2:
|
||||||
free(p);
|
free(p);
|
||||||
error_handler1:
|
error_handler1:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void UpnpString_delete(UpnpString *p)
|
void UpnpString_delete(UpnpString *p)
|
||||||
{
|
{
|
||||||
struct SUpnpString *q = (struct SUpnpString *)p;
|
struct SUpnpString *q = (struct SUpnpString *)p;
|
||||||
|
|
||||||
if (!q) return;
|
if (!q) return;
|
||||||
|
|
||||||
q->m_length = 0;
|
q->m_length = (size_t)0;
|
||||||
|
|
||||||
free(q->m_string);
|
free(q->m_string);
|
||||||
q->m_string = NULL;
|
q->m_string = NULL;
|
||||||
@@ -97,10 +114,9 @@ void UpnpString_delete(UpnpString *p)
|
|||||||
free(p);
|
free(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
UpnpString *UpnpString_dup(const UpnpString *p)
|
UpnpString *UpnpString_dup(const UpnpString *p)
|
||||||
{
|
{
|
||||||
struct SUpnpString *q = calloc(1, sizeof (struct SUpnpString));
|
struct SUpnpString *q = calloc((size_t)1, sizeof (struct SUpnpString));
|
||||||
if (q == NULL) {
|
if (q == NULL) {
|
||||||
goto error_handler1;
|
goto error_handler1;
|
||||||
}
|
}
|
||||||
@@ -112,14 +128,13 @@ UpnpString *UpnpString_dup(const UpnpString *p)
|
|||||||
|
|
||||||
return (UpnpString *)q;
|
return (UpnpString *)q;
|
||||||
|
|
||||||
//free(q->m_string);
|
/*free(q->m_string); */
|
||||||
error_handler2:
|
error_handler2:
|
||||||
free(q);
|
free(q);
|
||||||
error_handler1:
|
error_handler1:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void UpnpString_assign(UpnpString *p, const UpnpString *q)
|
void UpnpString_assign(UpnpString *p, const UpnpString *q)
|
||||||
{
|
{
|
||||||
if (p != q) {
|
if (p != q) {
|
||||||
@@ -127,13 +142,11 @@ void UpnpString_assign(UpnpString *p, const UpnpString *q)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
size_t UpnpString_get_Length(const UpnpString *p)
|
size_t UpnpString_get_Length(const UpnpString *p)
|
||||||
{
|
{
|
||||||
return ((struct SUpnpString *)p)->m_length;
|
return ((struct SUpnpString *)p)->m_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void UpnpString_set_Length(UpnpString *p, size_t n)
|
void UpnpString_set_Length(UpnpString *p, size_t n)
|
||||||
{
|
{
|
||||||
if (((struct SUpnpString *)p)->m_length > n) {
|
if (((struct SUpnpString *)p)->m_length > n) {
|
||||||
@@ -143,13 +156,11 @@ void UpnpString_set_Length(UpnpString *p, size_t n)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
const char *UpnpString_get_String(const UpnpString *p)
|
const char *UpnpString_get_String(const UpnpString *p)
|
||||||
{
|
{
|
||||||
return ((struct SUpnpString *)p)->m_string;
|
return ((struct SUpnpString *)p)->m_string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int UpnpString_set_String(UpnpString *p, const char *s)
|
int UpnpString_set_String(UpnpString *p, const char *s)
|
||||||
{
|
{
|
||||||
char *q = strdup(s);
|
char *q = strdup(s);
|
||||||
@@ -162,7 +173,6 @@ error_handler1:
|
|||||||
return q != NULL;
|
return q != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int UpnpString_set_StringN(UpnpString *p, const char *s, size_t n)
|
int UpnpString_set_StringN(UpnpString *p, const char *s, size_t n)
|
||||||
{
|
{
|
||||||
char *q = strndup(s, n);
|
char *q = strndup(s, n);
|
||||||
@@ -175,15 +185,13 @@ error_handler1:
|
|||||||
return q != NULL;
|
return q != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void UpnpString_clear(UpnpString *p)
|
void UpnpString_clear(UpnpString *p)
|
||||||
{
|
{
|
||||||
((struct SUpnpString *)p)->m_length = 0;
|
((struct SUpnpString *)p)->m_length = (size_t)0;
|
||||||
/* No need to realloc now, will do later when needed. */
|
/* No need to realloc now, will do later when needed. */
|
||||||
((struct SUpnpString *)p)->m_string[0] = 0;
|
((struct SUpnpString *)p)->m_string[0] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int UpnpString_cmp(UpnpString *p, UpnpString *q)
|
int UpnpString_cmp(UpnpString *p, UpnpString *q)
|
||||||
{
|
{
|
||||||
const char *cp = UpnpString_get_String(p);
|
const char *cp = UpnpString_get_String(p);
|
||||||
@@ -192,7 +200,6 @@ int UpnpString_cmp(UpnpString *p, UpnpString *q)
|
|||||||
return strcmp(cp, cq);
|
return strcmp(cp, cq);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int UpnpString_casecmp(UpnpString *p, UpnpString *q)
|
int UpnpString_casecmp(UpnpString *p, UpnpString *q)
|
||||||
{
|
{
|
||||||
const char *cp = UpnpString_get_String(p);
|
const char *cp = UpnpString_get_String(p);
|
||||||
@@ -202,4 +209,3 @@ int UpnpString_casecmp(UpnpString *p, UpnpString *q)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* @} UpnpString */
|
/* @} UpnpString */
|
||||||
|
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -29,21 +29,23 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
#include "config.h"
|
/*!
|
||||||
|
* \file
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
#include "ithread.h"
|
#include "ithread.h"
|
||||||
#include "ixml.h"
|
#include "ixml.h"
|
||||||
#include "upnp.h"
|
#include "upnp.h"
|
||||||
#include "upnpdebug.h"
|
#include "upnpdebug.h"
|
||||||
|
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
|
||||||
/*! 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;
|
static ithread_mutex_t GlobalDebugMutex;
|
||||||
@@ -63,31 +65,25 @@ static const char *errFileName = "IUpnpErrFile.txt";
|
|||||||
/*! Name of the info file */
|
/*! Name of the info file */
|
||||||
static const char *infoFileName = "IUpnpInfoFile.txt";
|
static const char *infoFileName = "IUpnpInfoFile.txt";
|
||||||
|
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
|
|
||||||
|
|
||||||
int UpnpInitLog(void)
|
int UpnpInitLog(void)
|
||||||
{
|
{
|
||||||
ithread_mutex_init(&GlobalDebugMutex, NULL);
|
ithread_mutex_init(&GlobalDebugMutex, NULL);
|
||||||
if(DEBUG_TARGET == 1) {
|
if (DEBUG_TARGET == 1) {
|
||||||
if((ErrFileHnd = fopen( errFileName, "a")) == NULL) {
|
if ((ErrFileHnd = fopen(errFileName, "a")) == NULL) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if((InfoFileHnd = fopen( infoFileName, "a")) == NULL) {
|
if ((InfoFileHnd = fopen(infoFileName, "a")) == NULL) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void UpnpSetLogLevel(Upnp_LogLevel log_level)
|
void UpnpSetLogLevel(Upnp_LogLevel log_level)
|
||||||
{
|
{
|
||||||
g_log_level = log_level;
|
g_log_level = log_level;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void UpnpCloseLog(void)
|
void UpnpCloseLog(void)
|
||||||
{
|
{
|
||||||
if (DEBUG_TARGET == 1) {
|
if (DEBUG_TARGET == 1) {
|
||||||
@@ -99,10 +95,7 @@ void UpnpCloseLog(void)
|
|||||||
ithread_mutex_destroy(&GlobalDebugMutex);
|
ithread_mutex_destroy(&GlobalDebugMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UpnpSetLogFileNames(const char *ErrFileName, const char *InfoFileName)
|
||||||
void UpnpSetLogFileNames(
|
|
||||||
const char *ErrFileName,
|
|
||||||
const char *InfoFileName)
|
|
||||||
{
|
{
|
||||||
if (ErrFileName) {
|
if (ErrFileName) {
|
||||||
errFileName = ErrFileName;
|
errFileName = ErrFileName;
|
||||||
@@ -112,58 +105,47 @@ void UpnpSetLogFileNames(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int DebugAtThisLevel(Upnp_LogLevel DLevel, Dbg_Module Module)
|
||||||
int DebugAtThisLevel(
|
|
||||||
Upnp_LogLevel DLevel,
|
|
||||||
Dbg_Module Module)
|
|
||||||
{
|
{
|
||||||
int ret = DLevel <= g_log_level;
|
int ret = DLevel <= g_log_level;
|
||||||
ret &=
|
ret &=
|
||||||
DEBUG_ALL ||
|
DEBUG_ALL ||
|
||||||
(Module == SSDP && DEBUG_SSDP ) ||
|
(Module == SSDP && DEBUG_SSDP) ||
|
||||||
(Module == SOAP && DEBUG_SOAP ) ||
|
(Module == SOAP && DEBUG_SOAP) ||
|
||||||
(Module == GENA && DEBUG_GENA ) ||
|
(Module == GENA && DEBUG_GENA) ||
|
||||||
(Module == TPOOL && DEBUG_TPOOL) ||
|
(Module == TPOOL && DEBUG_TPOOL) ||
|
||||||
(Module == MSERV && DEBUG_MSERV) ||
|
(Module == MSERV && DEBUG_MSERV) ||
|
||||||
(Module == DOM && DEBUG_DOM ) ||
|
(Module == DOM && DEBUG_DOM) || (Module == HTTP && DEBUG_HTTP);
|
||||||
(Module == HTTP && DEBUG_HTTP );
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
Module = Module; /* VC complains about this being unreferenced */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UpnpPrintf(Upnp_LogLevel DLevel,
|
||||||
void UpnpPrintf(
|
|
||||||
Upnp_LogLevel DLevel,
|
|
||||||
Dbg_Module Module,
|
Dbg_Module Module,
|
||||||
const char *DbgFileName,
|
const char *DbgFileName, int DbgLineNo, const char *FmtStr, ...)
|
||||||
int DbgLineNo,
|
|
||||||
const char *FmtStr,
|
|
||||||
...)
|
|
||||||
{
|
{
|
||||||
va_list ArgList;
|
va_list ArgList;
|
||||||
|
|
||||||
if (!DebugAtThisLevel(DLevel, Module)) {
|
if (!DebugAtThisLevel(DLevel, Module))
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
|
|
||||||
ithread_mutex_lock(&GlobalDebugMutex);
|
ithread_mutex_lock(&GlobalDebugMutex);
|
||||||
va_start(ArgList, FmtStr);
|
va_start(ArgList, FmtStr);
|
||||||
if (!DEBUG_TARGET) {
|
if (!DEBUG_TARGET) {
|
||||||
if (DbgFileName) {
|
if (DbgFileName)
|
||||||
UpnpDisplayFileAndLine(stdout, DbgFileName, DbgLineNo);
|
UpnpDisplayFileAndLine(stdout, DbgFileName, DbgLineNo);
|
||||||
}
|
|
||||||
vfprintf(stdout, FmtStr, ArgList);
|
vfprintf(stdout, FmtStr, ArgList);
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
} else if (DLevel == 0) {
|
} else if (DLevel == 0) {
|
||||||
if (DbgFileName) {
|
if (DbgFileName)
|
||||||
UpnpDisplayFileAndLine(ErrFileHnd, DbgFileName, DbgLineNo);
|
UpnpDisplayFileAndLine(ErrFileHnd, DbgFileName,
|
||||||
}
|
DbgLineNo);
|
||||||
vfprintf(ErrFileHnd, FmtStr, ArgList);
|
vfprintf(ErrFileHnd, FmtStr, ArgList);
|
||||||
fflush(ErrFileHnd);
|
fflush(ErrFileHnd);
|
||||||
} else {
|
} else {
|
||||||
if (DbgFileName) {
|
if (DbgFileName)
|
||||||
UpnpDisplayFileAndLine(InfoFileHnd, DbgFileName, DbgLineNo);
|
UpnpDisplayFileAndLine(InfoFileHnd, DbgFileName,
|
||||||
}
|
DbgLineNo);
|
||||||
vfprintf(InfoFileHnd, FmtStr, ArgList);
|
vfprintf(InfoFileHnd, FmtStr, ArgList);
|
||||||
fflush(InfoFileHnd);
|
fflush(InfoFileHnd);
|
||||||
}
|
}
|
||||||
@@ -171,31 +153,23 @@ void UpnpPrintf(
|
|||||||
ithread_mutex_unlock(&GlobalDebugMutex);
|
ithread_mutex_unlock(&GlobalDebugMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
FILE *GetDebugFile(Upnp_LogLevel DLevel, Dbg_Module Module)
|
FILE *GetDebugFile(Upnp_LogLevel DLevel, Dbg_Module Module)
|
||||||
{
|
{
|
||||||
FILE *ret;
|
FILE *ret;
|
||||||
|
|
||||||
if (!DebugAtThisLevel(DLevel, Module)) {
|
if (!DebugAtThisLevel(DLevel, Module))
|
||||||
ret = NULL;
|
ret = NULL;
|
||||||
}
|
if (!DEBUG_TARGET)
|
||||||
|
|
||||||
if (!DEBUG_TARGET) {
|
|
||||||
ret = stdout;
|
ret = stdout;
|
||||||
} else if (DLevel == 0) {
|
else if (DLevel == 0)
|
||||||
ret = ErrFileHnd;
|
ret = ErrFileHnd;
|
||||||
} else {
|
else
|
||||||
ret = InfoFileHnd;
|
ret = InfoFileHnd;
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UpnpDisplayFileAndLine(FILE *fd, const char *DbgFileName, int DbgLineNo)
|
||||||
void UpnpDisplayFileAndLine(
|
|
||||||
FILE *fd,
|
|
||||||
const char *DbgFileName,
|
|
||||||
int DbgLineNo)
|
|
||||||
{
|
{
|
||||||
#define NLINES 2
|
#define NLINES 2
|
||||||
#define MAX_LINE_SIZE 512
|
#define MAX_LINE_SIZE 512
|
||||||
@@ -205,10 +179,8 @@ void UpnpDisplayFileAndLine(
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Initialize the pointer array */
|
/* Initialize the pointer array */
|
||||||
for (i = 0; i < NLINES; i++) {
|
for (i = 0; i < NLINES; i++)
|
||||||
lines[i] = buf[i];
|
lines[i] = buf[i];
|
||||||
}
|
|
||||||
|
|
||||||
/* Put the debug lines in the buffer */
|
/* Put the debug lines in the buffer */
|
||||||
sprintf(buf[0], "DEBUG - THREAD ID: 0x%lX",
|
sprintf(buf[0], "DEBUG - THREAD ID: 0x%lX",
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
@@ -217,63 +189,53 @@ void UpnpDisplayFileAndLine(
|
|||||||
(unsigned long int)ithread_self()
|
(unsigned long int)ithread_self()
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
if (DbgFileName) {
|
if (DbgFileName)
|
||||||
sprintf(buf[1],
|
sprintf(buf[1], "FILE: %s, LINE: %d", DbgFileName, DbgLineNo);
|
||||||
"FILE: %s, LINE: %d",
|
|
||||||
DbgFileName,
|
|
||||||
DbgLineNo);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Show the lines centered */
|
/* Show the lines centered */
|
||||||
UpnpDisplayBanner(fd, lines, NLINES, NUMBER_OF_STARS);
|
UpnpDisplayBanner(fd, lines, NLINES, NUMBER_OF_STARS);
|
||||||
fflush(fd);
|
fflush(fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UpnpDisplayBanner(FILE * fd,
|
||||||
void UpnpDisplayBanner(
|
const char **lines, size_t size, size_t starLength)
|
||||||
FILE * fd,
|
|
||||||
const char **lines,
|
|
||||||
size_t size,
|
|
||||||
int starLength)
|
|
||||||
{
|
{
|
||||||
int leftMarginLength = starLength / 2 + 1;
|
size_t leftMarginLength = starLength / 2 + 1;
|
||||||
int rightMarginLength = starLength / 2 + 1;
|
size_t rightMarginLength = starLength / 2 + 1;
|
||||||
int i = 0;
|
size_t i = 0;
|
||||||
int LineSize = 0;
|
size_t LineSize = 0;
|
||||||
int starLengthMinus2 = starLength - 2;
|
size_t starLengthMinus2 = starLength - 2;
|
||||||
|
|
||||||
char *leftMargin = ( char * )malloc( leftMarginLength );
|
char *leftMargin = malloc(leftMarginLength);
|
||||||
char *rightMargin = ( char * )malloc( rightMarginLength );
|
char *rightMargin = malloc(rightMarginLength);
|
||||||
char *stars = ( char * )malloc( starLength + 1 );
|
char *stars = malloc(starLength + 1);
|
||||||
char *currentLine = ( char * )malloc( starLength + 1 );
|
char *currentLine = malloc(starLength + 1);
|
||||||
const char *line = NULL;
|
const char *line = NULL;
|
||||||
|
|
||||||
memset( stars, '*', starLength );
|
memset(stars, '*', starLength);
|
||||||
stars[starLength] = 0;
|
stars[starLength] = 0;
|
||||||
memset( leftMargin, 0, leftMarginLength );
|
memset(leftMargin, 0, leftMarginLength);
|
||||||
memset( rightMargin, 0, rightMarginLength );
|
memset(rightMargin, 0, rightMarginLength);
|
||||||
fprintf( fd, "\n%s\n", stars );
|
fprintf(fd, "\n%s\n", stars);
|
||||||
for( i = 0; i < size; i++ ) {
|
for (i = 0; i < size; i++) {
|
||||||
LineSize = strlen( lines[i] );
|
LineSize = strlen(lines[i]);
|
||||||
line = lines[i];
|
line = lines[i];
|
||||||
while( LineSize > starLengthMinus2 ) {
|
while (LineSize > starLengthMinus2) {
|
||||||
memcpy( currentLine, line, starLengthMinus2 );
|
memcpy(currentLine, line, starLengthMinus2);
|
||||||
currentLine[starLengthMinus2] = 0;
|
currentLine[starLengthMinus2] = 0;
|
||||||
fprintf( fd, "*%s*\n", currentLine );
|
fprintf(fd, "*%s*\n", currentLine);
|
||||||
LineSize -= starLengthMinus2;
|
LineSize -= starLengthMinus2;
|
||||||
line += starLengthMinus2;
|
line += starLengthMinus2;
|
||||||
}
|
}
|
||||||
leftMarginLength = (starLengthMinus2 - LineSize)/2;
|
leftMarginLength = (starLengthMinus2 - LineSize) / 2;
|
||||||
if( LineSize % 2 == 0 ) {
|
if (LineSize % 2 == 0)
|
||||||
rightMarginLength = leftMarginLength;
|
rightMarginLength = leftMarginLength;
|
||||||
} else {
|
else
|
||||||
rightMarginLength = leftMarginLength + 1;
|
rightMarginLength = leftMarginLength + 1;
|
||||||
}
|
memset(leftMargin, ' ', leftMarginLength);
|
||||||
memset( leftMargin, ' ', leftMarginLength );
|
memset(rightMargin, ' ', rightMarginLength);
|
||||||
memset( rightMargin, ' ', rightMarginLength );
|
|
||||||
leftMargin[leftMarginLength] = 0;
|
leftMargin[leftMarginLength] = 0;
|
||||||
rightMargin[rightMarginLength] = 0;
|
rightMargin[rightMarginLength] = 0;
|
||||||
fprintf( fd, "*%s%s%s*\n", leftMargin, line, rightMargin );
|
fprintf(fd, "*%s%s%s*\n", leftMargin, line, rightMargin);
|
||||||
}
|
}
|
||||||
fprintf(fd, "%s\n\n", stars);
|
fprintf(fd, "%s\n\n", stars);
|
||||||
|
|
||||||
@@ -283,46 +245,4 @@ void UpnpDisplayBanner(
|
|||||||
free(leftMargin);
|
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 /* DEBUG */
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -55,6 +56,9 @@
|
|||||||
/*! Maximum action header buffer length. */
|
/*! Maximum action header buffer length. */
|
||||||
#define HEADER_LENGTH 2000
|
#define HEADER_LENGTH 2000
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
#define snprintf _snprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Structure to maintain a error code and string associated with the
|
* \brief Structure to maintain a error code and string associated with the
|
||||||
@@ -119,10 +123,9 @@ struct ErrorString ErrorMessages[] = {
|
|||||||
{UPNP_E_INTERNAL_ERROR, "UPNP_E_INTERNAL_ERROR"},
|
{UPNP_E_INTERNAL_ERROR, "UPNP_E_INTERNAL_ERROR"},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
const char *UpnpGetErrorMessage(int rc)
|
const char *UpnpGetErrorMessage(int rc)
|
||||||
{
|
{
|
||||||
int i;
|
size_t i;
|
||||||
|
|
||||||
for (i = 0; i < sizeof (ErrorMessages) / sizeof (ErrorMessages[0]); ++i) {
|
for (i = 0; i < sizeof (ErrorMessages) / sizeof (ErrorMessages[0]); ++i) {
|
||||||
if (rc == ErrorMessages[i].rc) {
|
if (rc == ErrorMessages[i].rc) {
|
||||||
@@ -133,7 +136,6 @@ const char *UpnpGetErrorMessage(int rc)
|
|||||||
return "Unknown error code";
|
return "Unknown error code";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \todo There is some unnecessary allocation and deallocation going on here
|
* \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
|
* because of the way resolve_rel_url() was originally written and used. In the
|
||||||
@@ -147,21 +149,39 @@ int UpnpResolveURL(
|
|||||||
int ret = UPNP_E_SUCCESS;
|
int ret = UPNP_E_SUCCESS;
|
||||||
char *tempRel = NULL;
|
char *tempRel = NULL;
|
||||||
|
|
||||||
if (RelURL == NULL) {
|
if (!RelURL) {
|
||||||
ret = UPNP_E_INVALID_PARAM;
|
ret = UPNP_E_INVALID_PARAM;
|
||||||
goto ExitFunction;
|
goto ExitFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
tempRel = resolve_rel_url((char *)BaseURL, (char *)RelURL);
|
tempRel = resolve_rel_url((char *)BaseURL, (char *)RelURL);
|
||||||
if (tempRel) {
|
if (tempRel) {
|
||||||
strcpy(AbsURL, tempRel);
|
strcpy(AbsURL, tempRel);
|
||||||
free(tempRel);
|
free(tempRel);
|
||||||
} else {
|
} else
|
||||||
ret = UPNP_E_INVALID_URL;
|
ret = UPNP_E_INVALID_URL;
|
||||||
}
|
|
||||||
|
|
||||||
ExitFunction:
|
ExitFunction:
|
||||||
return UPNP_E_SUCCESS;
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
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 ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -204,14 +224,18 @@ static int addToAction(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (response) {
|
if (response) {
|
||||||
sprintf(ActBuff,
|
rc = snprintf(ActBuff, HEADER_LENGTH,
|
||||||
"<u:%sResponse xmlns:u=\"%s\">\r\n</u:%sResponse>",
|
"<u:%sResponse xmlns:u=\"%s\">\r\n</u:%sResponse>",
|
||||||
ActionName, ServType, ActionName);
|
ActionName, ServType, ActionName);
|
||||||
} else {
|
} else {
|
||||||
sprintf(ActBuff,
|
rc = snprintf(ActBuff, HEADER_LENGTH,
|
||||||
"<u:%s xmlns:u=\"%s\">\r\n</u:%s>",
|
"<u:%s xmlns:u=\"%s\">\r\n</u:%s>",
|
||||||
ActionName, ServType, ActionName);
|
ActionName, ServType, ActionName);
|
||||||
}
|
}
|
||||||
|
if (rc < 0 || (unsigned int) rc >= HEADER_LENGTH) {
|
||||||
|
free(ActBuff);
|
||||||
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
|
}
|
||||||
|
|
||||||
rc = ixmlParseBufferEx(ActBuff, ActionDoc);
|
rc = ixmlParseBufferEx(ActBuff, ActionDoc);
|
||||||
free(ActBuff);
|
free(ActBuff);
|
||||||
@@ -266,6 +290,7 @@ static IXML_Document *makeAction(
|
|||||||
IXML_Node *node;
|
IXML_Node *node;
|
||||||
IXML_Element *Ele;
|
IXML_Element *Ele;
|
||||||
IXML_Node *Txt = NULL;
|
IXML_Node *Txt = NULL;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
if (ActionName == NULL || ServType == NULL) {
|
if (ActionName == NULL || ServType == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
@@ -277,15 +302,16 @@ static IXML_Document *makeAction(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (response) {
|
if (response) {
|
||||||
sprintf(ActBuff,
|
rc = snprintf(ActBuff, HEADER_LENGTH,
|
||||||
"<u:%sResponse xmlns:u=\"%s\">\r\n</u:%sResponse>",
|
"<u:%sResponse xmlns:u=\"%s\">\r\n</u:%sResponse>",
|
||||||
ActionName, ServType, ActionName);
|
ActionName, ServType, ActionName);
|
||||||
} else {
|
} else {
|
||||||
sprintf(ActBuff,
|
rc = snprintf(ActBuff, HEADER_LENGTH,
|
||||||
"<u:%s xmlns:u=\"%s\">\r\n</u:%s>",
|
"<u:%s xmlns:u=\"%s\">\r\n</u:%s>",
|
||||||
ActionName, ServType, ActionName);
|
ActionName, ServType, ActionName);
|
||||||
}
|
}
|
||||||
if (ixmlParseBufferEx(ActBuff, &ActionDoc) != IXML_SUCCESS) {
|
if (rc < 0 || (unsigned int) rc >= HEADER_LENGTH ||
|
||||||
|
ixmlParseBufferEx(ActBuff, &ActionDoc) != IXML_SUCCESS) {
|
||||||
free(ActBuff);
|
free(ActBuff);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@@ -296,7 +322,7 @@ static IXML_Document *makeAction(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (NumArg > 0) {
|
if (NumArg > 0) {
|
||||||
//va_start(ArgList, Arg);
|
/*va_start(ArgList, Arg); */
|
||||||
ArgName = Arg;
|
ArgName = Arg;
|
||||||
for ( ; ; ) {
|
for ( ; ; ) {
|
||||||
ArgValue = va_arg(ArgList, const char *);
|
ArgValue = va_arg(ArgList, const char *);
|
||||||
@@ -315,7 +341,7 @@ static IXML_Document *makeAction(
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//va_end(ArgList);
|
/*va_end(ArgList); */
|
||||||
}
|
}
|
||||||
|
|
||||||
return ActionDoc;
|
return ActionDoc;
|
||||||
|
|||||||
@@ -1,33 +1,33 @@
|
|||||||
///////////////////////////////////////////////////////////////////////////
|
/*******************************************************************************
|
||||||
//
|
*
|
||||||
// Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
// All rights reserved.
|
* All rights reserved.
|
||||||
//
|
*
|
||||||
// Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
// modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
//
|
*
|
||||||
// * Redistributions of source code must retain the above copyright notice,
|
* - Redistributions of source code must retain the above copyright notice,
|
||||||
// this list of conditions and the following disclaimer.
|
* this list of conditions and the following disclaimer.
|
||||||
// * Redistributions in binary form must reproduce the above copyright notice,
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
// this list of conditions and the following disclaimer in the documentation
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
// and/or other materials provided with the distribution.
|
* and/or other materials provided with the distribution.
|
||||||
// * Neither name of Intel Corporation nor the names of its contributors
|
* - Neither name of Intel Corporation nor the names of its contributors
|
||||||
// may be used to endorse or promote products derived from this software
|
* may be used to endorse or promote products derived from this software
|
||||||
// without specific prior written permission.
|
* without specific prior written permission.
|
||||||
//
|
*
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
||||||
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
||||||
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
//
|
*
|
||||||
///////////////////////////////////////////////////////////////////////////
|
******************************************************************************/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#if EXCLUDE_GENA == 0
|
#if EXCLUDE_GENA == 0
|
||||||
@@ -63,7 +63,7 @@ error_respond( IN SOCKINFO * info,
|
|||||||
int major,
|
int major,
|
||||||
minor;
|
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,
|
http_CalcResponseVersion( hmsg->major_version,
|
||||||
hmsg->minor_version, &major, &minor );
|
hmsg->minor_version, &major, &minor );
|
||||||
|
|
||||||
@@ -90,38 +90,40 @@ genaCallback( IN http_parser_t * parser,
|
|||||||
IN http_message_t * request,
|
IN http_message_t * request,
|
||||||
INOUT SOCKINFO * info )
|
INOUT SOCKINFO * info )
|
||||||
{
|
{
|
||||||
xboolean found_function = FALSE;
|
int found_function = FALSE;
|
||||||
|
|
||||||
if( request->method == HTTPMETHOD_SUBSCRIBE ) {
|
if( request->method == HTTPMETHOD_SUBSCRIBE ) {
|
||||||
#ifdef INCLUDE_DEVICE_APIS
|
#ifdef INCLUDE_DEVICE_APIS
|
||||||
found_function = TRUE;
|
found_function = TRUE;
|
||||||
if( httpmsg_find_hdr( request, HDR_NT, NULL ) == NULL ) {
|
if( httpmsg_find_hdr( request, HDR_NT, NULL ) == NULL ) {
|
||||||
// renew subscription
|
/* renew subscription */
|
||||||
gena_process_subscription_renewal_request
|
gena_process_subscription_renewal_request
|
||||||
( info, request );
|
( info, request );
|
||||||
} else {
|
} else {
|
||||||
// subscribe
|
/* subscribe */
|
||||||
gena_process_subscription_request( info, request );
|
gena_process_subscription_request( info, request );
|
||||||
}
|
}
|
||||||
UpnpPrintf( UPNP_ALL, GENA, __FILE__, __LINE__,
|
UpnpPrintf( UPNP_ALL, GENA, __FILE__, __LINE__,
|
||||||
"got subscription request\n" );
|
"got subscription request\n" );
|
||||||
} else if( request->method == HTTPMETHOD_UNSUBSCRIBE ) {
|
} else if( request->method == HTTPMETHOD_UNSUBSCRIBE ) {
|
||||||
found_function = TRUE;
|
found_function = TRUE;
|
||||||
// unsubscribe
|
/* unsubscribe */
|
||||||
gena_process_unsubscribe_request( info, request );
|
gena_process_unsubscribe_request( info, request );
|
||||||
#endif
|
#endif
|
||||||
} else if( request->method == HTTPMETHOD_NOTIFY ) {
|
} else if( request->method == HTTPMETHOD_NOTIFY ) {
|
||||||
#ifdef INCLUDE_CLIENT_APIS
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
found_function = TRUE;
|
found_function = TRUE;
|
||||||
// notify
|
/* notify */
|
||||||
gena_process_notification_event( info, request );
|
gena_process_notification_event( info, request );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !found_function ) {
|
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 );
|
error_respond( info, HTTP_NOT_IMPLEMENTED, request );
|
||||||
}
|
}
|
||||||
|
return;
|
||||||
|
parser = parser;
|
||||||
}
|
}
|
||||||
#endif // EXCLUDE_GENA
|
#endif /* EXCLUDE_GENA */
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -51,6 +52,9 @@
|
|||||||
#include "uuid.h"
|
#include "uuid.h"
|
||||||
#include "upnpapi.h"
|
#include "upnpapi.h"
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
#define snprintf _snprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
extern ithread_mutex_t GlobalClientSubscribeMutex;
|
extern ithread_mutex_t GlobalClientSubscribeMutex;
|
||||||
|
|
||||||
@@ -106,7 +110,7 @@ static void GenaAutoRenewSubscription(
|
|||||||
}
|
}
|
||||||
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, "HANDLE IS VALID");
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, "HANDLE IS VALID");
|
||||||
|
|
||||||
// make callback
|
/* make callback */
|
||||||
callback_fun = handle_info->Callback;
|
callback_fun = handle_info->Callback;
|
||||||
cookie = handle_info->Cookie;
|
cookie = handle_info->Cookie;
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
@@ -142,6 +146,8 @@ static int ScheduleGenaAutoRenew(
|
|||||||
const UpnpString *tmpSID = UpnpClientSubscription_get_SID(sub);
|
const UpnpString *tmpSID = UpnpClientSubscription_get_SID(sub);
|
||||||
const UpnpString *tmpEventURL = UpnpClientSubscription_get_EventURL(sub);
|
const UpnpString *tmpEventURL = UpnpClientSubscription_get_EventURL(sub);
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
if (TimeOut == UPNP_INFINITE) {
|
if (TimeOut == UPNP_INFINITE) {
|
||||||
return_code = GENA_SUCCESS;
|
return_code = GENA_SUCCESS;
|
||||||
goto end_function;
|
goto end_function;
|
||||||
@@ -152,6 +158,7 @@ static int ScheduleGenaAutoRenew(
|
|||||||
return_code = UPNP_E_OUTOF_MEMORY;
|
return_code = UPNP_E_OUTOF_MEMORY;
|
||||||
goto end_function;
|
goto end_function;
|
||||||
}
|
}
|
||||||
|
memset(RenewEventStruct, 0, sizeof(struct Upnp_Event_Subscribe));
|
||||||
|
|
||||||
RenewEvent = (upnp_timeout *) malloc(sizeof(upnp_timeout));
|
RenewEvent = (upnp_timeout *) malloc(sizeof(upnp_timeout));
|
||||||
if (RenewEvent == NULL) {
|
if (RenewEvent == NULL) {
|
||||||
@@ -159,15 +166,17 @@ static int ScheduleGenaAutoRenew(
|
|||||||
return_code = UPNP_E_OUTOF_MEMORY;
|
return_code = UPNP_E_OUTOF_MEMORY;
|
||||||
goto end_function;
|
goto end_function;
|
||||||
}
|
}
|
||||||
|
memset(RenewEvent, 0, sizeof(upnp_timeout));
|
||||||
|
|
||||||
// schedule expire event
|
/* schedule expire event */
|
||||||
RenewEventStruct->ErrCode = UPNP_E_SUCCESS;
|
RenewEventStruct->ErrCode = UPNP_E_SUCCESS;
|
||||||
RenewEventStruct->TimeOut = TimeOut;
|
RenewEventStruct->TimeOut = TimeOut;
|
||||||
strcpy(RenewEventStruct->Sid, UpnpString_get_String(tmpSID));
|
strncpy(RenewEventStruct->Sid, UpnpString_get_String(tmpSID),
|
||||||
|
sizeof(RenewEventStruct->Sid) - 1);
|
||||||
strncpy(RenewEventStruct->PublisherUrl,
|
strncpy(RenewEventStruct->PublisherUrl,
|
||||||
UpnpString_get_String(tmpEventURL), NAME_SIZE - 1);
|
UpnpString_get_String(tmpEventURL), NAME_SIZE - 1);
|
||||||
|
|
||||||
// RenewEvent->EventType=UPNP_EVENT_SUBSCRIPTION_EXPIRE;
|
/* RenewEvent->EventType=UPNP_EVENT_SUBSCRIPTION_EXPIRE; */
|
||||||
RenewEvent->handle = client_handle;
|
RenewEvent->handle = client_handle;
|
||||||
RenewEvent->Event = RenewEventStruct;
|
RenewEvent->Event = RenewEventStruct;
|
||||||
|
|
||||||
@@ -175,7 +184,7 @@ static int ScheduleGenaAutoRenew(
|
|||||||
TPJobSetFreeFunction(&job, (free_routine)free_upnp_timeout);
|
TPJobSetFreeFunction(&job, (free_routine)free_upnp_timeout);
|
||||||
TPJobSetPriority(&job, MED_PRIORITY);
|
TPJobSetPriority(&job, MED_PRIORITY);
|
||||||
|
|
||||||
// Schedule the job
|
/* Schedule the job */
|
||||||
return_code = TimerThreadSchedule(
|
return_code = TimerThreadSchedule(
|
||||||
&gTimerThread,
|
&gTimerThread,
|
||||||
TimeOut - AUTO_RENEW_TIME,
|
TimeOut - AUTO_RENEW_TIME,
|
||||||
@@ -215,7 +224,7 @@ static int gena_unsubscribe(
|
|||||||
uri_type dest_url;
|
uri_type dest_url;
|
||||||
membuffer request;
|
membuffer request;
|
||||||
|
|
||||||
// parse url
|
/* parse url */
|
||||||
return_code = http_FixStrUrl(
|
return_code = http_FixStrUrl(
|
||||||
UpnpString_get_String(url),
|
UpnpString_get_String(url),
|
||||||
UpnpString_get_Length(url),
|
UpnpString_get_Length(url),
|
||||||
@@ -224,7 +233,7 @@ static int gena_unsubscribe(
|
|||||||
return return_code;
|
return return_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
// make request msg
|
/* make request msg */
|
||||||
membuffer_init(&request);
|
membuffer_init(&request);
|
||||||
request.size_inc = 30;
|
request.size_inc = 30;
|
||||||
return_code = http_MakeMessage(
|
return_code = http_MakeMessage(
|
||||||
@@ -233,14 +242,14 @@ static int gena_unsubscribe(
|
|||||||
HTTPMETHOD_UNSUBSCRIBE, &dest_url,
|
HTTPMETHOD_UNSUBSCRIBE, &dest_url,
|
||||||
"SID: ", UpnpString_get_String(sid));
|
"SID: ", UpnpString_get_String(sid));
|
||||||
|
|
||||||
// Not able to make the message so destroy the existing buffer
|
/* Not able to make the message so destroy the existing buffer */
|
||||||
if (return_code != 0) {
|
if (return_code != 0) {
|
||||||
membuffer_destroy(&request);
|
membuffer_destroy(&request);
|
||||||
|
|
||||||
return return_code;
|
return return_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
// send request and get reply
|
/* send request and get reply */
|
||||||
return_code = http_RequestAndResponse(
|
return_code = http_RequestAndResponse(
|
||||||
&dest_url, request.buf, request.length,
|
&dest_url, request.buf, request.length,
|
||||||
HTTPMETHOD_UNSUBSCRIBE, HTTP_DEFAULT_TIMEOUT, response);
|
HTTPMETHOD_UNSUBSCRIBE, HTTP_DEFAULT_TIMEOUT, response);
|
||||||
@@ -283,22 +292,27 @@ static int gena_subscribe(
|
|||||||
membuffer request;
|
membuffer request;
|
||||||
uri_type dest_url;
|
uri_type dest_url;
|
||||||
http_parser_t response;
|
http_parser_t response;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
UpnpString_clear(sid);
|
UpnpString_clear(sid);
|
||||||
|
|
||||||
// request timeout to string
|
/* request timeout to string */
|
||||||
if (timeout == NULL) {
|
if (timeout == NULL) {
|
||||||
timeout = &local_timeout;
|
timeout = &local_timeout;
|
||||||
}
|
}
|
||||||
if (*timeout < 0) {
|
if (*timeout < 0) {
|
||||||
strcpy(timeout_str, "infinite");
|
memset(timeout_str, 0, sizeof(timeout_str));
|
||||||
|
strncpy(timeout_str, "infinite", sizeof(timeout_str) - 1);
|
||||||
} else if(*timeout < CP_MINIMUM_SUBSCRIPTION_TIME) {
|
} else if(*timeout < CP_MINIMUM_SUBSCRIPTION_TIME) {
|
||||||
sprintf(timeout_str, "%d", CP_MINIMUM_SUBSCRIPTION_TIME);
|
rc = snprintf(timeout_str, sizeof(timeout_str),
|
||||||
|
"%d", CP_MINIMUM_SUBSCRIPTION_TIME);
|
||||||
} else {
|
} else {
|
||||||
sprintf(timeout_str, "%d", *timeout);
|
rc = snprintf(timeout_str, sizeof(timeout_str), "%d", *timeout);
|
||||||
}
|
}
|
||||||
|
if (rc < 0 || (unsigned int) rc >= sizeof(timeout_str))
|
||||||
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
|
|
||||||
// parse url
|
/* parse url */
|
||||||
return_code = http_FixStrUrl(
|
return_code = http_FixStrUrl(
|
||||||
UpnpString_get_String(url),
|
UpnpString_get_String(url),
|
||||||
UpnpString_get_Length(url),
|
UpnpString_get_Length(url),
|
||||||
@@ -307,11 +321,11 @@ static int gena_subscribe(
|
|||||||
return return_code;
|
return return_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
// make request msg
|
/* make request msg */
|
||||||
membuffer_init(&request);
|
membuffer_init(&request);
|
||||||
request.size_inc = 30;
|
request.size_inc = 30;
|
||||||
if (renewal_sid) {
|
if (renewal_sid) {
|
||||||
// renew subscription
|
/* renew subscription */
|
||||||
return_code = http_MakeMessage(
|
return_code = http_MakeMessage(
|
||||||
&request, 1, 1,
|
&request, 1, 1,
|
||||||
"q" "ssc" "sscc",
|
"q" "ssc" "sscc",
|
||||||
@@ -319,7 +333,7 @@ static int gena_subscribe(
|
|||||||
"SID: ", UpnpString_get_String(renewal_sid),
|
"SID: ", UpnpString_get_String(renewal_sid),
|
||||||
"TIMEOUT: Second-", timeout_str );
|
"TIMEOUT: Second-", timeout_str );
|
||||||
} else {
|
} else {
|
||||||
// subscribe
|
/* subscribe */
|
||||||
if (dest_url.hostport.IPaddress.ss_family == AF_INET6) {
|
if (dest_url.hostport.IPaddress.ss_family == AF_INET6) {
|
||||||
struct sockaddr_in6* DestAddr6 = (struct sockaddr_in6*)&dest_url.hostport.IPaddress;
|
struct sockaddr_in6* DestAddr6 = (struct sockaddr_in6*)&dest_url.hostport.IPaddress;
|
||||||
return_code = http_MakeMessage(
|
return_code = http_MakeMessage(
|
||||||
@@ -346,7 +360,7 @@ static int gena_subscribe(
|
|||||||
return return_code;
|
return return_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
// send request and get reply
|
/* send request and get reply */
|
||||||
return_code = http_RequestAndResponse(&dest_url, request.buf,
|
return_code = http_RequestAndResponse(&dest_url, request.buf,
|
||||||
request.length,
|
request.length,
|
||||||
HTTPMETHOD_SUBSCRIBE,
|
HTTPMETHOD_SUBSCRIBE,
|
||||||
@@ -365,7 +379,7 @@ static int gena_subscribe(
|
|||||||
return UPNP_E_SUBSCRIBE_UNACCEPTED;
|
return UPNP_E_SUBSCRIBE_UNACCEPTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get SID and TIMEOUT
|
/* get SID and TIMEOUT */
|
||||||
if (httpmsg_find_hdr(&response.msg, HDR_SID, &sid_hdr) == NULL ||
|
if (httpmsg_find_hdr(&response.msg, HDR_SID, &sid_hdr) == NULL ||
|
||||||
sid_hdr.length == 0 ||
|
sid_hdr.length == 0 ||
|
||||||
httpmsg_find_hdr( &response.msg, HDR_TIMEOUT, &timeout_hdr ) == NULL ||
|
httpmsg_find_hdr( &response.msg, HDR_TIMEOUT, &timeout_hdr ) == NULL ||
|
||||||
@@ -375,10 +389,10 @@ static int gena_subscribe(
|
|||||||
return UPNP_E_BAD_RESPONSE;
|
return UPNP_E_BAD_RESPONSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// save timeout
|
/* save timeout */
|
||||||
parse_ret = matchstr(timeout_hdr.buf, timeout_hdr.length, "%iSecond-%d%0", timeout);
|
parse_ret = matchstr(timeout_hdr.buf, timeout_hdr.length, "%iSecond-%d%0", timeout);
|
||||||
if (parse_ret == PARSE_OK) {
|
if (parse_ret == PARSE_OK) {
|
||||||
// nothing to do
|
/* nothing to do */
|
||||||
} else if (memptr_cmp_nocase(&timeout_hdr, "Second-infinite") == 0) {
|
} else if (memptr_cmp_nocase(&timeout_hdr, "Second-infinite") == 0) {
|
||||||
*timeout = -1;
|
*timeout = -1;
|
||||||
} else {
|
} else {
|
||||||
@@ -387,7 +401,7 @@ static int gena_subscribe(
|
|||||||
return UPNP_E_BAD_RESPONSE;
|
return UPNP_E_BAD_RESPONSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// save SID
|
/* save SID */
|
||||||
UpnpString_set_StringN(sid, sid_hdr.buf, sid_hdr.length);
|
UpnpString_set_StringN(sid, sid_hdr.buf, sid_hdr.length);
|
||||||
if (UpnpString_get_String(sid) == NULL) {
|
if (UpnpString_get_String(sid) == NULL) {
|
||||||
httpmsg_destroy(&response.msg);
|
httpmsg_destroy(&response.msg);
|
||||||
@@ -456,7 +470,7 @@ int genaUnSubscribe(
|
|||||||
ClientSubscription *sub_copy = UpnpClientSubscription_new();
|
ClientSubscription *sub_copy = UpnpClientSubscription_new();
|
||||||
http_parser_t response;
|
http_parser_t response;
|
||||||
|
|
||||||
// validate handle and sid
|
/* validate handle and sid */
|
||||||
HandleLock();
|
HandleLock();
|
||||||
if (GetHandleInfo(client_handle, &handle_info) != HND_CLIENT) {
|
if (GetHandleInfo(client_handle, &handle_info) != HND_CLIENT) {
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
@@ -512,21 +526,25 @@ int genaSubscribe(
|
|||||||
UpnpString *ActualSID = UpnpString_new();
|
UpnpString *ActualSID = UpnpString_new();
|
||||||
UpnpString *EventURL = UpnpString_new();
|
UpnpString *EventURL = UpnpString_new();
|
||||||
struct Handle_Info *handle_info;
|
struct Handle_Info *handle_info;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
|
memset(temp_sid, 0, sizeof(temp_sid));
|
||||||
|
memset(temp_sid2, 0, sizeof(temp_sid2));
|
||||||
|
|
||||||
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, "GENA SUBSCRIBE BEGIN");
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, "GENA SUBSCRIBE BEGIN");
|
||||||
|
|
||||||
UpnpString_clear(out_sid);
|
UpnpString_clear(out_sid);
|
||||||
|
|
||||||
HandleReadLock();
|
HandleReadLock();
|
||||||
// validate handle
|
/* validate handle */
|
||||||
if (GetHandleInfo(client_handle, &handle_info) != HND_CLIENT) {
|
if (GetHandleInfo(client_handle, &handle_info) != HND_CLIENT) {
|
||||||
HandleUnlock();
|
return_code = GENA_E_BAD_HANDLE;
|
||||||
|
SubscribeLock();
|
||||||
return GENA_E_BAD_HANDLE;
|
goto error_handler;
|
||||||
}
|
}
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
|
|
||||||
// subscribe
|
/* subscribe */
|
||||||
SubscribeLock();
|
SubscribeLock();
|
||||||
return_code = gena_subscribe(PublisherURL, TimeOut, NULL, ActualSID);
|
return_code = gena_subscribe(PublisherURL, TimeOut, NULL, ActualSID);
|
||||||
HandleLock();
|
HandleLock();
|
||||||
@@ -542,16 +560,20 @@ int genaSubscribe(
|
|||||||
goto error_handler;
|
goto error_handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
// generate client SID
|
/* generate client SID */
|
||||||
uuid_create(&uid );
|
uuid_create(&uid );
|
||||||
uuid_unpack(&uid, temp_sid);
|
uuid_unpack(&uid, temp_sid);
|
||||||
sprintf(temp_sid2, "uuid:%s", temp_sid);
|
rc = snprintf(temp_sid2, sizeof(temp_sid2), "uuid:%s", temp_sid);
|
||||||
|
if (rc < 0 || (unsigned int) rc >= sizeof(temp_sid2)) {
|
||||||
|
return_code = UPNP_E_OUTOF_MEMORY;
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
UpnpString_set_String(out_sid, temp_sid2);
|
UpnpString_set_String(out_sid, temp_sid2);
|
||||||
|
|
||||||
// create event url
|
/* create event url */
|
||||||
UpnpString_assign(EventURL, PublisherURL);
|
UpnpString_assign(EventURL, PublisherURL);
|
||||||
|
|
||||||
// fill subscription
|
/* fill subscription */
|
||||||
if (newSubscription == NULL) {
|
if (newSubscription == NULL) {
|
||||||
return_code = UPNP_E_OUTOF_MEMORY;
|
return_code = UPNP_E_OUTOF_MEMORY;
|
||||||
goto error_handler;
|
goto error_handler;
|
||||||
@@ -563,15 +585,14 @@ int genaSubscribe(
|
|||||||
UpnpClientSubscription_set_Next(newSubscription, handle_info->ClientSubList);
|
UpnpClientSubscription_set_Next(newSubscription, handle_info->ClientSubList);
|
||||||
handle_info->ClientSubList = newSubscription;
|
handle_info->ClientSubList = newSubscription;
|
||||||
|
|
||||||
// schedule expiration event
|
/* schedule expiration event */
|
||||||
return_code = ScheduleGenaAutoRenew(client_handle, *TimeOut, newSubscription);
|
return_code = ScheduleGenaAutoRenew(client_handle, *TimeOut, newSubscription);
|
||||||
|
|
||||||
error_handler:
|
error_handler:
|
||||||
if (return_code != UPNP_E_SUCCESS) {
|
|
||||||
UpnpString_delete(ActualSID);
|
UpnpString_delete(ActualSID);
|
||||||
UpnpString_delete(EventURL);
|
UpnpString_delete(EventURL);
|
||||||
|
if (return_code != UPNP_E_SUCCESS)
|
||||||
UpnpClientSubscription_delete(newSubscription);
|
UpnpClientSubscription_delete(newSubscription);
|
||||||
}
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
SubscribeUnlock();
|
SubscribeUnlock();
|
||||||
|
|
||||||
@@ -594,7 +615,7 @@ int genaRenewSubscription(
|
|||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
// validate handle and sid
|
/* validate handle and sid */
|
||||||
if (GetHandleInfo(client_handle, &handle_info) != HND_CLIENT) {
|
if (GetHandleInfo(client_handle, &handle_info) != HND_CLIENT) {
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
|
|
||||||
@@ -610,7 +631,7 @@ int genaRenewSubscription(
|
|||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// remove old events
|
/* remove old events */
|
||||||
if (TimerThreadRemove(
|
if (TimerThreadRemove(
|
||||||
&gTimerThread,
|
&gTimerThread,
|
||||||
UpnpClientSubscription_get_RenewEventId(sub),
|
UpnpClientSubscription_get_RenewEventId(sub),
|
||||||
@@ -639,17 +660,17 @@ int genaRenewSubscription(
|
|||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// we just called GetHandleInfo, so we don't check for return value
|
/* we just called GetHandleInfo, so we don't check for return value */
|
||||||
//GetHandleInfo(client_handle, &handle_info);
|
/*GetHandleInfo(client_handle, &handle_info); */
|
||||||
if (return_code != UPNP_E_SUCCESS) {
|
if (return_code != UPNP_E_SUCCESS) {
|
||||||
// network failure (remove client sub)
|
/* network failure (remove client sub) */
|
||||||
RemoveClientSubClientSID(&handle_info->ClientSubList, in_sid);
|
RemoveClientSubClientSID(&handle_info->ClientSubList, in_sid);
|
||||||
free_client_subscription(sub_copy);
|
free_client_subscription(sub_copy);
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get subscription
|
/* get subscription */
|
||||||
sub = GetClientSubClientSID(handle_info->ClientSubList, in_sid);
|
sub = GetClientSubClientSID(handle_info->ClientSubList, in_sid);
|
||||||
if (sub == NULL) {
|
if (sub == NULL) {
|
||||||
free_client_subscription(sub_copy);
|
free_client_subscription(sub_copy);
|
||||||
@@ -658,10 +679,10 @@ int genaRenewSubscription(
|
|||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// store actual sid
|
/* store actual sid */
|
||||||
UpnpClientSubscription_set_ActualSID(sub, ActualSID);
|
UpnpClientSubscription_set_ActualSID(sub, ActualSID);
|
||||||
|
|
||||||
// start renew subscription timer
|
/* start renew subscription timer */
|
||||||
return_code = ScheduleGenaAutoRenew(client_handle, *TimeOut, sub);
|
return_code = ScheduleGenaAutoRenew(client_handle, *TimeOut, sub);
|
||||||
if (return_code != GENA_SUCCESS) {
|
if (return_code != GENA_SUCCESS) {
|
||||||
RemoveClientSubClientSID(
|
RemoveClientSubClientSID(
|
||||||
@@ -698,7 +719,7 @@ void gena_process_notification_event(
|
|||||||
nts_hdr;
|
nts_hdr;
|
||||||
memptr seq_hdr;
|
memptr seq_hdr;
|
||||||
|
|
||||||
// get SID
|
/* get SID */
|
||||||
if (httpmsg_find_hdr(event, HDR_SID, &sid_hdr) == NULL) {
|
if (httpmsg_find_hdr(event, HDR_SID, &sid_hdr) == NULL) {
|
||||||
error_respond(info, HTTP_PRECONDITION_FAILED, event);
|
error_respond(info, HTTP_PRECONDITION_FAILED, event);
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
@@ -706,28 +727,28 @@ void gena_process_notification_event(
|
|||||||
sid.buff = sid_hdr.buf;
|
sid.buff = sid_hdr.buf;
|
||||||
sid.size = sid_hdr.length;
|
sid.size = sid_hdr.length;
|
||||||
|
|
||||||
// get event key
|
/* get event key */
|
||||||
if (httpmsg_find_hdr(event, HDR_SEQ, &seq_hdr) == NULL ||
|
if (httpmsg_find_hdr(event, HDR_SEQ, &seq_hdr) == NULL ||
|
||||||
matchstr(seq_hdr.buf, seq_hdr.length, "%d%0", &eventKey) != PARSE_OK) {
|
matchstr(seq_hdr.buf, seq_hdr.length, "%d%0", &eventKey) != PARSE_OK) {
|
||||||
error_respond( info, HTTP_BAD_REQUEST, event );
|
error_respond( info, HTTP_BAD_REQUEST, event );
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get NT and NTS headers
|
/* get NT and NTS headers */
|
||||||
if (httpmsg_find_hdr(event, HDR_NT, &nt_hdr) == NULL ||
|
if (httpmsg_find_hdr(event, HDR_NT, &nt_hdr) == NULL ||
|
||||||
httpmsg_find_hdr(event, HDR_NTS, &nts_hdr) == NULL) {
|
httpmsg_find_hdr(event, HDR_NTS, &nts_hdr) == NULL) {
|
||||||
error_respond( info, HTTP_BAD_REQUEST, event );
|
error_respond( info, HTTP_BAD_REQUEST, event );
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// verify NT and NTS headers
|
/* verify NT and NTS headers */
|
||||||
if (memptr_cmp(&nt_hdr, "upnp:event") != 0 ||
|
if (memptr_cmp(&nt_hdr, "upnp:event") != 0 ||
|
||||||
memptr_cmp(&nts_hdr, "upnp:propchange") != 0) {
|
memptr_cmp(&nts_hdr, "upnp:propchange") != 0) {
|
||||||
error_respond(info, HTTP_PRECONDITION_FAILED, event);
|
error_respond(info, HTTP_PRECONDITION_FAILED, event);
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// parse the content (should be XML)
|
/* parse the content (should be XML) */
|
||||||
if (!has_xml_content_type(event) ||
|
if (!has_xml_content_type(event) ||
|
||||||
event->msg.length == 0 ||
|
event->msg.length == 0 ||
|
||||||
ixmlParseBufferEx(event->entity.buf, &ChangedVars) != IXML_SUCCESS) {
|
ixmlParseBufferEx(event->entity.buf, &ChangedVars) != IXML_SUCCESS) {
|
||||||
@@ -737,28 +758,28 @@ void gena_process_notification_event(
|
|||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
// get client info
|
/* get client info */
|
||||||
if (GetClientHandleInfo(&client_handle, &handle_info) != HND_CLIENT) {
|
if (GetClientHandleInfo(&client_handle, &handle_info) != HND_CLIENT) {
|
||||||
error_respond(info, HTTP_PRECONDITION_FAILED, event);
|
error_respond(info, HTTP_PRECONDITION_FAILED, event);
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get subscription based on SID
|
/* get subscription based on SID */
|
||||||
subscription = GetClientSubActualSID(handle_info->ClientSubList, &sid);
|
subscription = GetClientSubActualSID(handle_info->ClientSubList, &sid);
|
||||||
if (subscription == NULL) {
|
if (subscription == NULL) {
|
||||||
if (eventKey == 0) {
|
if (eventKey == 0) {
|
||||||
// wait until we've finished processing a subscription
|
/* wait until we've finished processing a subscription */
|
||||||
// (if we are in the middle)
|
/* (if we are in the middle) */
|
||||||
// this is to avoid mistakenly rejecting the first event if we
|
/* this is to avoid mistakenly rejecting the first event if we */
|
||||||
// receive it before the subscription response
|
/* receive it before the subscription response */
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
|
|
||||||
// try and get Subscription Lock
|
/* try and get Subscription Lock */
|
||||||
// (in case we are in the process of subscribing)
|
/* (in case we are in the process of subscribing) */
|
||||||
SubscribeLock();
|
SubscribeLock();
|
||||||
|
|
||||||
// get HandleLock again
|
/* get HandleLock again */
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
if (GetClientHandleInfo(&client_handle, &handle_info) != HND_CLIENT) {
|
if (GetClientHandleInfo(&client_handle, &handle_info) != HND_CLIENT) {
|
||||||
@@ -784,25 +805,27 @@ void gena_process_notification_event(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// success
|
/* success */
|
||||||
error_respond(info, HTTP_OK, event);
|
error_respond(info, HTTP_OK, event);
|
||||||
|
|
||||||
// fill event struct
|
/* fill event struct */
|
||||||
tmpSID = UpnpClientSubscription_get_SID(subscription);
|
tmpSID = UpnpClientSubscription_get_SID(subscription);
|
||||||
strcpy(event_struct.Sid, UpnpString_get_String(tmpSID));
|
memset(event_struct.Sid, 0, sizeof(event_struct.Sid));
|
||||||
|
strncpy(event_struct.Sid, UpnpString_get_String(tmpSID),
|
||||||
|
sizeof(event_struct.Sid) - 1);
|
||||||
event_struct.EventKey = eventKey;
|
event_struct.EventKey = eventKey;
|
||||||
event_struct.ChangedVariables = ChangedVars;
|
event_struct.ChangedVariables = ChangedVars;
|
||||||
|
|
||||||
// copy callback
|
/* copy callback */
|
||||||
callback = handle_info->Callback;
|
callback = handle_info->Callback;
|
||||||
cookie = handle_info->Cookie;
|
cookie = handle_info->Cookie;
|
||||||
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
|
|
||||||
// make callback with event struct
|
/* make callback with event struct */
|
||||||
// In future, should find a way of mainting
|
/* In future, should find a way of mainting */
|
||||||
// that the handle is not unregistered in the middle of a
|
/* that the handle is not unregistered in the middle of a */
|
||||||
// callback
|
/* callback */
|
||||||
callback(UPNP_EVENT_RECEIVED, &event_struct, cookie);
|
callback(UPNP_EVENT_RECEIVED, &event_struct, cookie);
|
||||||
|
|
||||||
exit_function:
|
exit_function:
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,19 +30,15 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
|
|
||||||
#if EXCLUDE_GENA == 0
|
#if EXCLUDE_GENA == 0
|
||||||
#ifdef INCLUDE_DEVICE_APIS
|
#ifdef INCLUDE_DEVICE_APIS
|
||||||
|
|
||||||
|
|
||||||
#include "gena.h"
|
#include "gena.h"
|
||||||
#include "httpparser.h"
|
#include "httpparser.h"
|
||||||
#include "httpreadwrite.h"
|
#include "httpreadwrite.h"
|
||||||
@@ -53,6 +50,9 @@
|
|||||||
#include "upnpapi.h"
|
#include "upnpapi.h"
|
||||||
#include "uuid.h"
|
#include "uuid.h"
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
#define snprintf _snprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Unregisters a device.
|
* \brief Unregisters a device.
|
||||||
@@ -81,7 +81,6 @@ int genaUnregisterDevice(
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Generates XML property set for notifications.
|
* \brief Generates XML property set for notifications.
|
||||||
*
|
*
|
||||||
@@ -102,7 +101,7 @@ static int GeneratePropertySet(
|
|||||||
{
|
{
|
||||||
char *buffer;
|
char *buffer;
|
||||||
int counter = 0;
|
int counter = 0;
|
||||||
int size = 0;
|
size_t size = 0;
|
||||||
int temp_counter = 0;
|
int temp_counter = 0;
|
||||||
|
|
||||||
/*size += strlen(XML_VERSION);*/
|
/*size += strlen(XML_VERSION);*/
|
||||||
@@ -116,9 +115,8 @@ static int GeneratePropertySet(
|
|||||||
}
|
}
|
||||||
|
|
||||||
buffer = (char *)malloc(size + 1);
|
buffer = (char *)malloc(size + 1);
|
||||||
if (buffer == NULL) {
|
if (buffer == NULL)
|
||||||
return UPNP_E_OUTOF_MEMORY;
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
}
|
|
||||||
memset(buffer, 0, size + 1);
|
memset(buffer, 0, size + 1);
|
||||||
/*
|
/*
|
||||||
strcpy(buffer,XML_VERSION);
|
strcpy(buffer,XML_VERSION);
|
||||||
@@ -140,7 +138,6 @@ static int GeneratePropertySet(
|
|||||||
return XML_SUCCESS;
|
return XML_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Frees memory used in notify_threads if the reference count is 0,
|
* \brief Frees memory used in notify_threads if the reference count is 0,
|
||||||
* otherwise decrements the refrence count.
|
* otherwise decrements the refrence count.
|
||||||
@@ -160,7 +157,6 @@ static void free_notify_struct(
|
|||||||
free(input);
|
free(input);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Sends the notify message and returns a reply.
|
* \brief Sends the notify message and returns a reply.
|
||||||
*
|
*
|
||||||
@@ -179,12 +175,13 @@ static UPNP_INLINE int notify_send_and_recv(
|
|||||||
http_parser_t *response)
|
http_parser_t *response)
|
||||||
{
|
{
|
||||||
uri_type url;
|
uri_type url;
|
||||||
int conn_fd;
|
SOCKET conn_fd;
|
||||||
membuffer start_msg;
|
membuffer start_msg;
|
||||||
int ret_code;
|
int ret_code;
|
||||||
int err_code;
|
int err_code;
|
||||||
int timeout;
|
int timeout;
|
||||||
SOCKINFO info;
|
SOCKINFO info;
|
||||||
|
const char *CRLF = "\r\n";
|
||||||
|
|
||||||
/* connect */
|
/* connect */
|
||||||
UpnpPrintf(UPNP_ALL, GENA, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_ALL, GENA, __FILE__, __LINE__,
|
||||||
@@ -193,16 +190,12 @@ static UPNP_INLINE int notify_send_and_recv(
|
|||||||
destination_url->hostport.text.buff);
|
destination_url->hostport.text.buff);
|
||||||
|
|
||||||
conn_fd = http_Connect(destination_url, &url);
|
conn_fd = http_Connect(destination_url, &url);
|
||||||
if (conn_fd < 0) {
|
if (conn_fd < 0)
|
||||||
/* return UPNP error */
|
/* return UPNP error */
|
||||||
|
return UPNP_E_SOCKET_CONNECT;
|
||||||
return conn_fd;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret_code = sock_init(&info, conn_fd);
|
ret_code = sock_init(&info, conn_fd);
|
||||||
if (ret_code) {
|
if (ret_code) {
|
||||||
sock_destroy(&info, SD_BOTH);
|
sock_destroy(&info, SD_BOTH);
|
||||||
|
|
||||||
return ret_code;
|
return ret_code;
|
||||||
}
|
}
|
||||||
/* make start line and HOST header */
|
/* make start line and HOST header */
|
||||||
@@ -214,35 +207,29 @@ static UPNP_INLINE int notify_send_and_recv(
|
|||||||
mid_msg->buf) != 0) {
|
mid_msg->buf) != 0) {
|
||||||
membuffer_destroy(&start_msg);
|
membuffer_destroy(&start_msg);
|
||||||
sock_destroy(&info, SD_BOTH);
|
sock_destroy(&info, SD_BOTH);
|
||||||
|
|
||||||
return UPNP_E_OUTOF_MEMORY;
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
}
|
}
|
||||||
|
timeout = GENA_NOTIFICATION_SENDING_TIMEOUT;
|
||||||
timeout = HTTP_DEFAULT_TIMEOUT;
|
|
||||||
|
|
||||||
/* send msg (note: end of notification will contain "\r\n" twice) */
|
/* send msg (note: end of notification will contain "\r\n" twice) */
|
||||||
ret_code = http_SendMessage(&info, &timeout,
|
ret_code = http_SendMessage(&info, &timeout,
|
||||||
"bbb",
|
"bbb",
|
||||||
start_msg.buf, start_msg.length,
|
start_msg.buf, start_msg.length,
|
||||||
propertySet, strlen(propertySet),
|
propertySet, strlen(propertySet),
|
||||||
"\r\n", 2);
|
CRLF, strlen(CRLF));
|
||||||
if (ret_code) {
|
if (ret_code) {
|
||||||
membuffer_destroy(&start_msg);
|
membuffer_destroy(&start_msg);
|
||||||
sock_destroy(&info, SD_BOTH);
|
sock_destroy(&info, SD_BOTH);
|
||||||
|
|
||||||
return ret_code;
|
return ret_code;
|
||||||
}
|
}
|
||||||
|
timeout = GENA_NOTIFICATION_ANSWERING_TIMEOUT;
|
||||||
ret_code = http_RecvMessage(&info, response,
|
ret_code = http_RecvMessage(&info, response,
|
||||||
HTTPMETHOD_NOTIFY, &timeout, &err_code);
|
HTTPMETHOD_NOTIFY, &timeout, &err_code);
|
||||||
if (ret_code) {
|
if (ret_code) {
|
||||||
membuffer_destroy(&start_msg);
|
membuffer_destroy(&start_msg);
|
||||||
sock_destroy(&info, SD_BOTH);
|
sock_destroy(&info, SD_BOTH);
|
||||||
httpmsg_destroy(&response->msg);
|
httpmsg_destroy(&response->msg);
|
||||||
|
|
||||||
return ret_code;
|
return ret_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* should shutdown completely when closing socket */
|
/* should shutdown completely when closing socket */
|
||||||
sock_destroy(&info, SD_BOTH);
|
sock_destroy(&info, SD_BOTH);
|
||||||
membuffer_destroy(&start_msg);
|
membuffer_destroy(&start_msg);
|
||||||
@@ -250,7 +237,6 @@ static UPNP_INLINE int notify_send_and_recv(
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Function to Notify a particular subscription of a particular event.
|
* \brief Function to Notify a particular subscription of a particular event.
|
||||||
*
|
*
|
||||||
@@ -270,52 +256,44 @@ static int genaNotify(
|
|||||||
/*! [in] subscription to be Notified, assumes this is valid for life of function. */
|
/*! [in] subscription to be Notified, assumes this is valid for life of function. */
|
||||||
subscription *sub)
|
subscription *sub)
|
||||||
{
|
{
|
||||||
int i;
|
size_t i;
|
||||||
membuffer mid_msg;
|
membuffer mid_msg;
|
||||||
membuffer endmsg;
|
membuffer endmsg;
|
||||||
uri_type *url;
|
uri_type *url;
|
||||||
http_parser_t response;
|
http_parser_t response;
|
||||||
int return_code = -1;
|
int return_code = -1;
|
||||||
|
|
||||||
membuffer_init( &mid_msg );
|
membuffer_init(&mid_msg);
|
||||||
|
/* make 'end' msg (the part that won't vary with the destination) */
|
||||||
// make 'end' msg (the part that won't vary with the destination)
|
|
||||||
endmsg.size_inc = 30;
|
endmsg.size_inc = 30;
|
||||||
if( http_MakeMessage(
|
if (http_MakeMessage(&mid_msg, 1, 1,
|
||||||
&mid_msg, 1, 1,
|
|
||||||
"s" "ssc" "sdcc",
|
"s" "ssc" "sdcc",
|
||||||
headers,
|
headers,
|
||||||
"SID: ", sub->sid,
|
"SID: ", sub->sid,
|
||||||
"SEQ: ", sub->ToSendEventKey ) != 0 ) {
|
"SEQ: ", sub->ToSendEventKey) != 0) {
|
||||||
membuffer_destroy( &mid_msg );
|
membuffer_destroy(&mid_msg);
|
||||||
return UPNP_E_OUTOF_MEMORY;
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
}
|
}
|
||||||
// send a notify to each url until one goes thru
|
/* send a notify to each url until one goes thru */
|
||||||
for( i = 0; i < sub->DeliveryURLs.size; i++ ) {
|
for (i = 0; i < sub->DeliveryURLs.size; i++) {
|
||||||
url = &sub->DeliveryURLs.parsedURLs[i];
|
url = &sub->DeliveryURLs.parsedURLs[i];
|
||||||
|
return_code = notify_send_and_recv(
|
||||||
if( ( return_code = notify_send_and_recv( url,
|
url, &mid_msg, propertySet, &response);
|
||||||
&mid_msg, propertySet,
|
if (return_code == UPNP_E_SUCCESS)
|
||||||
&response ) ) ==
|
|
||||||
UPNP_E_SUCCESS ) {
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
membuffer_destroy(&mid_msg);
|
||||||
|
if (return_code == UPNP_E_SUCCESS) {
|
||||||
membuffer_destroy( &mid_msg );
|
if (response.msg.status_code == HTTP_OK)
|
||||||
|
|
||||||
if( return_code == UPNP_E_SUCCESS ) {
|
|
||||||
if( response.msg.status_code == HTTP_OK ) {
|
|
||||||
return_code = GENA_SUCCESS;
|
return_code = GENA_SUCCESS;
|
||||||
} else {
|
else {
|
||||||
if( response.msg.status_code == HTTP_PRECONDITION_FAILED ) {
|
if (response.msg.status_code == HTTP_PRECONDITION_FAILED)
|
||||||
//Invalid SID gets removed
|
/*Invalid SID gets removed */
|
||||||
return_code = GENA_E_NOTIFY_UNACCEPTED_REMOVE_SUB;
|
return_code = GENA_E_NOTIFY_UNACCEPTED_REMOVE_SUB;
|
||||||
} else {
|
else
|
||||||
return_code = GENA_E_NOTIFY_UNACCEPTED;
|
return_code = GENA_E_NOTIFY_UNACCEPTED;
|
||||||
}
|
}
|
||||||
}
|
httpmsg_destroy(&response.msg);
|
||||||
httpmsg_destroy( &response.msg );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return return_code;
|
return return_code;
|
||||||
@@ -337,51 +315,47 @@ static void genaNotifyThread(
|
|||||||
subscription *sub;
|
subscription *sub;
|
||||||
service_info *service;
|
service_info *service;
|
||||||
subscription sub_copy;
|
subscription sub_copy;
|
||||||
notify_thread_struct *in = ( notify_thread_struct * ) input;
|
notify_thread_struct *in = (notify_thread_struct *) input;
|
||||||
int return_code;
|
int return_code;
|
||||||
struct Handle_Info *handle_info;
|
struct Handle_Info *handle_info;
|
||||||
ThreadPoolJob job;
|
ThreadPoolJob job;
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
/* This should be a HandleLock and not a HandleReadLock otherwise if there
|
/* This should be a HandleLock and not a HandleReadLock otherwise if there
|
||||||
* is a lot of notifications, then multiple threads will acquire a read
|
* is a lot of notifications, then multiple threads will acquire a read
|
||||||
* lock and the thread which sends the notification will be blocked forever
|
* lock and the thread which sends the notification will be blocked forever
|
||||||
* on the HandleLock at the end of this function. */
|
* on the HandleLock at the end of this function. */
|
||||||
//HandleReadLock();
|
/*HandleReadLock(); */
|
||||||
HandleLock();
|
HandleLock();
|
||||||
//validate context
|
/* validate context */
|
||||||
|
|
||||||
if( GetHandleInfo( in->device_handle, &handle_info ) != HND_DEVICE ) {
|
if (GetHandleInfo(in->device_handle, &handle_info) != HND_DEVICE) {
|
||||||
free_notify_struct( in );
|
free_notify_struct(in);
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( ( ( service = FindServiceId( &handle_info->ServiceTable,
|
if (!(service = FindServiceId(&handle_info->ServiceTable, in->servId, in->UDN)) ||
|
||||||
in->servId, in->UDN ) ) == NULL )
|
!service->active ||
|
||||||
|| ( !service->active )
|
!(sub = GetSubscriptionSID(in->sid, service)) ||
|
||||||
|| ( ( sub = GetSubscriptionSID( in->sid, service ) ) == NULL )
|
copy_subscription(sub, &sub_copy) != HTTP_SUCCESS) {
|
||||||
|| ( ( copy_subscription( sub, &sub_copy ) != HTTP_SUCCESS ) ) ) {
|
free_notify_struct(in);
|
||||||
free_notify_struct( in );
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef UPNP_ENABLE_NOTIFICATION_REORDERING
|
#ifdef UPNP_ENABLE_NOTIFICATION_REORDERING
|
||||||
//If the event is out of order push it back to the job queue
|
/*If the event is out of order push it back to the job queue */
|
||||||
if( in->eventKey != sub->ToSendEventKey ) {
|
if (in->eventKey != sub->ToSendEventKey) {
|
||||||
|
TPJobInit(&job, (start_routine) genaNotifyThread, input);
|
||||||
TPJobInit( &job, ( start_routine ) genaNotifyThread, input );
|
TPJobSetFreeFunction(&job, (free_function) free_notify_struct);
|
||||||
TPJobSetFreeFunction( &job, ( free_function ) free_notify_struct );
|
TPJobSetPriority(&job, MED_PRIORITY);
|
||||||
TPJobSetPriority( &job, MED_PRIORITY );
|
|
||||||
|
|
||||||
/* Sleep a little before creating another thread otherwise if there is
|
/* Sleep a little before creating another thread otherwise if there is
|
||||||
* a lot of notifications to send, the device will take 100% of the CPU
|
* a lot of notifications to send, the device will take 100% of the CPU
|
||||||
* to create threads and push them back to the job queue. */
|
* to create threads and push them back to the job queue. */
|
||||||
imillisleep( 1 );
|
imillisleep(1);
|
||||||
|
ThreadPoolAdd(&gSendThreadPool, &job, NULL);
|
||||||
ThreadPoolAdd( &gSendThreadPool, &job, NULL );
|
freeSubscription(&sub_copy);
|
||||||
|
|
||||||
freeSubscription( &sub_copy );
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -389,38 +363,31 @@ static void genaNotifyThread(
|
|||||||
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
|
|
||||||
//send the notify
|
/* send the notify */
|
||||||
return_code = genaNotify( in->headers, in->propertySet, &sub_copy );
|
return_code = genaNotify(in->headers, in->propertySet, &sub_copy);
|
||||||
|
freeSubscription(&sub_copy);
|
||||||
freeSubscription( &sub_copy );
|
|
||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
if (GetHandleInfo(in->device_handle, &handle_info) != HND_DEVICE) {
|
||||||
if( GetHandleInfo( in->device_handle, &handle_info ) != HND_DEVICE ) {
|
free_notify_struct(in);
|
||||||
free_notify_struct( in );
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//validate context
|
/* validate context */
|
||||||
if( ( ( service = FindServiceId( &handle_info->ServiceTable,
|
if (!(service = FindServiceId(&handle_info->ServiceTable, in->servId, in->UDN)) ||
|
||||||
in->servId, in->UDN ) ) == NULL )
|
!service->active ||
|
||||||
|| ( !service->active )
|
!(sub = GetSubscriptionSID(in->sid, service))) {
|
||||||
|| ( ( sub = GetSubscriptionSID( in->sid, service ) ) == NULL ) ) {
|
free_notify_struct(in);
|
||||||
free_notify_struct( in );
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub->ToSendEventKey++;
|
sub->ToSendEventKey++;
|
||||||
|
if (sub->ToSendEventKey < 0)
|
||||||
if( sub->ToSendEventKey < 0 ) //wrap to 1 for overflow
|
/* wrap to 1 for overflow */
|
||||||
sub->ToSendEventKey = 1;
|
sub->ToSendEventKey = 1;
|
||||||
|
if (return_code == GENA_E_NOTIFY_UNACCEPTED_REMOVE_SUB)
|
||||||
|
RemoveSubscriptionSID(in->sid, service);
|
||||||
|
free_notify_struct(in);
|
||||||
|
|
||||||
if( return_code == GENA_E_NOTIFY_UNACCEPTED_REMOVE_SUB ) {
|
|
||||||
RemoveSubscriptionSID( in->sid, service );
|
|
||||||
}
|
|
||||||
|
|
||||||
free_notify_struct( in );
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -448,8 +415,9 @@ static char *AllocGenaHeaders(
|
|||||||
static const char *HEADER_LINE_4 =
|
static const char *HEADER_LINE_4 =
|
||||||
"NTS: upnp:propchange\r\n";
|
"NTS: upnp:propchange\r\n";
|
||||||
char *headers = NULL;
|
char *headers = NULL;
|
||||||
int headers_size = 0;
|
size_t headers_size = 0;
|
||||||
int line = 0;
|
int line = 0;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
headers_size =
|
headers_size =
|
||||||
strlen(HEADER_LINE_1 ) +
|
strlen(HEADER_LINE_1 ) +
|
||||||
@@ -462,7 +430,7 @@ static char *AllocGenaHeaders(
|
|||||||
line = __LINE__;
|
line = __LINE__;
|
||||||
goto ExitFunction;
|
goto ExitFunction;
|
||||||
}
|
}
|
||||||
sprintf(headers, "%s%s%"PRIzu"%s%s%s",
|
rc = snprintf(headers, headers_size, "%s%s%"PRIzu"%s%s%s",
|
||||||
HEADER_LINE_1,
|
HEADER_LINE_1,
|
||||||
HEADER_LINE_2A,
|
HEADER_LINE_2A,
|
||||||
strlen(propertySet) + 1,
|
strlen(propertySet) + 1,
|
||||||
@@ -471,7 +439,7 @@ static char *AllocGenaHeaders(
|
|||||||
HEADER_LINE_4);
|
HEADER_LINE_4);
|
||||||
|
|
||||||
ExitFunction:
|
ExitFunction:
|
||||||
if (headers == NULL) {
|
if (headers == NULL || rc < 0 || (unsigned int) rc >= headers_size) {
|
||||||
UpnpPrintf(UPNP_ALL, GENA, __FILE__, line,
|
UpnpPrintf(UPNP_ALL, GENA, __FILE__, line,
|
||||||
"AllocGenaHeaders(): Error UPNP_E_OUTOF_MEMORY\n");
|
"AllocGenaHeaders(): Error UPNP_E_OUTOF_MEMORY\n");
|
||||||
}
|
}
|
||||||
@@ -503,6 +471,8 @@ int genaInitNotify(
|
|||||||
struct Handle_Info *handle_info;
|
struct Handle_Info *handle_info;
|
||||||
ThreadPoolJob job;
|
ThreadPoolJob job;
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
||||||
"GENA BEGIN INITIAL NOTIFY");
|
"GENA BEGIN INITIAL NOTIFY");
|
||||||
|
|
||||||
@@ -528,8 +498,10 @@ int genaInitNotify(
|
|||||||
goto ExitFunction;
|
goto ExitFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(UDN_copy, UDN);
|
memset(UDN_copy, 0, strlen(UDN) + 1);
|
||||||
strcpy(servId_copy, servId);
|
strncpy(UDN_copy, UDN, strlen(UDN));
|
||||||
|
memset(servId_copy, 0, strlen(servId) + 1);
|
||||||
|
strncpy(servId_copy, servId, strlen(servId));
|
||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
@@ -593,7 +565,9 @@ int genaInitNotify(
|
|||||||
thread_struct->UDN = UDN_copy;
|
thread_struct->UDN = UDN_copy;
|
||||||
thread_struct->headers = headers;
|
thread_struct->headers = headers;
|
||||||
thread_struct->propertySet = propertySet;
|
thread_struct->propertySet = propertySet;
|
||||||
strcpy(thread_struct->sid, sid);
|
memset(thread_struct->sid, 0, sizeof(thread_struct->sid));
|
||||||
|
strncpy(thread_struct->sid, sid,
|
||||||
|
sizeof(thread_struct->sid) - 1);
|
||||||
thread_struct->eventKey = sub->eventKey++;
|
thread_struct->eventKey = sub->eventKey++;
|
||||||
thread_struct->reference_count = reference_count;
|
thread_struct->reference_count = reference_count;
|
||||||
thread_struct->device_handle = device_handle;
|
thread_struct->device_handle = device_handle;
|
||||||
@@ -656,6 +630,8 @@ int genaInitNotifyExt(
|
|||||||
struct Handle_Info *handle_info;
|
struct Handle_Info *handle_info;
|
||||||
ThreadPoolJob job;
|
ThreadPoolJob job;
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
||||||
"GENA BEGIN INITIAL NOTIFY EXT");
|
"GENA BEGIN INITIAL NOTIFY EXT");
|
||||||
|
|
||||||
@@ -681,8 +657,10 @@ int genaInitNotifyExt(
|
|||||||
goto ExitFunction;
|
goto ExitFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(UDN_copy, UDN);
|
memset(UDN_copy, 0, strlen(UDN) + 1);
|
||||||
strcpy(servId_copy, servId);
|
strncpy(UDN_copy, UDN, strlen(UDN));
|
||||||
|
memset(servId_copy, 0, strlen(servId) + 1);
|
||||||
|
strncpy(servId_copy, servId, strlen(servId));
|
||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
@@ -747,7 +725,9 @@ int genaInitNotifyExt(
|
|||||||
thread_struct->UDN = UDN_copy;
|
thread_struct->UDN = UDN_copy;
|
||||||
thread_struct->headers = headers;
|
thread_struct->headers = headers;
|
||||||
thread_struct->propertySet = propertySet;
|
thread_struct->propertySet = propertySet;
|
||||||
strcpy(thread_struct->sid, sid);
|
memset(thread_struct->sid, 0, sizeof(thread_struct->sid));
|
||||||
|
strncpy(thread_struct->sid, sid,
|
||||||
|
sizeof(thread_struct->sid) - 1);
|
||||||
thread_struct->eventKey = sub->eventKey++;
|
thread_struct->eventKey = sub->eventKey++;
|
||||||
thread_struct->reference_count = reference_count;
|
thread_struct->reference_count = reference_count;
|
||||||
thread_struct->device_handle = device_handle;
|
thread_struct->device_handle = device_handle;
|
||||||
@@ -809,6 +789,8 @@ int genaNotifyAllExt(
|
|||||||
struct Handle_Info *handle_info;
|
struct Handle_Info *handle_info;
|
||||||
ThreadPoolJob job;
|
ThreadPoolJob job;
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
||||||
"GENA BEGIN NOTIFY ALL EXT");
|
"GENA BEGIN NOTIFY ALL EXT");
|
||||||
|
|
||||||
@@ -834,8 +816,10 @@ int genaNotifyAllExt(
|
|||||||
goto ExitFunction;
|
goto ExitFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(UDN_copy, UDN);
|
memset(UDN_copy, 0, strlen(UDN) + 1);
|
||||||
strcpy(servId_copy, servId);
|
strncpy(UDN_copy, UDN, strlen(UDN));
|
||||||
|
memset(servId_copy, 0, strlen(servId) + 1);
|
||||||
|
strncpy(servId_copy, servId, strlen(servId));
|
||||||
|
|
||||||
propertySet = ixmlPrintNode((IXML_Node *)PropSet);
|
propertySet = ixmlPrintNode((IXML_Node *)PropSet);
|
||||||
if (propertySet == NULL) {
|
if (propertySet == NULL) {
|
||||||
@@ -877,7 +861,10 @@ int genaNotifyAllExt(
|
|||||||
thread_struct->servId = servId_copy;
|
thread_struct->servId = servId_copy;
|
||||||
thread_struct->headers = headers;
|
thread_struct->headers = headers;
|
||||||
thread_struct->propertySet = propertySet;
|
thread_struct->propertySet = propertySet;
|
||||||
strcpy(thread_struct->sid, finger->sid);
|
memset(thread_struct->sid, 0,
|
||||||
|
sizeof(thread_struct->sid));
|
||||||
|
strncpy(thread_struct->sid, finger->sid,
|
||||||
|
sizeof(thread_struct->sid) - 1);
|
||||||
thread_struct->eventKey = finger->eventKey++;
|
thread_struct->eventKey = finger->eventKey++;
|
||||||
thread_struct->device_handle = device_handle;
|
thread_struct->device_handle = device_handle;
|
||||||
/* if overflow, wrap to 1 */
|
/* if overflow, wrap to 1 */
|
||||||
@@ -948,6 +935,8 @@ int genaNotifyAll(
|
|||||||
struct Handle_Info *handle_info;
|
struct Handle_Info *handle_info;
|
||||||
ThreadPoolJob job;
|
ThreadPoolJob job;
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
||||||
"GENA BEGIN NOTIFY ALL");
|
"GENA BEGIN NOTIFY ALL");
|
||||||
|
|
||||||
@@ -973,8 +962,10 @@ int genaNotifyAll(
|
|||||||
goto ExitFunction;
|
goto ExitFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(UDN_copy, UDN);
|
memset(UDN_copy, 0, strlen(UDN) + 1);
|
||||||
strcpy(servId_copy, servId);
|
strncpy(UDN_copy, UDN, strlen(UDN));
|
||||||
|
memset(servId_copy, 0, strlen(servId) + 1);
|
||||||
|
strncpy(servId_copy, servId, strlen(servId));
|
||||||
|
|
||||||
ret = GeneratePropertySet(VarNames, VarValues, var_count, &propertySet);
|
ret = GeneratePropertySet(VarNames, VarValues, var_count, &propertySet);
|
||||||
if (ret != XML_SUCCESS) {
|
if (ret != XML_SUCCESS) {
|
||||||
@@ -1015,7 +1006,10 @@ int genaNotifyAll(
|
|||||||
thread_struct->servId = servId_copy;
|
thread_struct->servId = servId_copy;
|
||||||
thread_struct->headers = headers;
|
thread_struct->headers = headers;
|
||||||
thread_struct->propertySet = propertySet;
|
thread_struct->propertySet = propertySet;
|
||||||
strcpy(thread_struct->sid, finger->sid);
|
memset(thread_struct->sid, 0,
|
||||||
|
sizeof(thread_struct->sid));
|
||||||
|
strncpy(thread_struct->sid, finger->sid,
|
||||||
|
sizeof(thread_struct->sid) - 1);
|
||||||
thread_struct->eventKey = finger->eventKey++;
|
thread_struct->eventKey = finger->eventKey++;
|
||||||
thread_struct->device_handle = device_handle;
|
thread_struct->device_handle = device_handle;
|
||||||
/* if overflow, wrap to 1 */
|
/* if overflow, wrap to 1 */
|
||||||
@@ -1085,14 +1079,22 @@ static int respond_ok(
|
|||||||
int return_code;
|
int return_code;
|
||||||
char timeout_str[100];
|
char timeout_str[100];
|
||||||
int upnp_timeout = UPNP_TIMEOUT;
|
int upnp_timeout = UPNP_TIMEOUT;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
http_CalcResponseVersion( request->major_version,
|
http_CalcResponseVersion( request->major_version,
|
||||||
request->minor_version, &major, &minor );
|
request->minor_version, &major, &minor );
|
||||||
|
|
||||||
if( time_out >= 0 ) {
|
if( time_out >= 0 ) {
|
||||||
sprintf( timeout_str, "TIMEOUT: Second-%d", time_out );
|
rc = snprintf( timeout_str, sizeof ( timeout_str ),
|
||||||
|
"TIMEOUT: Second-%d", time_out );
|
||||||
} else {
|
} else {
|
||||||
strcpy( timeout_str, "TIMEOUT: Second-infinite" );
|
memset( timeout_str, 0, sizeof( timeout_str ) );
|
||||||
|
strncpy( timeout_str, "TIMEOUT: Second-infinite",
|
||||||
|
sizeof ( timeout_str ) - 1);
|
||||||
|
}
|
||||||
|
if (rc < 0 || (unsigned int) rc >= sizeof ( timeout_str ) ) {
|
||||||
|
error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request );
|
||||||
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
}
|
}
|
||||||
|
|
||||||
membuffer_init( &response );
|
membuffer_init( &response );
|
||||||
@@ -1135,8 +1137,8 @@ static int create_url_list(
|
|||||||
/*! [out] . */
|
/*! [out] . */
|
||||||
URL_list *out)
|
URL_list *out)
|
||||||
{
|
{
|
||||||
int URLcount = 0;
|
size_t URLcount = 0;
|
||||||
int i;
|
size_t i;
|
||||||
int return_code = 0;
|
int return_code = 0;
|
||||||
uri_type temp;
|
uri_type temp;
|
||||||
token urls;
|
token urls;
|
||||||
@@ -1166,12 +1168,11 @@ static int create_url_list(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if( URLcount > 0 ) {
|
if( URLcount > 0 ) {
|
||||||
out->URLs = ( char * )malloc( URLS->size + 1 );
|
out->URLs = malloc(URLS->size + 1);
|
||||||
out->parsedURLs =
|
out->parsedURLs = malloc(sizeof(uri_type) * URLcount);
|
||||||
( uri_type * ) malloc( sizeof( uri_type ) * URLcount );
|
if (!out->URLs || !out->parsedURLs) {
|
||||||
if( ( out->URLs == NULL ) || ( out->parsedURLs == NULL ) ) {
|
free(out->URLs);
|
||||||
free( out->URLs );
|
free(out->parsedURLs);
|
||||||
free( out->parsedURLs );
|
|
||||||
out->URLs = NULL;
|
out->URLs = NULL;
|
||||||
out->parsedURLs = NULL;
|
out->parsedURLs = NULL;
|
||||||
return UPNP_E_OUTOF_MEMORY;
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
@@ -1202,7 +1203,7 @@ static int create_url_list(
|
|||||||
}
|
}
|
||||||
out->size = URLcount;
|
out->size = URLcount;
|
||||||
|
|
||||||
return URLcount;
|
return (int)URLcount;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -1225,6 +1226,9 @@ void gena_process_subscription_request(
|
|||||||
char *event_url_path = NULL;
|
char *event_url_path = NULL;
|
||||||
memptr callback_hdr;
|
memptr callback_hdr;
|
||||||
memptr timeout_hdr;
|
memptr timeout_hdr;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
|
memset(&request_struct, 0, sizeof(request_struct));
|
||||||
|
|
||||||
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__,
|
||||||
"Subscription Request Received:\n");
|
"Subscription Request Received:\n");
|
||||||
@@ -1234,20 +1238,20 @@ void gena_process_subscription_request(
|
|||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// check NT header
|
/* check NT header */
|
||||||
// Windows Millenium Interoperability:
|
/* Windows Millenium Interoperability: */
|
||||||
// we accept either upnp:event, or upnp:propchange for the NT header
|
/* we accept either upnp:event, or upnp:propchange for the NT header */
|
||||||
if (memptr_cmp_nocase(&nt_hdr, "upnp:event") != 0) {
|
if (memptr_cmp_nocase(&nt_hdr, "upnp:event") != 0) {
|
||||||
error_respond(info, HTTP_PRECONDITION_FAILED, request);
|
error_respond(info, HTTP_PRECONDITION_FAILED, request);
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if a SID is present then the we have a bad request "incompatible headers"
|
/* if a SID is present then the we have a bad request "incompatible headers" */
|
||||||
if (httpmsg_find_hdr(request, HDR_SID, NULL) != NULL) {
|
if (httpmsg_find_hdr(request, HDR_SID, NULL) != NULL) {
|
||||||
error_respond(info, HTTP_BAD_REQUEST, request);
|
error_respond(info, HTTP_BAD_REQUEST, request);
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
// look up service by eventURL
|
/* look up service by eventURL */
|
||||||
event_url_path = str_alloc(request->uri.pathquery.buff, request->uri.pathquery.size);
|
event_url_path = str_alloc(request->uri.pathquery.buff, request->uri.pathquery.size);
|
||||||
if (event_url_path == NULL) {
|
if (event_url_path == NULL) {
|
||||||
error_respond(info, HTTP_INTERNAL_SERVER_ERROR, request);
|
error_respond(info, HTTP_INTERNAL_SERVER_ERROR, request);
|
||||||
@@ -1260,7 +1264,7 @@ void gena_process_subscription_request(
|
|||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
// CURRENTLY, ONLY ONE DEVICE
|
/* CURRENTLY, ONLY ONE DEVICE */
|
||||||
if (GetDeviceHandleInfo(info->foreign_sockaddr.ss_family ,
|
if (GetDeviceHandleInfo(info->foreign_sockaddr.ss_family ,
|
||||||
&device_handle, &handle_info) != HND_DEVICE) {
|
&device_handle, &handle_info) != HND_DEVICE) {
|
||||||
free(event_url_path);
|
free(event_url_path);
|
||||||
@@ -1283,14 +1287,14 @@ void gena_process_subscription_request(
|
|||||||
service->TotalSubscriptions,
|
service->TotalSubscriptions,
|
||||||
handle_info->MaxSubscriptions);
|
handle_info->MaxSubscriptions);
|
||||||
|
|
||||||
// too many subscriptions
|
/* too many subscriptions */
|
||||||
if (handle_info->MaxSubscriptions != -1 &&
|
if (handle_info->MaxSubscriptions != -1 &&
|
||||||
service->TotalSubscriptions >= handle_info->MaxSubscriptions) {
|
service->TotalSubscriptions >= handle_info->MaxSubscriptions) {
|
||||||
error_respond(info, HTTP_INTERNAL_SERVER_ERROR, request);
|
error_respond(info, HTTP_INTERNAL_SERVER_ERROR, request);
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
// generate new subscription
|
/* generate new subscription */
|
||||||
sub = (subscription *)malloc(sizeof (subscription));
|
sub = (subscription *)malloc(sizeof (subscription));
|
||||||
if (sub == NULL) {
|
if (sub == NULL) {
|
||||||
error_respond(info, HTTP_INTERNAL_SERVER_ERROR, request);
|
error_respond(info, HTTP_INTERNAL_SERVER_ERROR, request);
|
||||||
@@ -1305,7 +1309,7 @@ void gena_process_subscription_request(
|
|||||||
sub->DeliveryURLs.URLs = NULL;
|
sub->DeliveryURLs.URLs = NULL;
|
||||||
sub->DeliveryURLs.parsedURLs = NULL;
|
sub->DeliveryURLs.parsedURLs = NULL;
|
||||||
|
|
||||||
// check for valid callbacks
|
/* check for valid callbacks */
|
||||||
if (httpmsg_find_hdr( request, HDR_CALLBACK, &callback_hdr) == NULL) {
|
if (httpmsg_find_hdr( request, HDR_CALLBACK, &callback_hdr) == NULL) {
|
||||||
error_respond(info, HTTP_PRECONDITION_FAILED, request);
|
error_respond(info, HTTP_PRECONDITION_FAILED, request);
|
||||||
freeSubscriptionList(sub);
|
freeSubscriptionList(sub);
|
||||||
@@ -1325,20 +1329,20 @@ void gena_process_subscription_request(
|
|||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
// set the timeout
|
/* set the timeout */
|
||||||
if (httpmsg_find_hdr(request, HDR_TIMEOUT, &timeout_hdr) != NULL) {
|
if (httpmsg_find_hdr(request, HDR_TIMEOUT, &timeout_hdr) != NULL) {
|
||||||
if (matchstr(timeout_hdr.buf, timeout_hdr.length,
|
if (matchstr(timeout_hdr.buf, timeout_hdr.length,
|
||||||
"%iSecond-%d%0", &time_out) == PARSE_OK) {
|
"%iSecond-%d%0", &time_out) == PARSE_OK) {
|
||||||
// nothing
|
/* nothing */
|
||||||
} else if(memptr_cmp_nocase(&timeout_hdr, "Second-infinite") == 0) {
|
} else if(memptr_cmp_nocase(&timeout_hdr, "Second-infinite") == 0) {
|
||||||
// infinite timeout
|
/* infinite timeout */
|
||||||
time_out = -1;
|
time_out = -1;
|
||||||
} else {
|
} else {
|
||||||
// default is > 1800 seconds
|
/* default is > 1800 seconds */
|
||||||
time_out = DEFAULT_TIMEOUT;
|
time_out = DEFAULT_TIMEOUT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// replace infinite timeout with max timeout, if possible
|
/* replace infinite timeout with max timeout, if possible */
|
||||||
if (handle_info->MaxSubscriptionTimeOut != -1) {
|
if (handle_info->MaxSubscriptionTimeOut != -1) {
|
||||||
if (time_out == -1 ||
|
if (time_out == -1 ||
|
||||||
time_out > handle_info->MaxSubscriptionTimeOut) {
|
time_out > handle_info->MaxSubscriptionTimeOut) {
|
||||||
@@ -1348,40 +1352,43 @@ void gena_process_subscription_request(
|
|||||||
if (time_out >= 0) {
|
if (time_out >= 0) {
|
||||||
sub->expireTime = time(NULL) + time_out;
|
sub->expireTime = time(NULL) + time_out;
|
||||||
} else {
|
} else {
|
||||||
// infinite time
|
/* infinite time */
|
||||||
sub->expireTime = 0;
|
sub->expireTime = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// generate SID
|
/* generate SID */
|
||||||
uuid_create(&uid);
|
uuid_create(&uid);
|
||||||
uuid_unpack(&uid, temp_sid);
|
uuid_unpack(&uid, temp_sid);
|
||||||
sprintf(sub->sid, "uuid:%s", temp_sid);
|
rc = snprintf(sub->sid, sizeof(sub->sid), "uuid:%s", temp_sid);
|
||||||
|
|
||||||
// respond OK
|
/* respond OK */
|
||||||
if (respond_ok(info, time_out, sub, request) != UPNP_E_SUCCESS) {
|
if (rc < 0 || (unsigned int) rc >= sizeof(sub->sid) ||
|
||||||
|
(respond_ok(info, time_out,
|
||||||
|
sub, request) != UPNP_E_SUCCESS)) {
|
||||||
freeSubscriptionList(sub);
|
freeSubscriptionList(sub);
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
goto exit_function;
|
goto exit_function;
|
||||||
}
|
}
|
||||||
// add to subscription list
|
/* add to subscription list */
|
||||||
sub->next = service->subscriptionList;
|
sub->next = service->subscriptionList;
|
||||||
service->subscriptionList = sub;
|
service->subscriptionList = sub;
|
||||||
service->TotalSubscriptions++;
|
service->TotalSubscriptions++;
|
||||||
|
|
||||||
// finally generate callback for init table dump
|
/* finally generate callback for init table dump */
|
||||||
request_struct.ServiceId = service->serviceId;
|
request_struct.ServiceId = service->serviceId;
|
||||||
request_struct.UDN = service->UDN;
|
request_struct.UDN = service->UDN;
|
||||||
strcpy((char *)request_struct.Sid, sub->sid);
|
strncpy((char *)request_struct.Sid, sub->sid,
|
||||||
|
sizeof(request_struct.Sid) - 1);
|
||||||
|
|
||||||
// copy callback
|
/* copy callback */
|
||||||
callback_fun = handle_info->Callback;
|
callback_fun = handle_info->Callback;
|
||||||
cookie = handle_info->Cookie;
|
cookie = handle_info->Cookie;
|
||||||
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
|
|
||||||
// make call back with request struct
|
/* make call back with request struct */
|
||||||
// in the future should find a way of mainting that the handle
|
/* in the future should find a way of mainting that the handle */
|
||||||
// is not unregistered in the middle of a callback
|
/* is not unregistered in the middle of a callback */
|
||||||
callback_fun(UPNP_EVENT_SUBSCRIPTION_REQUEST, &request_struct, cookie);
|
callback_fun(UPNP_EVENT_SUBSCRIPTION_REQUEST, &request_struct, cookie);
|
||||||
|
|
||||||
exit_function:
|
exit_function:
|
||||||
@@ -1403,13 +1410,13 @@ void gena_process_subscription_renewal_request(
|
|||||||
membuffer event_url_path;
|
membuffer event_url_path;
|
||||||
memptr timeout_hdr;
|
memptr timeout_hdr;
|
||||||
|
|
||||||
// if a CALLBACK or NT header is present, then it is an error
|
/* if a CALLBACK or NT header is present, then it is an error */
|
||||||
if( httpmsg_find_hdr( request, HDR_CALLBACK, NULL ) != NULL ||
|
if( httpmsg_find_hdr( request, HDR_CALLBACK, NULL ) != NULL ||
|
||||||
httpmsg_find_hdr( request, HDR_NT, NULL ) != NULL ) {
|
httpmsg_find_hdr( request, HDR_NT, NULL ) != NULL ) {
|
||||||
error_respond( info, HTTP_BAD_REQUEST, request );
|
error_respond( info, HTTP_BAD_REQUEST, request );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// get SID
|
/* get SID */
|
||||||
if( httpmsg_find_hdr( request, HDR_SID, &temp_hdr ) == NULL ||
|
if( httpmsg_find_hdr( request, HDR_SID, &temp_hdr ) == NULL ||
|
||||||
temp_hdr.length > SID_SIZE ) {
|
temp_hdr.length > SID_SIZE ) {
|
||||||
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
||||||
@@ -1418,7 +1425,7 @@ void gena_process_subscription_renewal_request(
|
|||||||
memcpy( sid, temp_hdr.buf, temp_hdr.length );
|
memcpy( sid, temp_hdr.buf, temp_hdr.length );
|
||||||
sid[temp_hdr.length] = '\0';
|
sid[temp_hdr.length] = '\0';
|
||||||
|
|
||||||
// lookup service by eventURL
|
/* lookup service by eventURL */
|
||||||
membuffer_init( &event_url_path );
|
membuffer_init( &event_url_path );
|
||||||
if( membuffer_append( &event_url_path, request->uri.pathquery.buff,
|
if( membuffer_append( &event_url_path, request->uri.pathquery.buff,
|
||||||
request->uri.pathquery.size ) != 0 ) {
|
request->uri.pathquery.size ) != 0 ) {
|
||||||
@@ -1428,7 +1435,7 @@ void gena_process_subscription_renewal_request(
|
|||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
// CURRENTLY, ONLY SUPPORT ONE DEVICE
|
/* CURRENTLY, ONLY SUPPORT ONE DEVICE */
|
||||||
if( GetDeviceHandleInfo( info->foreign_sockaddr.ss_family,
|
if( GetDeviceHandleInfo( info->foreign_sockaddr.ss_family,
|
||||||
&device_handle, &handle_info ) != HND_DEVICE ) {
|
&device_handle, &handle_info ) != HND_DEVICE ) {
|
||||||
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
||||||
@@ -1440,7 +1447,7 @@ void gena_process_subscription_renewal_request(
|
|||||||
event_url_path.buf );
|
event_url_path.buf );
|
||||||
membuffer_destroy( &event_url_path );
|
membuffer_destroy( &event_url_path );
|
||||||
|
|
||||||
// get subscription
|
/* get subscription */
|
||||||
if( service == NULL ||
|
if( service == NULL ||
|
||||||
!service->active ||
|
!service->active ||
|
||||||
( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) ) {
|
( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) ) {
|
||||||
@@ -1454,7 +1461,7 @@ void gena_process_subscription_renewal_request(
|
|||||||
"Max Subscriptions allowed:%d\n",
|
"Max Subscriptions allowed:%d\n",
|
||||||
service->TotalSubscriptions,
|
service->TotalSubscriptions,
|
||||||
handle_info->MaxSubscriptions );
|
handle_info->MaxSubscriptions );
|
||||||
// too many subscriptions
|
/* too many subscriptions */
|
||||||
if( handle_info->MaxSubscriptions != -1 &&
|
if( handle_info->MaxSubscriptions != -1 &&
|
||||||
service->TotalSubscriptions > handle_info->MaxSubscriptions ) {
|
service->TotalSubscriptions > handle_info->MaxSubscriptions ) {
|
||||||
error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request );
|
error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request );
|
||||||
@@ -1462,25 +1469,25 @@ void gena_process_subscription_renewal_request(
|
|||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// set the timeout
|
/* set the timeout */
|
||||||
if( httpmsg_find_hdr( request, HDR_TIMEOUT, &timeout_hdr ) != NULL ) {
|
if( httpmsg_find_hdr( request, HDR_TIMEOUT, &timeout_hdr ) != NULL ) {
|
||||||
if( matchstr( timeout_hdr.buf, timeout_hdr.length,
|
if( matchstr( timeout_hdr.buf, timeout_hdr.length,
|
||||||
"%iSecond-%d%0", &time_out ) == PARSE_OK ) {
|
"%iSecond-%d%0", &time_out ) == PARSE_OK ) {
|
||||||
|
|
||||||
//nothing
|
/*nothing */
|
||||||
|
|
||||||
} else if( memptr_cmp_nocase( &timeout_hdr, "Second-infinite" ) ==
|
} else if( memptr_cmp_nocase( &timeout_hdr, "Second-infinite" ) ==
|
||||||
0 ) {
|
0 ) {
|
||||||
|
|
||||||
time_out = -1; // inifinite timeout
|
time_out = -1; /* inifinite timeout */
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
time_out = DEFAULT_TIMEOUT; // default is > 1800 seconds
|
time_out = DEFAULT_TIMEOUT; /* default is > 1800 seconds */
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// replace infinite timeout with max timeout, if possible
|
/* replace infinite timeout with max timeout, if possible */
|
||||||
if( handle_info->MaxSubscriptionTimeOut != -1 ) {
|
if( handle_info->MaxSubscriptionTimeOut != -1 ) {
|
||||||
if( time_out == -1 ||
|
if( time_out == -1 ||
|
||||||
time_out > handle_info->MaxSubscriptionTimeOut ) {
|
time_out > handle_info->MaxSubscriptionTimeOut ) {
|
||||||
@@ -1514,13 +1521,13 @@ void gena_process_unsubscribe_request(
|
|||||||
memptr temp_hdr;
|
memptr temp_hdr;
|
||||||
membuffer event_url_path;
|
membuffer event_url_path;
|
||||||
|
|
||||||
// if a CALLBACK or NT header is present, then it is an error
|
/* if a CALLBACK or NT header is present, then it is an error */
|
||||||
if( httpmsg_find_hdr( request, HDR_CALLBACK, NULL ) != NULL ||
|
if( httpmsg_find_hdr( request, HDR_CALLBACK, NULL ) != NULL ||
|
||||||
httpmsg_find_hdr( request, HDR_NT, NULL ) != NULL ) {
|
httpmsg_find_hdr( request, HDR_NT, NULL ) != NULL ) {
|
||||||
error_respond( info, HTTP_BAD_REQUEST, request );
|
error_respond( info, HTTP_BAD_REQUEST, request );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// get SID
|
/* get SID */
|
||||||
if( httpmsg_find_hdr( request, HDR_SID, &temp_hdr ) == NULL ||
|
if( httpmsg_find_hdr( request, HDR_SID, &temp_hdr ) == NULL ||
|
||||||
temp_hdr.length > SID_SIZE ) {
|
temp_hdr.length > SID_SIZE ) {
|
||||||
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
||||||
@@ -1529,7 +1536,7 @@ void gena_process_unsubscribe_request(
|
|||||||
memcpy( sid, temp_hdr.buf, temp_hdr.length );
|
memcpy( sid, temp_hdr.buf, temp_hdr.length );
|
||||||
sid[temp_hdr.length] = '\0';
|
sid[temp_hdr.length] = '\0';
|
||||||
|
|
||||||
// lookup service by eventURL
|
/* lookup service by eventURL */
|
||||||
membuffer_init( &event_url_path );
|
membuffer_init( &event_url_path );
|
||||||
if( membuffer_append( &event_url_path, request->uri.pathquery.buff,
|
if( membuffer_append( &event_url_path, request->uri.pathquery.buff,
|
||||||
request->uri.pathquery.size ) != 0 ) {
|
request->uri.pathquery.size ) != 0 ) {
|
||||||
@@ -1539,7 +1546,7 @@ void gena_process_unsubscribe_request(
|
|||||||
|
|
||||||
HandleLock();
|
HandleLock();
|
||||||
|
|
||||||
// CURRENTLY, ONLY SUPPORT ONE DEVICE
|
/* CURRENTLY, ONLY SUPPORT ONE DEVICE */
|
||||||
if( GetDeviceHandleInfo( info->foreign_sockaddr.ss_family,
|
if( GetDeviceHandleInfo( info->foreign_sockaddr.ss_family,
|
||||||
&device_handle, &handle_info ) != HND_DEVICE ) {
|
&device_handle, &handle_info ) != HND_DEVICE ) {
|
||||||
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
error_respond( info, HTTP_PRECONDITION_FAILED, request );
|
||||||
@@ -1551,7 +1558,7 @@ void gena_process_unsubscribe_request(
|
|||||||
event_url_path.buf );
|
event_url_path.buf );
|
||||||
membuffer_destroy( &event_url_path );
|
membuffer_destroy( &event_url_path );
|
||||||
|
|
||||||
// validate service
|
/* validate service */
|
||||||
if( service == NULL ||
|
if( service == NULL ||
|
||||||
!service->active || GetSubscriptionSID( sid, service ) == NULL )
|
!service->active || GetSubscriptionSID( sid, service ) == NULL )
|
||||||
{
|
{
|
||||||
@@ -1561,7 +1568,7 @@ void gena_process_unsubscribe_request(
|
|||||||
}
|
}
|
||||||
|
|
||||||
RemoveSubscriptionSID(sid, service);
|
RemoveSubscriptionSID(sid, service);
|
||||||
error_respond(info, HTTP_OK, request); // success
|
error_respond(info, HTTP_OK, request); /* success */
|
||||||
|
|
||||||
HandleUnlock();
|
HandleUnlock();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -44,9 +45,9 @@
|
|||||||
|
|
||||||
|
|
||||||
#ifdef INCLUDE_CLIENT_APIS
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
|
#if EXCLUDE_GENA == 0
|
||||||
|
|
||||||
|
#include <stdlib.h> /* for calloc(), free() */
|
||||||
#include <stdlib.h> // for calloc(), free()
|
|
||||||
|
|
||||||
|
|
||||||
struct SClientSubscription {
|
struct SClientSubscription {
|
||||||
@@ -113,12 +114,12 @@ ClientSubscription *UpnpClientSubscription_dup(const ClientSubscription *p)
|
|||||||
void UpnpClientSubscription_assign(ClientSubscription *q, const ClientSubscription *p)
|
void UpnpClientSubscription_assign(ClientSubscription *q, const ClientSubscription *p)
|
||||||
{
|
{
|
||||||
if (q != p) {
|
if (q != p) {
|
||||||
// Do not copy RenewEventId
|
/* Do not copy RenewEventId */
|
||||||
((struct SClientSubscription *)q)->m_renewEventId = -1;
|
((struct SClientSubscription *)q)->m_renewEventId = -1;
|
||||||
UpnpClientSubscription_set_SID(q, UpnpClientSubscription_get_SID(p));
|
UpnpClientSubscription_set_SID(q, UpnpClientSubscription_get_SID(p));
|
||||||
UpnpClientSubscription_set_ActualSID(q, UpnpClientSubscription_get_ActualSID(p));
|
UpnpClientSubscription_set_ActualSID(q, UpnpClientSubscription_get_ActualSID(p));
|
||||||
UpnpClientSubscription_set_EventURL(q, UpnpClientSubscription_get_EventURL(p));
|
UpnpClientSubscription_set_EventURL(q, UpnpClientSubscription_get_EventURL(p));
|
||||||
// Do not copy m_next
|
/* Do not copy m_next */
|
||||||
((struct SClientSubscription *)q)->m_next = NULL;
|
((struct SClientSubscription *)q)->m_next = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -238,8 +239,8 @@ void free_client_subscription(ClientSubscription *sub)
|
|||||||
UpnpClientSubscription_strcpy_ActualSID(sub, "");
|
UpnpClientSubscription_strcpy_ActualSID(sub, "");
|
||||||
UpnpClientSubscription_strcpy_EventURL(sub, "");
|
UpnpClientSubscription_strcpy_EventURL(sub, "");
|
||||||
if (renewEventId != -1) {
|
if (renewEventId != -1) {
|
||||||
// do not remove timer event of copy
|
/* do not remove timer event of copy */
|
||||||
// invalid timer event id
|
/* invalid timer event id */
|
||||||
if (TimerThreadRemove(&gTimerThread, renewEventId, &tempJob) == 0) {
|
if (TimerThreadRemove(&gTimerThread, renewEventId, &tempJob) == 0) {
|
||||||
event = (upnp_timeout *)tempJob.arg;
|
event = (upnp_timeout *)tempJob.arg;
|
||||||
free_upnp_timeout(event);
|
free_upnp_timeout(event);
|
||||||
@@ -324,6 +325,6 @@ ClientSubscription *GetClientSubActualSID(ClientSubscription *head, token *sid)
|
|||||||
return next;
|
return next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* EXCLUDE_GENA */
|
||||||
#endif /* INCLUDE_CLIENT_APIS */
|
#endif /* INCLUDE_CLIENT_APIS */
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (C) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,9 +30,9 @@
|
|||||||
*
|
*
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
|
#if EXCLUDE_MINISERVER == 0
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
@@ -46,10 +47,8 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "miniserver.h"
|
#include "miniserver.h"
|
||||||
|
|
||||||
|
|
||||||
#include "httpreadwrite.h"
|
#include "httpreadwrite.h"
|
||||||
#include "ithread.h"
|
#include "ithread.h"
|
||||||
#include "ssdplib.h"
|
#include "ssdplib.h"
|
||||||
@@ -57,8 +56,7 @@
|
|||||||
#include "ThreadPool.h"
|
#include "ThreadPool.h"
|
||||||
#include "unixutil.h" /* for socklen_t, EAFNOSUPPORT */
|
#include "unixutil.h" /* for socklen_t, EAFNOSUPPORT */
|
||||||
#include "upnpapi.h"
|
#include "upnpapi.h"
|
||||||
#include "util.h"
|
#include "upnputil.h"
|
||||||
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
@@ -67,19 +65,16 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
|
||||||
/*! . */
|
/*! . */
|
||||||
#define APPLICATION_LISTENING_PORT 49152
|
#define APPLICATION_LISTENING_PORT 49152
|
||||||
|
|
||||||
|
|
||||||
struct mserv_request_t {
|
struct mserv_request_t {
|
||||||
/*! Connection handle. */
|
/*! Connection handle. */
|
||||||
int connfd;
|
SOCKET connfd;
|
||||||
/*! . */
|
/*! . */
|
||||||
struct sockaddr_storage foreign_sockaddr;
|
struct sockaddr_storage foreign_sockaddr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*! . */
|
/*! . */
|
||||||
typedef enum {
|
typedef enum {
|
||||||
/*! . */
|
/*! . */
|
||||||
@@ -90,10 +85,8 @@ typedef enum {
|
|||||||
MSERV_STOPPING
|
MSERV_STOPPING
|
||||||
} MiniServerState;
|
} MiniServerState;
|
||||||
|
|
||||||
|
|
||||||
/*! . */
|
/*! . */
|
||||||
unsigned short miniStopSockPort;
|
uint16_t miniStopSockPort;
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* module vars
|
* module vars
|
||||||
@@ -103,13 +96,11 @@ static MiniServerCallback gSoapCallback = NULL;
|
|||||||
static MiniServerCallback gGenaCallback = NULL;
|
static MiniServerCallback gGenaCallback = NULL;
|
||||||
static MiniServerState gMServState = MSERV_IDLE;
|
static MiniServerState gMServState = MSERV_IDLE;
|
||||||
|
|
||||||
|
|
||||||
void SetHTTPGetCallback(MiniServerCallback callback)
|
void SetHTTPGetCallback(MiniServerCallback callback)
|
||||||
{
|
{
|
||||||
gGetCallback = callback;
|
gGetCallback = callback;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef INCLUDE_DEVICE_APIS
|
#ifdef INCLUDE_DEVICE_APIS
|
||||||
void SetSoapCallback(MiniServerCallback callback)
|
void SetSoapCallback(MiniServerCallback callback)
|
||||||
{
|
{
|
||||||
@@ -122,7 +113,6 @@ void SetGenaCallback(MiniServerCallback callback)
|
|||||||
gGenaCallback = callback;
|
gGenaCallback = callback;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef INTERNAL_WEB_SERVER
|
#ifdef INTERNAL_WEB_SERVER
|
||||||
/*!
|
/*!
|
||||||
* \brief Based on the type pf message, appropriate callback is issued.
|
* \brief Based on the type pf message, appropriate callback is issued.
|
||||||
@@ -169,7 +159,6 @@ static int dispatch_request(
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Send Error Message.
|
* \brief Send Error Message.
|
||||||
*/
|
*/
|
||||||
@@ -186,7 +175,6 @@ static UPNP_INLINE void handle_error(
|
|||||||
http_SendStatusResponse(info, http_error_code, major, minor);
|
http_SendStatusResponse(info, http_error_code, major, minor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Free memory assigned for handling request and unitialize socket
|
* \brief Free memory assigned for handling request and unitialize socket
|
||||||
* functionality.
|
* functionality.
|
||||||
@@ -201,7 +189,6 @@ static void free_handle_request_arg(
|
|||||||
free(request);
|
free(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Receive the request and dispatch it for handling.
|
* \brief Receive the request and dispatch it for handling.
|
||||||
*/
|
*/
|
||||||
@@ -218,7 +205,7 @@ static void handle_request(
|
|||||||
http_message_t *hmsg = NULL;
|
http_message_t *hmsg = NULL;
|
||||||
int timeout = HTTP_DEFAULT_TIMEOUT;
|
int timeout = HTTP_DEFAULT_TIMEOUT;
|
||||||
struct mserv_request_t *request = (struct mserv_request_t *)args;
|
struct mserv_request_t *request = (struct mserv_request_t *)args;
|
||||||
int connfd = request->connfd;
|
SOCKET connfd = request->connfd;
|
||||||
|
|
||||||
UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__,
|
UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__,
|
||||||
"miniserver %d: READING\n", connfd );
|
"miniserver %d: READING\n", connfd );
|
||||||
@@ -262,20 +249,21 @@ error_handler:
|
|||||||
"miniserver %d: COMPLETE\n", connfd);
|
"miniserver %d: COMPLETE\n", connfd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Initilize the thread pool to handle a request, sets priority for the
|
* \brief Initilize the thread pool to handle a request, sets priority for the
|
||||||
* job and adds the job to the thread pool.
|
* job and adds the job to the thread pool.
|
||||||
*/
|
*/
|
||||||
static UPNP_INLINE void schedule_request_job(
|
static UPNP_INLINE void schedule_request_job(
|
||||||
/*! [in] Socket Descriptor on which connection is accepted. */
|
/*! [in] Socket Descriptor on which connection is accepted. */
|
||||||
int connfd,
|
SOCKET connfd,
|
||||||
/*! [in] Clients Address information. */
|
/*! [in] Clients Address information. */
|
||||||
struct sockaddr *clientAddr)
|
struct sockaddr *clientAddr)
|
||||||
{
|
{
|
||||||
struct mserv_request_t *request;
|
struct mserv_request_t *request;
|
||||||
ThreadPoolJob job;
|
ThreadPoolJob job;
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
request = (struct mserv_request_t *)malloc(
|
request = (struct mserv_request_t *)malloc(
|
||||||
sizeof (struct mserv_request_t));
|
sizeof (struct mserv_request_t));
|
||||||
if (request == NULL) {
|
if (request == NULL) {
|
||||||
@@ -301,26 +289,26 @@ static UPNP_INLINE void schedule_request_job(
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static inline void fdset_if_valid(int sock, fd_set *set)
|
static UPNP_INLINE void fdset_if_valid(SOCKET sock, fd_set *set)
|
||||||
{
|
{
|
||||||
if (sock != -1) {
|
if (sock != INVALID_SOCKET) {
|
||||||
FD_SET(sock, set);
|
FD_SET(sock, set);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void web_server_accept(int lsock, fd_set *set)
|
static void web_server_accept(SOCKET lsock, fd_set *set)
|
||||||
{
|
{
|
||||||
#ifdef INTERNAL_WEB_SERVER
|
#ifdef INTERNAL_WEB_SERVER
|
||||||
int asock;
|
SOCKET asock;
|
||||||
socklen_t clientLen;
|
socklen_t clientLen;
|
||||||
struct sockaddr_storage clientAddr;
|
struct sockaddr_storage clientAddr;
|
||||||
char errorBuffer[ERROR_BUFFER_LEN];
|
char errorBuffer[ERROR_BUFFER_LEN];
|
||||||
|
|
||||||
if (lsock != -1 && FD_ISSET(lsock, set)) {
|
if (lsock != INVALID_SOCKET && FD_ISSET(lsock, set)) {
|
||||||
clientLen = sizeof(clientAddr);
|
clientLen = sizeof(clientAddr);
|
||||||
asock = accept(lsock, (struct sockaddr *)&clientAddr,
|
asock = accept(lsock, (struct sockaddr *)&clientAddr,
|
||||||
&clientLen);
|
&clientLen);
|
||||||
if (asock == -1) {
|
if (asock == INVALID_SOCKET) {
|
||||||
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
||||||
"miniserver: Error in accept(): %s\n",
|
"miniserver: Error in accept(): %s\n",
|
||||||
@@ -333,20 +321,20 @@ static void web_server_accept(int lsock, fd_set *set)
|
|||||||
#endif /* INTERNAL_WEB_SERVER */
|
#endif /* INTERNAL_WEB_SERVER */
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ssdp_read(int rsock, fd_set *set)
|
static void ssdp_read(SOCKET rsock, fd_set *set)
|
||||||
{
|
{
|
||||||
if (rsock != -1 && FD_ISSET(rsock, set)) {
|
if (rsock != INVALID_SOCKET && FD_ISSET(rsock, set)) {
|
||||||
readFromSSDPSocket(rsock);
|
readFromSSDPSocket(rsock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int receive_from_stopSock(int ssock, fd_set *set)
|
static int receive_from_stopSock(SOCKET ssock, fd_set *set)
|
||||||
{
|
{
|
||||||
int byteReceived;
|
ssize_t byteReceived;
|
||||||
socklen_t clientLen;
|
socklen_t clientLen;
|
||||||
struct sockaddr_storage clientAddr;
|
struct sockaddr_storage clientAddr;
|
||||||
char requestBuf[256];
|
char requestBuf[256];
|
||||||
char buf_ntop[64];
|
char buf_ntop[INET6_ADDRSTRLEN];
|
||||||
|
|
||||||
if (FD_ISSET(ssock, set)) {
|
if (FD_ISSET(ssock, set)) {
|
||||||
clientLen = sizeof(clientAddr);
|
clientLen = sizeof(clientAddr);
|
||||||
@@ -387,9 +375,9 @@ static void RunMiniServer(
|
|||||||
char errorBuffer[ERROR_BUFFER_LEN];
|
char errorBuffer[ERROR_BUFFER_LEN];
|
||||||
fd_set expSet;
|
fd_set expSet;
|
||||||
fd_set rdSet;
|
fd_set rdSet;
|
||||||
int maxMiniSock;
|
SOCKET maxMiniSock;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
int stopSock = 0;
|
SOCKET stopSock = 0;
|
||||||
|
|
||||||
maxMiniSock = 0;
|
maxMiniSock = 0;
|
||||||
maxMiniSock = max(maxMiniSock, miniSock->miniServerSock4);
|
maxMiniSock = max(maxMiniSock, miniSock->miniServerSock4);
|
||||||
@@ -398,8 +386,10 @@ static void RunMiniServer(
|
|||||||
maxMiniSock = max(maxMiniSock, miniSock->ssdpSock4);
|
maxMiniSock = max(maxMiniSock, miniSock->ssdpSock4);
|
||||||
maxMiniSock = max(maxMiniSock, miniSock->ssdpSock6);
|
maxMiniSock = max(maxMiniSock, miniSock->ssdpSock6);
|
||||||
maxMiniSock = max(maxMiniSock, miniSock->ssdpSock6UlaGua);
|
maxMiniSock = max(maxMiniSock, miniSock->ssdpSock6UlaGua);
|
||||||
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
maxMiniSock = max(maxMiniSock, miniSock->ssdpReqSock4);
|
maxMiniSock = max(maxMiniSock, miniSock->ssdpReqSock4);
|
||||||
maxMiniSock = max(maxMiniSock, miniSock->ssdpReqSock6);
|
maxMiniSock = max(maxMiniSock, miniSock->ssdpReqSock6);
|
||||||
|
#endif /* INCLUDE_CLIENT_APIS */
|
||||||
++maxMiniSock;
|
++maxMiniSock;
|
||||||
|
|
||||||
gMServState = MSERV_RUNNING;
|
gMServState = MSERV_RUNNING;
|
||||||
@@ -414,14 +404,16 @@ static void RunMiniServer(
|
|||||||
fdset_if_valid(miniSock->ssdpSock4, &rdSet);
|
fdset_if_valid(miniSock->ssdpSock4, &rdSet);
|
||||||
fdset_if_valid(miniSock->ssdpSock6, &rdSet);
|
fdset_if_valid(miniSock->ssdpSock6, &rdSet);
|
||||||
fdset_if_valid(miniSock->ssdpSock6UlaGua, &rdSet);
|
fdset_if_valid(miniSock->ssdpSock6UlaGua, &rdSet);
|
||||||
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
fdset_if_valid(miniSock->ssdpReqSock4, &rdSet);
|
fdset_if_valid(miniSock->ssdpReqSock4, &rdSet);
|
||||||
fdset_if_valid(miniSock->ssdpReqSock6, &rdSet);
|
fdset_if_valid(miniSock->ssdpReqSock6, &rdSet);
|
||||||
|
#endif /* INCLUDE_CLIENT_APIS */
|
||||||
/* select() */
|
/* select() */
|
||||||
ret = select(maxMiniSock, &rdSet, NULL, &expSet, NULL);
|
ret = select((int) maxMiniSock, &rdSet, NULL, &expSet, NULL);
|
||||||
if (ret == -1 && errno == EINTR) {
|
if (ret == SOCKET_ERROR && errno == EINTR) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (ret == -1) {
|
if (ret == SOCKET_ERROR) {
|
||||||
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_CRITICAL, SSDP, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_CRITICAL, SSDP, __FILE__, __LINE__,
|
||||||
"Error in select(): %s\n", errorBuffer);
|
"Error in select(): %s\n", errorBuffer);
|
||||||
@@ -447,8 +439,10 @@ static void RunMiniServer(
|
|||||||
sock_close(miniSock->ssdpSock4);
|
sock_close(miniSock->ssdpSock4);
|
||||||
sock_close(miniSock->ssdpSock6);
|
sock_close(miniSock->ssdpSock6);
|
||||||
sock_close(miniSock->ssdpSock6UlaGua);
|
sock_close(miniSock->ssdpSock6UlaGua);
|
||||||
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
sock_close(miniSock->ssdpReqSock4);
|
sock_close(miniSock->ssdpReqSock4);
|
||||||
sock_close(miniSock->ssdpReqSock6);
|
sock_close(miniSock->ssdpReqSock6);
|
||||||
|
#endif /* INCLUDE_CLIENT_APIS */
|
||||||
/* Free minisock. */
|
/* Free minisock. */
|
||||||
free(miniSock);
|
free(miniSock);
|
||||||
gMServState = MSERV_IDLE;
|
gMServState = MSERV_IDLE;
|
||||||
@@ -456,20 +450,20 @@ static void RunMiniServer(
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns port to which socket, sockfd, is bound.
|
* \brief Returns port to which socket, sockfd, is bound.
|
||||||
*
|
*
|
||||||
* \return -1 on error; check errno, otherwise > 0 means port number.
|
* \return -1 on error; check errno. 0 if successfull.
|
||||||
*/
|
*/
|
||||||
static int get_port(
|
static int get_port(
|
||||||
/*! [in] Socket descriptor. */
|
/*! [in] Socket descriptor. */
|
||||||
int sockfd)
|
SOCKET sockfd,
|
||||||
|
/*! [out] The port value if successful, otherwise, untouched. */
|
||||||
|
uint16_t *port)
|
||||||
{
|
{
|
||||||
struct sockaddr_storage sockinfo;
|
struct sockaddr_storage sockinfo;
|
||||||
socklen_t len;
|
socklen_t len;
|
||||||
int code;
|
int code;
|
||||||
int port = 0;
|
|
||||||
|
|
||||||
len = sizeof(sockinfo);
|
len = sizeof(sockinfo);
|
||||||
code = getsockname(sockfd, (struct sockaddr *)&sockinfo, &len);
|
code = getsockname(sockfd, (struct sockaddr *)&sockinfo, &len);
|
||||||
@@ -477,17 +471,16 @@ static int get_port(
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (sockinfo.ss_family == AF_INET) {
|
if (sockinfo.ss_family == AF_INET) {
|
||||||
port = ntohs(((struct sockaddr_in*)&sockinfo)->sin_port);
|
*port = ntohs(((struct sockaddr_in*)&sockinfo)->sin_port);
|
||||||
} else if(sockinfo.ss_family == AF_INET6) {
|
} else if(sockinfo.ss_family == AF_INET6) {
|
||||||
port = ntohs(((struct sockaddr_in6*)&sockinfo)->sin6_port);
|
*port = ntohs(((struct sockaddr_in6*)&sockinfo)->sin6_port);
|
||||||
}
|
}
|
||||||
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
||||||
"sockfd = %d, .... port = %d\n", sockfd, port);
|
"sockfd = %d, .... port = %u\n", sockfd, *port);
|
||||||
|
|
||||||
return port;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef INTERNAL_WEB_SERVER
|
#ifdef INTERNAL_WEB_SERVER
|
||||||
/*!
|
/*!
|
||||||
* \brief Creates a STREAM socket, binds to INADDR_ANY and listens for
|
* \brief Creates a STREAM socket, binds to INADDR_ANY and listens for
|
||||||
@@ -509,21 +502,22 @@ static int get_miniserver_sockets(
|
|||||||
MiniServerSockArray *out,
|
MiniServerSockArray *out,
|
||||||
/*! [in] port on which the server is listening for incoming IPv4
|
/*! [in] port on which the server is listening for incoming IPv4
|
||||||
* connections. */
|
* connections. */
|
||||||
unsigned short listen_port4,
|
uint16_t listen_port4,
|
||||||
/*! [in] port on which the server is listening for incoming IPv6
|
/*! [in] port on which the server is listening for incoming IPv6
|
||||||
* connections. */
|
* connections. */
|
||||||
unsigned short listen_port6)
|
uint16_t listen_port6)
|
||||||
{
|
{
|
||||||
char errorBuffer[ERROR_BUFFER_LEN];
|
char errorBuffer[ERROR_BUFFER_LEN];
|
||||||
struct sockaddr_storage __ss_v4;
|
struct sockaddr_storage __ss_v4;
|
||||||
struct sockaddr_in* serverAddr4 = (struct sockaddr_in*)&__ss_v4;
|
struct sockaddr_in* serverAddr4 = (struct sockaddr_in*)&__ss_v4;
|
||||||
SOCKET listenfd4;
|
SOCKET listenfd4;
|
||||||
unsigned short actual_port4;
|
uint16_t actual_port4;
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
struct sockaddr_storage __ss_v6;
|
struct sockaddr_storage __ss_v6;
|
||||||
struct sockaddr_in6* serverAddr6 = (struct sockaddr_in6*)&__ss_v6;
|
struct sockaddr_in6* serverAddr6 = (struct sockaddr_in6*)&__ss_v6;
|
||||||
SOCKET listenfd6;
|
SOCKET listenfd6;
|
||||||
unsigned short actual_port6;
|
uint16_t actual_port6;
|
||||||
|
int onOff;
|
||||||
#endif
|
#endif
|
||||||
int ret_code;
|
int ret_code;
|
||||||
int reuseaddr_on = 0;
|
int reuseaddr_on = 0;
|
||||||
@@ -533,14 +527,23 @@ static int get_miniserver_sockets(
|
|||||||
/* Create listen socket for IPv4/IPv6. An error here may indicate
|
/* Create listen socket for IPv4/IPv6. An error here may indicate
|
||||||
* that we don't have an IPv4/IPv6 stack. */
|
* that we don't have an IPv4/IPv6 stack. */
|
||||||
listenfd4 = socket(AF_INET, SOCK_STREAM, 0);
|
listenfd4 = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
if (listenfd4 == -1) {
|
if (listenfd4 == INVALID_SOCKET) {
|
||||||
return UPNP_E_OUTOF_SOCKET;
|
return UPNP_E_OUTOF_SOCKET;
|
||||||
}
|
}
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
listenfd6 = socket(AF_INET6, SOCK_STREAM, 0);
|
listenfd6 = socket(AF_INET6, SOCK_STREAM, 0);
|
||||||
if (listenfd6 == -1) {
|
if (listenfd6 == INVALID_SOCKET) {
|
||||||
|
sock_close(listenfd4);
|
||||||
return UPNP_E_OUTOF_SOCKET;
|
return UPNP_E_OUTOF_SOCKET;
|
||||||
}
|
}
|
||||||
|
onOff = 1;
|
||||||
|
sockError = setsockopt(listenfd6, IPPROTO_IPV6, IPV6_V6ONLY,
|
||||||
|
(char *)&onOff, sizeof(onOff));
|
||||||
|
if (sockError == SOCKET_ERROR) {
|
||||||
|
sock_close(listenfd4);
|
||||||
|
sock_close(listenfd6);
|
||||||
|
return UPNP_E_SOCKET_BIND;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
/* As per the IANA specifications for the use of ports by applications
|
/* As per the IANA specifications for the use of ports by applications
|
||||||
* override the listen port passed in with the first available. */
|
* override the listen port passed in with the first available. */
|
||||||
@@ -572,11 +575,11 @@ static int get_miniserver_sockets(
|
|||||||
* HOWEVER IT HAS BEEN SUGESTED FOR TCP SERVERS. */
|
* HOWEVER IT HAS BEEN SUGESTED FOR TCP SERVERS. */
|
||||||
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
||||||
"get_miniserver_sockets: resuseaddr is set.\n");
|
"get_miniserver_sockets: resuseaddr is set.\n");
|
||||||
if (listenfd4 != -1) {
|
if (listenfd4 != INVALID_SOCKET) {
|
||||||
sockError = setsockopt(listenfd4, SOL_SOCKET,
|
sockError = setsockopt(listenfd4, SOL_SOCKET,
|
||||||
SO_REUSEADDR,
|
SO_REUSEADDR,
|
||||||
(const char *)&reuseaddr_on, sizeof (int));
|
(const char *)&reuseaddr_on, sizeof (int));
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
sock_close(listenfd4);
|
sock_close(listenfd4);
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
sock_close(listenfd6);
|
sock_close(listenfd6);
|
||||||
@@ -587,7 +590,7 @@ static int get_miniserver_sockets(
|
|||||||
sockError = bind(listenfd4,
|
sockError = bind(listenfd4,
|
||||||
(struct sockaddr *)&__ss_v4,
|
(struct sockaddr *)&__ss_v4,
|
||||||
sizeof (__ss_v4));
|
sizeof (__ss_v4));
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
strerror_r(errno, errorBuffer,
|
strerror_r(errno, errorBuffer,
|
||||||
ERROR_BUFFER_LEN);
|
ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, MSERV,
|
UpnpPrintf(UPNP_INFO, MSERV,
|
||||||
@@ -604,11 +607,11 @@ static int get_miniserver_sockets(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
if (listenfd6 != -1) {
|
if (listenfd6 != INVALID_SOCKET) {
|
||||||
sockError = setsockopt(listenfd6, SOL_SOCKET,
|
sockError = setsockopt(listenfd6, SOL_SOCKET,
|
||||||
SO_REUSEADDR,
|
SO_REUSEADDR,
|
||||||
(const char *)&reuseaddr_on, sizeof (int));
|
(const char *)&reuseaddr_on, sizeof (int));
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
sock_close(listenfd4);
|
sock_close(listenfd4);
|
||||||
sock_close(listenfd6);
|
sock_close(listenfd6);
|
||||||
return UPNP_E_SOCKET_BIND;
|
return UPNP_E_SOCKET_BIND;
|
||||||
@@ -617,7 +620,7 @@ static int get_miniserver_sockets(
|
|||||||
sockError = bind(listenfd6,
|
sockError = bind(listenfd6,
|
||||||
(struct sockaddr *)&__ss_v6,
|
(struct sockaddr *)&__ss_v6,
|
||||||
sizeof (__ss_v6));
|
sizeof (__ss_v6));
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
strerror_r(errno, errorBuffer,
|
strerror_r(errno, errorBuffer,
|
||||||
ERROR_BUFFER_LEN);
|
ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, MSERV,
|
UpnpPrintf(UPNP_INFO, MSERV,
|
||||||
@@ -633,14 +636,14 @@ static int get_miniserver_sockets(
|
|||||||
}
|
}
|
||||||
#endif /* IPv6 */
|
#endif /* IPv6 */
|
||||||
} else {
|
} else {
|
||||||
if (listenfd4 != -1) {
|
if (listenfd4 != INVALID_SOCKET) {
|
||||||
unsigned short orig_listen_port4 = listen_port4;
|
uint16_t orig_listen_port4 = listen_port4;
|
||||||
do {
|
do {
|
||||||
serverAddr4->sin_port = htons(listen_port4++);
|
serverAddr4->sin_port = htons(listen_port4++);
|
||||||
sockError = bind(listenfd4,
|
sockError = bind(listenfd4,
|
||||||
(struct sockaddr *)serverAddr4,
|
(struct sockaddr *)serverAddr4,
|
||||||
sizeof(*serverAddr4));
|
sizeof(*serverAddr4));
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
errCode = WSAGetLastError();
|
errCode = WSAGetLastError();
|
||||||
#else
|
#else
|
||||||
@@ -654,7 +657,7 @@ static int get_miniserver_sockets(
|
|||||||
}
|
}
|
||||||
} while (errCode != 0 &&
|
} while (errCode != 0 &&
|
||||||
listen_port4 >= orig_listen_port4);
|
listen_port4 >= orig_listen_port4);
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
strerror_r(errno, errorBuffer,
|
strerror_r(errno, errorBuffer,
|
||||||
ERROR_BUFFER_LEN);
|
ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, MSERV,
|
UpnpPrintf(UPNP_INFO, MSERV,
|
||||||
@@ -671,14 +674,14 @@ static int get_miniserver_sockets(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
if (listenfd6 != -1) {
|
if (listenfd6 != INVALID_SOCKET) {
|
||||||
unsigned short orig_listen_port6 = listen_port6;
|
uint16_t orig_listen_port6 = listen_port6;
|
||||||
do {
|
do {
|
||||||
serverAddr6->sin6_port = htons(listen_port6++);
|
serverAddr6->sin6_port = htons(listen_port6++);
|
||||||
sockError = bind(listenfd6,
|
sockError = bind(listenfd6,
|
||||||
(struct sockaddr *)serverAddr6,
|
(struct sockaddr *)serverAddr6,
|
||||||
sizeof(*serverAddr6));
|
sizeof(*serverAddr6));
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
errCode = WSAGetLastError();
|
errCode = WSAGetLastError();
|
||||||
#else
|
#else
|
||||||
@@ -692,7 +695,7 @@ static int get_miniserver_sockets(
|
|||||||
}
|
}
|
||||||
} while (errCode != 0 &&
|
} while (errCode != 0 &&
|
||||||
listen_port6 >= orig_listen_port6);
|
listen_port6 >= orig_listen_port6);
|
||||||
if (sockError == -1) {
|
if (sockError == SOCKET_ERROR) {
|
||||||
strerror_r(errno, errorBuffer,
|
strerror_r(errno, errorBuffer,
|
||||||
ERROR_BUFFER_LEN);
|
ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, MSERV,
|
UpnpPrintf(UPNP_INFO, MSERV,
|
||||||
@@ -710,9 +713,9 @@ static int get_miniserver_sockets(
|
|||||||
}
|
}
|
||||||
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
||||||
"get_miniserver_sockets: bind successful\n");
|
"get_miniserver_sockets: bind successful\n");
|
||||||
if (listenfd4 != -1) {
|
if (listenfd4 != INVALID_SOCKET) {
|
||||||
ret_code = listen(listenfd4, SOMAXCONN);
|
ret_code = listen(listenfd4, SOMAXCONN);
|
||||||
if (ret_code == -1) {
|
if (ret_code == SOCKET_ERROR) {
|
||||||
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
||||||
"mserv start: Error in IPv4 listen(): %s\n",
|
"mserv start: Error in IPv4 listen(): %s\n",
|
||||||
@@ -723,8 +726,8 @@ static int get_miniserver_sockets(
|
|||||||
#endif
|
#endif
|
||||||
return UPNP_E_LISTEN;
|
return UPNP_E_LISTEN;
|
||||||
}
|
}
|
||||||
actual_port4 = get_port(listenfd4);
|
ret_code = get_port(listenfd4, &actual_port4);
|
||||||
if (actual_port4 <= 0) {
|
if (ret_code < 0) {
|
||||||
sock_close(listenfd4);
|
sock_close(listenfd4);
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
sock_close(listenfd6);
|
sock_close(listenfd6);
|
||||||
@@ -734,9 +737,9 @@ static int get_miniserver_sockets(
|
|||||||
out->miniServerPort4 = actual_port4;
|
out->miniServerPort4 = actual_port4;
|
||||||
}
|
}
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
if (listenfd6 != -1) {
|
if (listenfd6 != INVALID_SOCKET) {
|
||||||
ret_code = listen(listenfd6, SOMAXCONN);
|
ret_code = listen(listenfd6, SOMAXCONN);
|
||||||
if (ret_code == -1) {
|
if (ret_code == SOCKET_ERROR) {
|
||||||
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, MSERV, __FILE__, __LINE__,
|
||||||
"mserv start: Error in IPv6 listen(): %s\n",
|
"mserv start: Error in IPv6 listen(): %s\n",
|
||||||
@@ -745,8 +748,8 @@ static int get_miniserver_sockets(
|
|||||||
sock_close(listenfd6);
|
sock_close(listenfd6);
|
||||||
return UPNP_E_LISTEN;
|
return UPNP_E_LISTEN;
|
||||||
}
|
}
|
||||||
actual_port6 = get_port(listenfd6);
|
ret_code = get_port(listenfd6, &actual_port6);
|
||||||
if (actual_port6 <= 0) {
|
if (ret_code < 0) {
|
||||||
sock_close(listenfd4);
|
sock_close(listenfd4);
|
||||||
sock_close(listenfd6);
|
sock_close(listenfd6);
|
||||||
return UPNP_E_INTERNAL_ERROR;
|
return UPNP_E_INTERNAL_ERROR;
|
||||||
@@ -757,12 +760,15 @@ static int get_miniserver_sockets(
|
|||||||
out->miniServerSock4 = listenfd4;
|
out->miniServerSock4 = listenfd4;
|
||||||
#ifdef UPNP_ENABLE_IPV6
|
#ifdef UPNP_ENABLE_IPV6
|
||||||
out->miniServerSock6 = listenfd6;
|
out->miniServerSock6 = listenfd6;
|
||||||
|
#else
|
||||||
|
/* Silence compiler warning message:
|
||||||
|
* warning: unused parameter ‘listen_port6’ */
|
||||||
|
listen_port6 = 0;
|
||||||
#endif
|
#endif
|
||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
#endif /* INTERNAL_WEB_SERVER */
|
#endif /* INTERNAL_WEB_SERVER */
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Creates the miniserver STOP socket. This socket is created and
|
* \brief Creates the miniserver STOP socket. This socket is created and
|
||||||
* listened on to know when it is time to stop the Miniserver.
|
* listened on to know when it is time to stop the Miniserver.
|
||||||
@@ -779,11 +785,11 @@ static int get_miniserver_stopsock(
|
|||||||
{
|
{
|
||||||
char errorBuffer[ERROR_BUFFER_LEN];
|
char errorBuffer[ERROR_BUFFER_LEN];
|
||||||
struct sockaddr_in stop_sockaddr;
|
struct sockaddr_in stop_sockaddr;
|
||||||
int miniServerStopSock = 0;
|
SOCKET miniServerStopSock = 0;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
miniServerStopSock = socket(AF_INET, SOCK_DGRAM, 0);
|
miniServerStopSock = socket(AF_INET, SOCK_DGRAM, 0);
|
||||||
if (miniServerStopSock == -1) {
|
if (miniServerStopSock == INVALID_SOCKET) {
|
||||||
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_CRITICAL, MSERV, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_CRITICAL, MSERV, __FILE__, __LINE__,
|
||||||
"Error in socket(): %s\n", errorBuffer);
|
"Error in socket(): %s\n", errorBuffer);
|
||||||
@@ -795,15 +801,15 @@ static int get_miniserver_stopsock(
|
|||||||
stop_sockaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
|
stop_sockaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
|
||||||
ret = bind(miniServerStopSock, (struct sockaddr *)&stop_sockaddr,
|
ret = bind(miniServerStopSock, (struct sockaddr *)&stop_sockaddr,
|
||||||
sizeof(stop_sockaddr));
|
sizeof(stop_sockaddr));
|
||||||
if (ret == -1) {
|
if (ret == SOCKET_ERROR) {
|
||||||
UpnpPrintf(UPNP_CRITICAL,
|
UpnpPrintf(UPNP_CRITICAL,
|
||||||
MSERV, __FILE__, __LINE__,
|
MSERV, __FILE__, __LINE__,
|
||||||
"Error in binding localhost!!!\n");
|
"Error in binding localhost!!!\n");
|
||||||
sock_close(miniServerStopSock);
|
sock_close(miniServerStopSock);
|
||||||
return UPNP_E_SOCKET_BIND;
|
return UPNP_E_SOCKET_BIND;
|
||||||
}
|
}
|
||||||
miniStopSockPort = get_port( miniServerStopSock );
|
ret = get_port(miniServerStopSock, &miniStopSockPort);
|
||||||
if (miniStopSockPort <= 0) {
|
if (ret < 0) {
|
||||||
sock_close(miniServerStopSock);
|
sock_close(miniServerStopSock);
|
||||||
return UPNP_E_INTERNAL_ERROR;
|
return UPNP_E_INTERNAL_ERROR;
|
||||||
}
|
}
|
||||||
@@ -813,28 +819,30 @@ static int get_miniserver_stopsock(
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void InitMiniServerSockArray(MiniServerSockArray *miniSocket)
|
static UPNP_INLINE void InitMiniServerSockArray(MiniServerSockArray *miniSocket)
|
||||||
{
|
{
|
||||||
miniSocket->miniServerSock4 = -1;
|
miniSocket->miniServerSock4 = INVALID_SOCKET;
|
||||||
miniSocket->miniServerSock6 = -1;
|
miniSocket->miniServerSock6 = INVALID_SOCKET;
|
||||||
miniSocket->miniServerStopSock = -1;
|
miniSocket->miniServerStopSock = INVALID_SOCKET;
|
||||||
miniSocket->ssdpSock4 = -1;
|
miniSocket->ssdpSock4 = INVALID_SOCKET;
|
||||||
miniSocket->ssdpSock6 = -1;
|
miniSocket->ssdpSock6 = INVALID_SOCKET;
|
||||||
miniSocket->ssdpSock6UlaGua = -1;
|
miniSocket->ssdpSock6UlaGua = INVALID_SOCKET;
|
||||||
miniSocket->stopPort = -1;
|
miniSocket->stopPort = 0;
|
||||||
miniSocket->miniServerPort4 = -1;
|
miniSocket->miniServerPort4 = 0;
|
||||||
miniSocket->miniServerPort6 = -1;
|
miniSocket->miniServerPort6 = 0;
|
||||||
miniSocket->ssdpReqSock4 = -1;
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
miniSocket->ssdpReqSock6 = -1;
|
miniSocket->ssdpReqSock4 = INVALID_SOCKET;
|
||||||
|
miniSocket->ssdpReqSock6 = INVALID_SOCKET;
|
||||||
|
#endif /* INCLUDE_CLIENT_APIS */
|
||||||
}
|
}
|
||||||
|
|
||||||
int StartMiniServer(
|
int StartMiniServer(
|
||||||
/*! [in,out] Port on which the server listens for incoming IPv4
|
/*! [in,out] Port on which the server listens for incoming IPv4
|
||||||
* connections. */
|
* connections. */
|
||||||
unsigned short *listen_port4,
|
uint16_t *listen_port4,
|
||||||
/*! [in,out] Port on which the server listens for incoming IPv6
|
/*! [in,out] Port on which the server listens for incoming IPv6
|
||||||
* connections. */
|
* connections. */
|
||||||
unsigned short *listen_port6)
|
uint16_t *listen_port6)
|
||||||
{
|
{
|
||||||
int ret_code;
|
int ret_code;
|
||||||
int count;
|
int count;
|
||||||
@@ -842,6 +850,8 @@ int StartMiniServer(
|
|||||||
MiniServerSockArray *miniSocket;
|
MiniServerSockArray *miniSocket;
|
||||||
ThreadPoolJob job;
|
ThreadPoolJob job;
|
||||||
|
|
||||||
|
memset(&job, 0, sizeof(job));
|
||||||
|
|
||||||
if (gMServState != MSERV_IDLE) {
|
if (gMServState != MSERV_IDLE) {
|
||||||
/* miniserver running. */
|
/* miniserver running. */
|
||||||
return UPNP_E_INTERNAL_ERROR;
|
return UPNP_E_INTERNAL_ERROR;
|
||||||
@@ -889,8 +899,10 @@ int StartMiniServer(
|
|||||||
sock_close(miniSocket->ssdpSock4);
|
sock_close(miniSocket->ssdpSock4);
|
||||||
sock_close(miniSocket->ssdpSock6);
|
sock_close(miniSocket->ssdpSock6);
|
||||||
sock_close(miniSocket->ssdpSock6UlaGua);
|
sock_close(miniSocket->ssdpSock6UlaGua);
|
||||||
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
sock_close(miniSocket->ssdpReqSock4);
|
sock_close(miniSocket->ssdpReqSock4);
|
||||||
sock_close(miniSocket->ssdpReqSock6);
|
sock_close(miniSocket->ssdpReqSock6);
|
||||||
|
#endif /* INCLUDE_CLIENT_APIS */
|
||||||
return UPNP_E_OUTOF_MEMORY;
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
}
|
}
|
||||||
/* Wait for miniserver to start. */
|
/* Wait for miniserver to start. */
|
||||||
@@ -908,8 +920,10 @@ int StartMiniServer(
|
|||||||
sock_close(miniSocket->ssdpSock4);
|
sock_close(miniSocket->ssdpSock4);
|
||||||
sock_close(miniSocket->ssdpSock6);
|
sock_close(miniSocket->ssdpSock6);
|
||||||
sock_close(miniSocket->ssdpSock6UlaGua);
|
sock_close(miniSocket->ssdpSock6UlaGua);
|
||||||
|
#ifdef INCLUDE_CLIENT_APIS
|
||||||
sock_close(miniSocket->ssdpReqSock4);
|
sock_close(miniSocket->ssdpReqSock4);
|
||||||
sock_close(miniSocket->ssdpReqSock6);
|
sock_close(miniSocket->ssdpReqSock6);
|
||||||
|
#endif /* INCLUDE_CLIENT_APIS */
|
||||||
return UPNP_E_INTERNAL_ERROR;
|
return UPNP_E_INTERNAL_ERROR;
|
||||||
}
|
}
|
||||||
#ifdef INTERNAL_WEB_SERVER
|
#ifdef INTERNAL_WEB_SERVER
|
||||||
@@ -920,15 +934,14 @@ int StartMiniServer(
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int StopMiniServer()
|
int StopMiniServer()
|
||||||
{
|
{
|
||||||
char errorBuffer[ERROR_BUFFER_LEN];
|
char errorBuffer[ERROR_BUFFER_LEN];
|
||||||
int socklen = sizeof (struct sockaddr_in);
|
socklen_t socklen = sizeof (struct sockaddr_in);
|
||||||
SOCKET sock;
|
SOCKET sock;
|
||||||
struct sockaddr_in ssdpAddr;
|
struct sockaddr_in ssdpAddr;
|
||||||
char buf[256] = "ShutDown";
|
char buf[256] = "ShutDown";
|
||||||
int bufLen = strlen(buf);
|
size_t bufLen = strlen(buf);
|
||||||
|
|
||||||
if(gMServState == MSERV_RUNNING) {
|
if(gMServState == MSERV_RUNNING) {
|
||||||
gMServState = MSERV_STOPPING;
|
gMServState = MSERV_STOPPING;
|
||||||
@@ -936,7 +949,7 @@ int StopMiniServer()
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
sock = socket(AF_INET, SOCK_DGRAM, 0);
|
sock = socket(AF_INET, SOCK_DGRAM, 0);
|
||||||
if (sock == -1) {
|
if (sock == INVALID_SOCKET) {
|
||||||
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
||||||
UpnpPrintf(UPNP_INFO, SSDP, __FILE__, __LINE__,
|
UpnpPrintf(UPNP_INFO, SSDP, __FILE__, __LINE__,
|
||||||
"SSDP_SERVER: StopSSDPServer: Error in socket() %s\n",
|
"SSDP_SERVER: StopSSDPServer: Error in socket() %s\n",
|
||||||
@@ -947,8 +960,8 @@ int StopMiniServer()
|
|||||||
ssdpAddr.sin_family = AF_INET;
|
ssdpAddr.sin_family = AF_INET;
|
||||||
ssdpAddr.sin_addr.s_addr = inet_addr("127.0.0.1");
|
ssdpAddr.sin_addr.s_addr = inet_addr("127.0.0.1");
|
||||||
ssdpAddr.sin_port = htons(miniStopSockPort);
|
ssdpAddr.sin_port = htons(miniStopSockPort);
|
||||||
sendto(sock, buf, bufLen, 0, (struct sockaddr *)&ssdpAddr,
|
sendto(sock, buf, bufLen, 0,
|
||||||
socklen);
|
(struct sockaddr *)&ssdpAddr, socklen);
|
||||||
usleep(1000);
|
usleep(1000);
|
||||||
if (gMServState == MSERV_IDLE) {
|
if (gMServState == MSERV_IDLE) {
|
||||||
break;
|
break;
|
||||||
@@ -959,4 +972,4 @@ int StopMiniServer()
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif /* EXCLUDE_MINISERVER */
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -1,71 +1,65 @@
|
|||||||
///////////////////////////////////////////////////////////////////////////
|
/*******************************************************************************
|
||||||
//
|
*
|
||||||
// Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
// All rights reserved.
|
* All rights reserved.
|
||||||
//
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
// Redistribution and use in source and binary forms, with or without
|
*
|
||||||
// modification, are permitted provided that the following conditions are met:
|
* 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 of source code must retain the above copyright notice,
|
||||||
// * Redistributions in binary form must reproduce the above copyright notice,
|
* this list of conditions and the following disclaimer.
|
||||||
// this list of conditions and the following disclaimer in the documentation
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
// and/or other materials provided with the distribution.
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
// * Neither name of Intel Corporation nor the names of its contributors
|
* and/or other materials provided with the distribution.
|
||||||
// may be used to endorse or promote products derived from this software
|
* - Neither name of Intel Corporation nor the names of its contributors
|
||||||
// without specific prior written permission.
|
* 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
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
||||||
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
||||||
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* 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 a function to extract the header information from *
|
* \file
|
||||||
* 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 "config.h"
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include "util.h"
|
#include "upnputil.h"
|
||||||
#include "membuffer.h"
|
#include "membuffer.h"
|
||||||
#include "httpparser.h"
|
#include "httpparser.h"
|
||||||
#include "statcodes.h"
|
#include "statcodes.h"
|
||||||
#include "parsetools.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;
|
memptr hdr_value;
|
||||||
|
|
||||||
assert( hmsg );
|
assert(hmsg);
|
||||||
|
|
||||||
// find 'content-type' header which must have text/xml
|
/* find 'content-type' header which must have text/xml */
|
||||||
if( httpmsg_find_hdr( hmsg, HDR_CONTENT_TYPE, &hdr_value ) != NULL &&
|
if (httpmsg_find_hdr(hmsg, HDR_CONTENT_TYPE, &hdr_value)) {
|
||||||
matchstr( hdr_value.buf, hdr_value.length,
|
switch (matchstr(hdr_value.buf, hdr_value.length, "%itext%w/%wxml" )) {
|
||||||
"%itext%w/%wxml" ) == PARSE_OK ) {
|
case PARSE_OK:
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,33 +1,34 @@
|
|||||||
///////////////////////////////////////////////////////////////////////////
|
/*******************************************************************************
|
||||||
//
|
*
|
||||||
// Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
// All rights reserved.
|
* All rights reserved.
|
||||||
//
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
// Redistribution and use in source and binary forms, with or without
|
*
|
||||||
// modification, are permitted provided that the following conditions are met:
|
* 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 of source code must retain the above copyright notice,
|
||||||
// * Redistributions in binary form must reproduce the above copyright notice,
|
* this list of conditions and the following disclaimer.
|
||||||
// this list of conditions and the following disclaimer in the documentation
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
// and/or other materials provided with the distribution.
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
// * Neither name of Intel Corporation nor the names of its contributors
|
* and/or other materials provided with the distribution.
|
||||||
// may be used to endorse or promote products derived from this software
|
* - Neither name of Intel Corporation nor the names of its contributors
|
||||||
// without specific prior written permission.
|
* 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
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
||||||
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
||||||
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* 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 *
|
* Purpose: This file defines status codes, buffers to store the status *
|
||||||
@@ -37,7 +38,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "util.h"
|
#include "upnputil.h"
|
||||||
#include "statcodes.h"
|
#include "statcodes.h"
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
@@ -96,7 +97,7 @@ static const char *Http5xxStr =
|
|||||||
"Service Unavailable\0"
|
"Service Unavailable\0"
|
||||||
"Gateway Timeout\0" "HTTP Version Not Supported\0";
|
"Gateway Timeout\0" "HTTP Version Not Supported\0";
|
||||||
|
|
||||||
static xboolean gInitialized = FALSE;
|
static int gInitialized = FALSE;
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
************************* Functions *************************************
|
************************* Functions *************************************
|
||||||
@@ -128,7 +129,7 @@ init_table( IN const char *encoded_str,
|
|||||||
|
|
||||||
for( i = 0; i < tbl_size; i++ ) {
|
for( i = 0; i < tbl_size; i++ ) {
|
||||||
table[i] = s;
|
table[i] = s;
|
||||||
s += strlen( s ) + 1; // next entry
|
s += strlen( s ) + (size_t)1; /* next entry */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -153,7 +154,7 @@ init_tables( void )
|
|||||||
init_table( Http4xxStr, Http4xxCodes, NUM_4XX_CODES );
|
init_table( Http4xxStr, Http4xxCodes, NUM_4XX_CODES );
|
||||||
init_table( Http5xxStr, Http5xxCodes, NUM_5XX_CODES );
|
init_table( Http5xxStr, Http5xxCodes, NUM_5XX_CODES );
|
||||||
|
|
||||||
gInitialized = TRUE; // mark only after complete
|
gInitialized = TRUE; /* mark only after complete */
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
@@ -179,7 +180,7 @@ http_get_code_text( int statusCode )
|
|||||||
init_tables();
|
init_tables();
|
||||||
}
|
}
|
||||||
|
|
||||||
if( statusCode < 100 && statusCode >= 600 ) {
|
if( statusCode < 100 || statusCode >= 600 ) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -30,6 +31,10 @@
|
|||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
* \addtogroup Sock
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
* \file
|
* \file
|
||||||
*
|
*
|
||||||
* \brief Implements the sockets functionality.
|
* \brief Implements the sockets functionality.
|
||||||
@@ -41,9 +46,14 @@
|
|||||||
|
|
||||||
#include "unixutil.h" /* for socklen_t, EAFNOSUPPORT */
|
#include "unixutil.h" /* for socklen_t, EAFNOSUPPORT */
|
||||||
#include "upnp.h"
|
#include "upnp.h"
|
||||||
|
#include "UpnpStdInt.h" /* for ssize_t */
|
||||||
|
|
||||||
|
#include "upnpdebug.h"
|
||||||
|
#include "upnputil.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <fcntl.h> /* for F_GETFL, F_SETFL, O_NONBLOCK */
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
@@ -51,7 +61,7 @@
|
|||||||
#define MSG_NOSIGNAL 0
|
#define MSG_NOSIGNAL 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int sock_init(OUT SOCKINFO *info, IN SOCKET sockfd)
|
int sock_init(SOCKINFO *info, SOCKET sockfd)
|
||||||
{
|
{
|
||||||
assert(info);
|
assert(info);
|
||||||
|
|
||||||
@@ -61,8 +71,8 @@ int sock_init(OUT SOCKINFO *info, IN SOCKET sockfd)
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sock_init_with_ip(OUT SOCKINFO *info, IN SOCKET sockfd,
|
int sock_init_with_ip(SOCKINFO *info, SOCKET sockfd,
|
||||||
IN struct sockaddr *foreign_sockaddr)
|
struct sockaddr *foreign_sockaddr)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@@ -77,16 +87,21 @@ int sock_init_with_ip(OUT SOCKINFO *info, IN SOCKET sockfd,
|
|||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sock_destroy(INOUT SOCKINFO *info, int ShutdownMethod)
|
int sock_destroy(SOCKINFO *info, int ShutdownMethod)
|
||||||
{
|
{
|
||||||
int ret = UPNP_E_SUCCESS;
|
int ret = UPNP_E_SUCCESS;
|
||||||
|
char errorBuffer[ERROR_BUFFER_LEN];
|
||||||
|
|
||||||
if (info->socket != -1) {
|
if (info->socket != INVALID_SOCKET) {
|
||||||
shutdown(info->socket, ShutdownMethod);
|
if (shutdown(info->socket, ShutdownMethod) == -1) {
|
||||||
|
strerror_r(errno, errorBuffer, ERROR_BUFFER_LEN);
|
||||||
|
UpnpPrintf(UPNP_INFO, HTTP, __FILE__, __LINE__,
|
||||||
|
"Error in shutdown: %s\n", errorBuffer);
|
||||||
|
}
|
||||||
if (sock_close(info->socket) == -1) {
|
if (sock_close(info->socket) == -1) {
|
||||||
ret = UPNP_E_SOCKET_ERROR;
|
ret = UPNP_E_SOCKET_ERROR;
|
||||||
}
|
}
|
||||||
info->socket = -1;
|
info->socket = INVALID_SOCKET;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
@@ -102,58 +117,55 @@ int sock_destroy(INOUT SOCKINFO *info, int ShutdownMethod)
|
|||||||
* \li \c UPNP_E_SOCKET_ERROR - Error on socket calls
|
* \li \c UPNP_E_SOCKET_ERROR - Error on socket calls
|
||||||
*/
|
*/
|
||||||
static int sock_read_write(
|
static int sock_read_write(
|
||||||
/*! Socket Information Object. */
|
/*! [in] Socket Information Object. */
|
||||||
IN SOCKINFO *info,
|
SOCKINFO *info,
|
||||||
/*! Buffer to get data to or send data from. */
|
/*! [out] Buffer to get data to or send data from. */
|
||||||
OUT char *buffer,
|
char *buffer,
|
||||||
/*! Size of the buffer. */
|
/*! [in] Size of the buffer. */
|
||||||
IN size_t bufsize,
|
size_t bufsize,
|
||||||
/*! timeout value. */
|
/*! [in] timeout value. */
|
||||||
IN int *timeoutSecs,
|
int *timeoutSecs,
|
||||||
/*! Boolean value specifying read or write option. */
|
/*! [in] Boolean value specifying read or write option. */
|
||||||
IN xboolean bRead)
|
int bRead)
|
||||||
{
|
{
|
||||||
int retCode;
|
int retCode;
|
||||||
fd_set readSet;
|
fd_set readSet;
|
||||||
fd_set writeSet;
|
fd_set writeSet;
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
int numBytes;
|
long numBytes;
|
||||||
time_t start_time = time(NULL);
|
time_t start_time = time(NULL);
|
||||||
SOCKET sockfd = info->socket;
|
SOCKET sockfd = info->socket;
|
||||||
long bytes_sent = 0, byte_left = 0, num_written;
|
long bytes_sent = 0;
|
||||||
|
size_t byte_left = (size_t)0;
|
||||||
|
ssize_t num_written;
|
||||||
|
|
||||||
if (*timeoutSecs < 0) {
|
if (*timeoutSecs < 0)
|
||||||
return UPNP_E_TIMEDOUT;
|
return UPNP_E_TIMEDOUT;
|
||||||
}
|
|
||||||
FD_ZERO(&readSet);
|
FD_ZERO(&readSet);
|
||||||
FD_ZERO(&writeSet);
|
FD_ZERO(&writeSet);
|
||||||
if (bRead) {
|
if (bRead)
|
||||||
FD_SET(sockfd, &readSet);
|
FD_SET(sockfd, &readSet);
|
||||||
} else {
|
else
|
||||||
FD_SET(sockfd, &writeSet);
|
FD_SET(sockfd, &writeSet);
|
||||||
}
|
|
||||||
timeout.tv_sec = *timeoutSecs;
|
timeout.tv_sec = *timeoutSecs;
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
while (TRUE) {
|
while (TRUE) {
|
||||||
if (*timeoutSecs == 0) {
|
if (*timeoutSecs == 0)
|
||||||
retCode = select(sockfd + 1, &readSet, &writeSet,
|
retCode = select(sockfd + 1, &readSet, &writeSet,
|
||||||
NULL, NULL);
|
NULL, NULL);
|
||||||
} else {
|
else
|
||||||
retCode = select(sockfd + 1, &readSet, &writeSet,
|
retCode = select(sockfd + 1, &readSet, &writeSet,
|
||||||
NULL, &timeout);
|
NULL, &timeout);
|
||||||
}
|
if (retCode == 0)
|
||||||
if (retCode == 0) {
|
|
||||||
return UPNP_E_TIMEDOUT;
|
return UPNP_E_TIMEDOUT;
|
||||||
}
|
|
||||||
if (retCode == -1) {
|
if (retCode == -1) {
|
||||||
if (errno == EINTR)
|
if (errno == EINTR)
|
||||||
continue;
|
continue;
|
||||||
return UPNP_E_SOCKET_ERROR;
|
return UPNP_E_SOCKET_ERROR;
|
||||||
} else {
|
} else
|
||||||
/* read or write. */
|
/* read or write. */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
#ifdef SO_NOSIGPIPE
|
#ifdef SO_NOSIGPIPE
|
||||||
{
|
{
|
||||||
int old;
|
int old;
|
||||||
@@ -164,11 +176,11 @@ static int sock_read_write(
|
|||||||
#endif
|
#endif
|
||||||
if (bRead) {
|
if (bRead) {
|
||||||
/* read data. */
|
/* read data. */
|
||||||
numBytes = recv(sockfd, buffer, bufsize, MSG_NOSIGNAL);
|
numBytes = (long)recv(sockfd, buffer, bufsize, MSG_NOSIGNAL);
|
||||||
} else {
|
} else {
|
||||||
byte_left = bufsize;
|
byte_left = bufsize;
|
||||||
bytes_sent = 0;
|
bytes_sent = 0;
|
||||||
while (byte_left > 0) {
|
while (byte_left != (size_t)0) {
|
||||||
/* write data. */
|
/* write data. */
|
||||||
num_written = send(sockfd,
|
num_written = send(sockfd,
|
||||||
buffer + bytes_sent, byte_left,
|
buffer + bytes_sent, byte_left,
|
||||||
@@ -178,9 +190,9 @@ static int sock_read_write(
|
|||||||
setsockopt(sockfd, SOL_SOCKET,
|
setsockopt(sockfd, SOL_SOCKET,
|
||||||
SO_NOSIGPIPE, &old, olen);
|
SO_NOSIGPIPE, &old, olen);
|
||||||
#endif
|
#endif
|
||||||
return num_written;
|
return (int)num_written;
|
||||||
}
|
}
|
||||||
byte_left = byte_left - num_written;
|
byte_left -= (size_t)num_written;
|
||||||
bytes_sent += num_written;
|
bytes_sent += num_written;
|
||||||
}
|
}
|
||||||
numBytes = bytes_sent;
|
numBytes = bytes_sent;
|
||||||
@@ -189,26 +201,57 @@ static int sock_read_write(
|
|||||||
setsockopt(sockfd, SOL_SOCKET, SO_NOSIGPIPE, &old, olen);
|
setsockopt(sockfd, SOL_SOCKET, SO_NOSIGPIPE, &old, olen);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (numBytes < 0) {
|
if (numBytes < 0)
|
||||||
return UPNP_E_SOCKET_ERROR;
|
return UPNP_E_SOCKET_ERROR;
|
||||||
}
|
|
||||||
/* subtract time used for reading/writing. */
|
/* subtract time used for reading/writing. */
|
||||||
if (*timeoutSecs != 0) {
|
if (*timeoutSecs != 0)
|
||||||
*timeoutSecs -= time(NULL) - start_time;
|
*timeoutSecs -= (int)(time(NULL) - start_time);
|
||||||
}
|
|
||||||
|
|
||||||
return numBytes;
|
return (int)numBytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sock_read(IN SOCKINFO *info, OUT char *buffer, IN size_t bufsize,
|
int sock_read(SOCKINFO *info, char *buffer, size_t bufsize, int *timeoutSecs)
|
||||||
INOUT int *timeoutSecs)
|
|
||||||
{
|
{
|
||||||
return sock_read_write(info, buffer, bufsize, timeoutSecs, TRUE);
|
return sock_read_write(info, buffer, bufsize, timeoutSecs, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
int sock_write(IN SOCKINFO *info, IN char *buffer, IN size_t bufsize,
|
int sock_write(SOCKINFO *info, const char *buffer, size_t bufsize, int *timeoutSecs)
|
||||||
INOUT int *timeoutSecs)
|
|
||||||
{
|
{
|
||||||
return sock_read_write(info, buffer, bufsize, timeoutSecs, FALSE);
|
/* Consciently removing constness. */
|
||||||
|
return sock_read_write(info, (char *)buffer, bufsize, timeoutSecs, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int sock_make_blocking(SOCKET sock)
|
||||||
|
{
|
||||||
|
#ifdef WIN32
|
||||||
|
u_long val = 0;
|
||||||
|
return ioctlsocket(sock, FIONBIO, &val);
|
||||||
|
#else
|
||||||
|
int val;
|
||||||
|
|
||||||
|
val = fcntl(sock, F_GETFL, 0);
|
||||||
|
if (fcntl(sock, F_SETFL, val & ~O_NONBLOCK) == -1) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int sock_make_no_blocking(SOCKET sock)
|
||||||
|
{
|
||||||
|
#ifdef WIN32
|
||||||
|
u_long val = 1;
|
||||||
|
return ioctlsocket(sock, FIONBIO, &val);
|
||||||
|
#else /* WIN32 */
|
||||||
|
int val;
|
||||||
|
|
||||||
|
val = fcntl(sock, F_GETFL, 0);
|
||||||
|
if (fcntl(sock, F_SETFL, val | O_NONBLOCK) == -1) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif /* WIN32 */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* @} Sock */
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -43,6 +44,9 @@
|
|||||||
#include <lwres/netdb.h>
|
#include <lwres/netdb.h>
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef WIN32
|
||||||
|
#define snprintf _snprintf
|
||||||
|
#endif
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
|
||||||
@@ -65,7 +69,7 @@ static int is_reserved(
|
|||||||
/*! [in] Char to be matched for RESERVED characters. */
|
/*! [in] Char to be matched for RESERVED characters. */
|
||||||
char in)
|
char in)
|
||||||
{
|
{
|
||||||
if (strchr(RESERVED, in)) {
|
if (strchr(RESERVED, (int)in)) {
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
@@ -83,7 +87,7 @@ int is_mark(
|
|||||||
/*! [in] Char to be matched for MARKED characters. */
|
/*! [in] Char to be matched for MARKED characters. */
|
||||||
char in)
|
char in)
|
||||||
{
|
{
|
||||||
if (strchr(MARK, in)) {
|
if (strchr(MARK, (int)in)) {
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
@@ -128,23 +132,21 @@ int is_escaped(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int replace_escaped(char *in, size_t index, size_t *max)
|
||||||
int replace_escaped(char *in, int index, size_t *max)
|
|
||||||
{
|
{
|
||||||
int tempInt = 0;
|
int tempInt = 0;
|
||||||
char tempChar = 0;
|
char tempChar = 0;
|
||||||
int i = 0;
|
size_t i = (size_t)0;
|
||||||
int j = 0;
|
size_t j = (size_t)0;
|
||||||
|
|
||||||
if (in[index] == '%' && isxdigit(in[index + 1]) && isxdigit(in[index + 2])) {
|
if (in[index] == '%' && isxdigit(in[index + (size_t)1]) && isxdigit(in[index + (size_t)2])) {
|
||||||
/* Note the "%2x", makes sure that we convert a maximum of two
|
/* Note the "%2x", makes sure that we convert a maximum of two
|
||||||
* characters. */
|
* characters. */
|
||||||
if (sscanf(&in[index + 1], "%2x", &tempInt) != 1) {
|
if (sscanf(&in[index + (size_t)1], "%2x", &tempInt) != 1) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
tempChar = (char)tempInt;
|
||||||
tempChar = ( char )tempInt;
|
for (i = index + (size_t)3, j = index; j < *max; i++, j++) {
|
||||||
for (i = index + 3, j = index; j < *max; i++, j++) {
|
|
||||||
in[j] = tempChar;
|
in[j] = tempChar;
|
||||||
if (i < *max) {
|
if (i < *max) {
|
||||||
tempChar = in[i];
|
tempChar = in[i];
|
||||||
@@ -152,7 +154,7 @@ int replace_escaped(char *in, int index, size_t *max)
|
|||||||
tempChar = 0;
|
tempChar = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*max -= 2;
|
*max -= (size_t)2;
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
@@ -166,20 +168,20 @@ int replace_escaped(char *in, int index, size_t *max)
|
|||||||
*
|
*
|
||||||
* \return
|
* \return
|
||||||
*/
|
*/
|
||||||
static int parse_uric(
|
static size_t parse_uric(
|
||||||
/*! [in] String of characters. */
|
/*! [in] String of characters. */
|
||||||
const char *in,
|
const char *in,
|
||||||
/*! [in] Maximum limit. */
|
/*! [in] Maximum limit. */
|
||||||
int max,
|
size_t max,
|
||||||
/*! [out] Token object where the string of characters is copied. */
|
/*! [out] Token object where the string of characters is copied. */
|
||||||
token *out)
|
token *out)
|
||||||
{
|
{
|
||||||
int i = 0;
|
size_t i = (size_t)0;
|
||||||
|
|
||||||
while (i < max &&
|
while (i < max &&
|
||||||
(is_unreserved(in[i]) ||
|
(is_unreserved(in[i]) ||
|
||||||
is_reserved(in[i]) ||
|
is_reserved(in[i]) ||
|
||||||
((i + 2 < max) && is_escaped(&in[i])))) {
|
((i + (size_t)2 < max) && is_escaped(&in[i])))) {
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -211,28 +213,24 @@ static void copy_token(
|
|||||||
|
|
||||||
int copy_URL_list(URL_list *in, URL_list *out)
|
int copy_URL_list(URL_list *in, URL_list *out)
|
||||||
{
|
{
|
||||||
int len = strlen( in->URLs ) + 1;
|
size_t len = strlen(in->URLs) + (size_t)1;
|
||||||
int i = 0;
|
size_t i = (size_t)0;
|
||||||
|
|
||||||
out->URLs = NULL;
|
out->URLs = NULL;
|
||||||
out->parsedURLs = NULL;
|
out->parsedURLs = NULL;
|
||||||
out->size = 0;
|
out->size = (size_t)0;
|
||||||
|
|
||||||
out->URLs = ( char * )malloc( len );
|
out->URLs = malloc(len);
|
||||||
out->parsedURLs =
|
out->parsedURLs = malloc(sizeof(uri_type) * in->size);
|
||||||
( uri_type * ) malloc( sizeof( uri_type ) * in->size );
|
|
||||||
|
|
||||||
if( ( out->URLs == NULL ) || ( out->parsedURLs == NULL ) )
|
if ( !out->URLs || !out->parsedURLs)
|
||||||
return UPNP_E_OUTOF_MEMORY;
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
|
memcpy(out->URLs, in->URLs, len);
|
||||||
memcpy( out->URLs, in->URLs, len );
|
for( i = (size_t)0; i < in->size; i++ ) {
|
||||||
|
/*copy the parsed uri */
|
||||||
for( i = 0; i < in->size; i++ ) {
|
|
||||||
//copy the parsed uri
|
|
||||||
out->parsedURLs[i].type = in->parsedURLs[i].type;
|
out->parsedURLs[i].type = in->parsedURLs[i].type;
|
||||||
copy_token( &in->parsedURLs[i].scheme, in->URLs,
|
copy_token( &in->parsedURLs[i].scheme, in->URLs,
|
||||||
&out->parsedURLs[i].scheme, out->URLs );
|
&out->parsedURLs[i].scheme, out->URLs );
|
||||||
|
|
||||||
out->parsedURLs[i].path_type = in->parsedURLs[i].path_type;
|
out->parsedURLs[i].path_type = in->parsedURLs[i].path_type;
|
||||||
copy_token( &in->parsedURLs[i].pathquery, in->URLs,
|
copy_token( &in->parsedURLs[i].pathquery, in->URLs,
|
||||||
&out->parsedURLs[i].pathquery, out->URLs );
|
&out->parsedURLs[i].pathquery, out->URLs );
|
||||||
@@ -241,7 +239,6 @@ int copy_URL_list(URL_list *in, URL_list *out)
|
|||||||
copy_token( &in->parsedURLs[i].hostport.text,
|
copy_token( &in->parsedURLs[i].hostport.text,
|
||||||
in->URLs, &out->parsedURLs[i].hostport.text,
|
in->URLs, &out->parsedURLs[i].hostport.text,
|
||||||
out->URLs );
|
out->URLs );
|
||||||
|
|
||||||
memcpy( &out->parsedURLs[i].hostport.IPaddress,
|
memcpy( &out->parsedURLs[i].hostport.IPaddress,
|
||||||
&in->parsedURLs[i].hostport.IPaddress,
|
&in->parsedURLs[i].hostport.IPaddress,
|
||||||
sizeof(struct sockaddr_storage) );
|
sizeof(struct sockaddr_storage) );
|
||||||
@@ -260,7 +257,7 @@ void free_URL_list(URL_list *list)
|
|||||||
if (list->parsedURLs) {
|
if (list->parsedURLs) {
|
||||||
free(list->parsedURLs);
|
free(list->parsedURLs);
|
||||||
}
|
}
|
||||||
list->size = 0;
|
list->size = (size_t)0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -278,113 +275,110 @@ void print_uri(uri_type *in)
|
|||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
void print_token(token * in)
|
void print_token(token * in)
|
||||||
{
|
{
|
||||||
int i = 0;
|
size_t i = 0;
|
||||||
printf( "Token Size : %"PRIzu"\n\'", in->size );
|
|
||||||
for( i = 0; i < in->size; i++ ) {
|
printf("Token Size : %" PRIzu "\n\'", in->size);
|
||||||
putchar( in->buff[i] );
|
for (i = 0; i < in->size; i++)
|
||||||
}
|
putchar(in->buff[i]);
|
||||||
putchar( '\'' );
|
putchar('\'');
|
||||||
putchar( '\n' );
|
putchar('\n');
|
||||||
}
|
}
|
||||||
#endif /* DEBUG */
|
#endif /* DEBUG */
|
||||||
|
|
||||||
|
|
||||||
int token_string_casecmp(token *in1, char *in2)
|
int token_string_casecmp(token *in1, const char *in2)
|
||||||
{
|
{
|
||||||
int in2_length = strlen(in2);
|
size_t in2_length = strlen(in2);
|
||||||
|
if (in1->size != in2_length)
|
||||||
if (in1->size != in2_length) {
|
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
else
|
||||||
return strncasecmp(in1->buff, in2, in1->size);
|
return strncasecmp(in1->buff, in2, in1->size);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int token_string_cmp(token * in1, char *in2)
|
int token_string_cmp(token * in1, char *in2)
|
||||||
{
|
{
|
||||||
int in2_length = strlen(in2);
|
size_t in2_length = strlen(in2);
|
||||||
|
if (in1->size != in2_length)
|
||||||
if (in1->size != in2_length) {
|
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
else
|
||||||
return strncmp(in1->buff, in2, in1->size);
|
return strncmp(in1->buff, in2, in1->size);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int token_cmp(token *in1, token *in2)
|
int token_cmp(token *in1, token *in2)
|
||||||
{
|
{
|
||||||
if (in1->size != in2->size) {
|
if (in1->size != in2->size)
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
else
|
||||||
return memcmp(in1->buff, in2->buff, in1->size);
|
return memcmp(in1->buff, in2->buff, in1->size);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
int parse_hostport(
|
* \brief Parses a string representing a host and port (e.g. "127.127.0.1:80"
|
||||||
|
* or "localhost") and fills out a hostport_type struct with internet address
|
||||||
|
* and a token representing the full host and port.
|
||||||
|
*
|
||||||
|
* Uses gethostbyname.
|
||||||
|
*/
|
||||||
|
static int parse_hostport(
|
||||||
|
/*! [in] String of characters representing host and port. */
|
||||||
const char *in,
|
const char *in,
|
||||||
int max,
|
/*! [out] Output parameter where the host and port are represented as
|
||||||
|
* an internet address. */
|
||||||
hostport_type *out)
|
hostport_type *out)
|
||||||
{
|
{
|
||||||
char workbuf[256];
|
char workbuf[256];
|
||||||
char* c;
|
char *c;
|
||||||
struct sockaddr_in* sai4 = (struct sockaddr_in*)&out->IPaddress;
|
struct sockaddr_in *sai4 = (struct sockaddr_in *)&out->IPaddress;
|
||||||
struct sockaddr_in6* sai6 = (struct sockaddr_in6*)&out->IPaddress;
|
struct sockaddr_in6 *sai6 = (struct sockaddr_in6 *)&out->IPaddress;
|
||||||
char *srvname = NULL;
|
char *srvname = NULL;
|
||||||
char *srvport = NULL;
|
char *srvport = NULL;
|
||||||
char *last_dot = NULL;
|
char *last_dot = NULL;
|
||||||
unsigned short int port;
|
unsigned short int port;
|
||||||
int af = AF_UNSPEC;
|
int af = AF_UNSPEC;
|
||||||
int hostport_size;
|
size_t hostport_size;
|
||||||
int has_port = 0;
|
int has_port = 0;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
memset( out, 0, sizeof(hostport_type) );
|
memset(out, 0, sizeof(hostport_type));
|
||||||
|
memset(workbuf, 0, sizeof(workbuf));
|
||||||
// Work on a copy of the input string.
|
/* Work on a copy of the input string. */
|
||||||
strncpy( workbuf, in, sizeof(workbuf) );
|
strncpy(workbuf, in, sizeof(workbuf) - 1);
|
||||||
|
|
||||||
c = workbuf;
|
c = workbuf;
|
||||||
if( *c == '[' ) {
|
if (*c == '[') {
|
||||||
// IPv6 addresses are enclosed in square brackets.
|
/* IPv6 addresses are enclosed in square brackets. */
|
||||||
srvname = ++c;
|
srvname = ++c;
|
||||||
while( *c != '\0' && *c != ']' ) {
|
while (*c != '\0' && *c != ']')
|
||||||
c++;
|
c++;
|
||||||
}
|
if (*c == '\0')
|
||||||
if( *c == '\0' ) {
|
/* did not find closing bracket. */
|
||||||
// did not find closing bracket.
|
|
||||||
return UPNP_E_INVALID_URL;
|
return UPNP_E_INVALID_URL;
|
||||||
}
|
/* NULL terminate the srvname and then increment c. */
|
||||||
// NULL terminate the srvname and then increment c.
|
*c++ = '\0'; /* overwrite the ']' */
|
||||||
*c++ = '\0'; // overwrite the ']'
|
if (*c == ':') {
|
||||||
if( *c == ':' ) {
|
|
||||||
has_port = 1;
|
has_port = 1;
|
||||||
c++;
|
c++;
|
||||||
}
|
}
|
||||||
af = AF_INET6;
|
af = AF_INET6;
|
||||||
}
|
} else {
|
||||||
else {
|
/* IPv4 address -OR- host name. */
|
||||||
// IPv4 address -OR- host name.
|
|
||||||
srvname = c;
|
srvname = c;
|
||||||
while( (*c != ':') && (*c != '/') && ( (isalnum(*c)) || (*c == '.') || (*c == '-') ) ) {
|
while (*c != ':' && *c != '/' &&
|
||||||
if( *c == '.' )
|
(isalnum(*c) || *c == '.' || *c == '-')) {
|
||||||
|
if (*c == '.')
|
||||||
last_dot = c;
|
last_dot = c;
|
||||||
c++;
|
c++;
|
||||||
}
|
}
|
||||||
has_port = (*c == ':') ? 1 : 0;
|
has_port = (*c == ':') ? 1 : 0;
|
||||||
// NULL terminate the srvname
|
/* NULL terminate the srvname */
|
||||||
*c = '\0';
|
*c = '\0';
|
||||||
if( has_port == 1 )
|
if (has_port == 1)
|
||||||
c++;
|
c++;
|
||||||
|
if (last_dot != NULL && isdigit(*(last_dot + 1)))
|
||||||
if( last_dot != NULL && isdigit(*(last_dot+1)) ) {
|
/* Must be an IPv4 address. */
|
||||||
// Must be an IPv4 address.
|
|
||||||
af = AF_INET;
|
af = AF_INET;
|
||||||
}
|
|
||||||
else {
|
else {
|
||||||
// Must be a host name.
|
/* Must be a host name. */
|
||||||
struct addrinfo hints, *res, *res0;
|
struct addrinfo hints, *res, *res0;
|
||||||
|
|
||||||
memset(&hints, 0, sizeof(hints));
|
memset(&hints, 0, sizeof(hints));
|
||||||
@@ -392,82 +386,75 @@ int parse_hostport(
|
|||||||
hints.ai_socktype = SOCK_STREAM;
|
hints.ai_socktype = SOCK_STREAM;
|
||||||
|
|
||||||
ret = getaddrinfo(srvname, NULL, &hints, &res0);
|
ret = getaddrinfo(srvname, NULL, &hints, &res0);
|
||||||
if( ret == 0 ) {
|
if (ret == 0) {
|
||||||
for (res = res0; res; res = res->ai_next) {
|
for (res = res0; res && !ret; res = res->ai_next) {
|
||||||
if( res->ai_family == AF_INET ||
|
switch (res->ai_family) {
|
||||||
res->ai_family == AF_INET6 ) {
|
case AF_INET:
|
||||||
// Found a valid IPv4 or IPv6 address.
|
case AF_INET6:
|
||||||
memcpy( &out->IPaddress, res->ai_addr,
|
/* Found a valid IPv4 or IPv6 address. */
|
||||||
res->ai_addrlen );
|
memcpy(&out->IPaddress,
|
||||||
|
res->ai_addr,
|
||||||
|
res->ai_addrlen);
|
||||||
|
ret=1;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
freeaddrinfo(res0);
|
freeaddrinfo(res0);
|
||||||
|
if (res == NULL)
|
||||||
if( res == NULL ) {
|
/* Didn't find an AF_INET or AF_INET6 address. */
|
||||||
// Didn't find an AF_INET or AF_INET6 address.
|
return UPNP_E_INVALID_URL;
|
||||||
|
} else
|
||||||
|
/* getaddrinfo failed. */
|
||||||
return UPNP_E_INVALID_URL;
|
return UPNP_E_INVALID_URL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
/* Check if a port is specified. */
|
||||||
// getaddrinfo failed.
|
if (has_port == 1) {
|
||||||
return UPNP_E_INVALID_URL;
|
/* Port is specified. */
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if a port is specified.
|
|
||||||
if( has_port == 1 ) {
|
|
||||||
// Port is specified.
|
|
||||||
srvport = c;
|
srvport = c;
|
||||||
while( *c != '\0' && isdigit(*c) ) {
|
while (*c != '\0' && isdigit(*c))
|
||||||
c++;
|
c++;
|
||||||
}
|
|
||||||
port = (unsigned short int)atoi(srvport);
|
port = (unsigned short int)atoi(srvport);
|
||||||
if( port == 0 ) {
|
if (port == 0)
|
||||||
// Bad port number.
|
/* Bad port number. */
|
||||||
return UPNP_E_INVALID_URL;
|
return UPNP_E_INVALID_URL;
|
||||||
}
|
} else
|
||||||
}
|
/* Port was not specified, use default port. */
|
||||||
else {
|
port = 80u;
|
||||||
// Port was not specified, use default port.
|
/* The length of the host and port string can be calculated by */
|
||||||
port = 80;
|
/* subtracting pointers. */
|
||||||
}
|
hostport_size = (size_t)c - (size_t)workbuf;
|
||||||
|
/* Fill in the 'out' information. */
|
||||||
// The length of the host and port string can be calculated by
|
switch (af) {
|
||||||
// subtracting pointers.
|
case AF_INET:
|
||||||
hostport_size = (int)(c - workbuf);
|
sai4->sin_family = (sa_family_t)af;
|
||||||
|
|
||||||
// Fill in the 'out' information.
|
|
||||||
if( af == AF_INET ) {
|
|
||||||
sai4->sin_family = AF_INET;
|
|
||||||
sai4->sin_port = htons(port);
|
sai4->sin_port = htons(port);
|
||||||
ret = inet_pton(AF_INET, srvname, &sai4->sin_addr);
|
ret = inet_pton(AF_INET, srvname, &sai4->sin_addr);
|
||||||
}
|
break;
|
||||||
else if( af == AF_INET6 ) {
|
case AF_INET6:
|
||||||
sai6->sin6_family = AF_INET6;
|
sai6->sin6_family = (sa_family_t)af;
|
||||||
sai6->sin6_port = htons(port);
|
sai6->sin6_port = htons(port);
|
||||||
sai6->sin6_scope_id = gIF_INDEX;
|
sai6->sin6_scope_id = gIF_INDEX;
|
||||||
ret = inet_pton(AF_INET6, srvname, &sai6->sin6_addr);
|
ret = inet_pton(AF_INET6, srvname, &sai6->sin6_addr);
|
||||||
} else {
|
break;
|
||||||
// IP address was set by the hostname (getaddrinfo).
|
default:
|
||||||
// Override port:
|
/* IP address was set by the hostname (getaddrinfo). */
|
||||||
if( out->IPaddress.ss_family == AF_INET )
|
/* Override port: */
|
||||||
|
if (out->IPaddress.ss_family == (sa_family_t)AF_INET)
|
||||||
sai4->sin_port = htons(port);
|
sai4->sin_port = htons(port);
|
||||||
else
|
else
|
||||||
sai6->sin6_port = htons(port);
|
sai6->sin6_port = htons(port);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check if address was converted successfully. */
|
/* Check if address was converted successfully. */
|
||||||
if (ret <= 0) {
|
if (ret <= 0)
|
||||||
return UPNP_E_INVALID_URL;
|
return UPNP_E_INVALID_URL;
|
||||||
}
|
|
||||||
|
|
||||||
out->text.size = hostport_size;
|
out->text.size = hostport_size;
|
||||||
out->text.buff = in;
|
out->text.buff = in;
|
||||||
|
|
||||||
return hostport_size;
|
return (int)hostport_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@@ -480,29 +467,27 @@ int parse_hostport(
|
|||||||
*
|
*
|
||||||
* \return
|
* \return
|
||||||
*/
|
*/
|
||||||
static int parse_scheme(
|
static size_t parse_scheme(
|
||||||
/*! [in] String of characters representing a scheme. */
|
/*! [in] String of characters representing a scheme. */
|
||||||
const char *in,
|
const char *in,
|
||||||
/*! [in] Maximum number of characters. */
|
/*! [in] Maximum number of characters. */
|
||||||
int max,
|
size_t max,
|
||||||
/*! [out] Output parameter whose buffer is filled in with the scheme. */
|
/*! [out] Output parameter whose buffer is filled in with the scheme. */
|
||||||
token *out)
|
token *out)
|
||||||
{
|
{
|
||||||
int i = 0;
|
size_t i = (size_t)0;
|
||||||
|
|
||||||
out->size = 0;
|
out->size = (size_t)0;
|
||||||
out->buff = NULL;
|
out->buff = NULL;
|
||||||
|
|
||||||
if( ( max == 0 ) || ( !isalpha( in[0] ) ) )
|
if( ( max == (size_t)0 ) || ( !isalpha( in[0] ) ) )
|
||||||
return FALSE;
|
return (size_t)0;
|
||||||
|
|
||||||
i++;
|
i++;
|
||||||
while( ( i < max ) && ( in[i] != ':' ) ) {
|
while( ( i < max ) && ( in[i] != ':' ) ) {
|
||||||
|
|
||||||
if( !( isalnum( in[i] ) || ( in[i] == '+' ) || ( in[i] == '-' )
|
if( !( isalnum( in[i] ) || ( in[i] == '+' ) || ( in[i] == '-' )
|
||||||
|| ( in[i] == '.' ) ) )
|
|| ( in[i] == '.' ) ) )
|
||||||
return FALSE;
|
return (size_t)0;
|
||||||
|
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
if( i < max ) {
|
if( i < max ) {
|
||||||
@@ -511,18 +496,18 @@ static int parse_scheme(
|
|||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE;
|
return (size_t)0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int remove_escaped_chars(INOUT char *in, INOUT size_t *size )
|
int remove_escaped_chars(INOUT char *in, INOUT size_t *size)
|
||||||
{
|
{
|
||||||
int i = 0;
|
size_t i = (size_t)0;
|
||||||
|
|
||||||
for( i = 0; i < *size; i++ ) {
|
for (i = (size_t)0; i < *size; i++) {
|
||||||
replace_escaped( in, i, size );
|
replace_escaped(in, i, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
return UPNP_E_SUCCESS;
|
return UPNP_E_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -562,7 +547,7 @@ int remove_dots(char *in, size_t size)
|
|||||||
copyTo = Segments[--lastSegment];
|
copyTo = Segments[--lastSegment];
|
||||||
} else {
|
} else {
|
||||||
free( Segments );
|
free( Segments );
|
||||||
//TRACE("ERROR RESOLVING URL, ../ at ROOT");
|
/*TRACE("ERROR RESOLVING URL, ../ at ROOT"); */
|
||||||
return UPNP_E_INVALID_URL;
|
return UPNP_E_INVALID_URL;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
@@ -597,20 +582,17 @@ char *resolve_rel_url(char *base_url, char *rel_url)
|
|||||||
{
|
{
|
||||||
uri_type base;
|
uri_type base;
|
||||||
uri_type rel;
|
uri_type rel;
|
||||||
char temp_path = '/';
|
|
||||||
|
|
||||||
int i = 0;
|
size_t i = (size_t)0;
|
||||||
char *finger = NULL;
|
char *finger = NULL;
|
||||||
|
|
||||||
char *last_slash = NULL;
|
char *last_slash = NULL;
|
||||||
|
|
||||||
char *out = NULL;
|
char *out = NULL;
|
||||||
char *out_finger = NULL;
|
|
||||||
|
|
||||||
if( base_url && rel_url ) {
|
if( base_url && rel_url ) {
|
||||||
out =
|
out =
|
||||||
( char * )malloc( strlen( base_url ) + strlen( rel_url ) + 2 );
|
( char * )malloc( strlen( base_url ) + strlen( rel_url ) + (size_t)2 );
|
||||||
out_finger = out;
|
|
||||||
} else {
|
} else {
|
||||||
if( rel_url )
|
if( rel_url )
|
||||||
return strdup( rel_url );
|
return strdup( rel_url );
|
||||||
@@ -621,51 +603,59 @@ char *resolve_rel_url(char *base_url, char *rel_url)
|
|||||||
if( out == NULL ) {
|
if( out == NULL ) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
memset( out, 0, strlen( base_url ) + strlen( rel_url ) + (size_t)2 );
|
||||||
|
|
||||||
if( ( parse_uri( rel_url, strlen( rel_url ), &rel ) ) == HTTP_SUCCESS ) {
|
if( ( parse_uri( rel_url, strlen( rel_url ), &rel ) ) == HTTP_SUCCESS ) {
|
||||||
|
|
||||||
if( rel.type == ABSOLUTE ) {
|
if( rel.type == ( enum uriType) ABSOLUTE ) {
|
||||||
|
|
||||||
strcpy( out, rel_url );
|
strncpy( out, rel_url, strlen ( rel_url ) );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
if( ( parse_uri( base_url, strlen( base_url ), &base ) ==
|
if( ( parse_uri( base_url, strlen( base_url ), &base ) ==
|
||||||
HTTP_SUCCESS )
|
HTTP_SUCCESS )
|
||||||
&& ( base.type == ABSOLUTE ) ) {
|
&& ( base.type == ( enum uriType ) ABSOLUTE ) ) {
|
||||||
|
|
||||||
if( strlen( rel_url ) == 0 ) {
|
if( strlen( rel_url ) == (size_t)0 ) {
|
||||||
strcpy( out, base_url );
|
strncpy( out, base_url, strlen ( base_url ) );
|
||||||
} else {
|
} else {
|
||||||
|
char *out_finger = out;
|
||||||
|
assert( base.scheme.size + (size_t)1 /* ':' */ <= strlen ( base_url ) );
|
||||||
memcpy( out, base.scheme.buff, base.scheme.size );
|
memcpy( out, base.scheme.buff, base.scheme.size );
|
||||||
out_finger += base.scheme.size;
|
out_finger += base.scheme.size;
|
||||||
( *out_finger ) = ':';
|
( *out_finger ) = ':';
|
||||||
out_finger++;
|
out_finger++;
|
||||||
|
|
||||||
if( rel.hostport.text.size > 0 ) {
|
if( rel.hostport.text.size > (size_t)0 ) {
|
||||||
sprintf( out_finger, "%s", rel_url );
|
snprintf( out_finger, strlen( rel_url ) + (size_t)1,
|
||||||
|
"%s", rel_url );
|
||||||
} else {
|
} else {
|
||||||
if( base.hostport.text.size > 0 ) {
|
if( base.hostport.text.size > (size_t)0 ) {
|
||||||
memcpy( out_finger, "//", 2 );
|
assert( base.scheme.size + (size_t)1
|
||||||
|
+ base.hostport.text.size + (size_t)2 /* "//" */ <= strlen ( base_url ) );
|
||||||
|
memcpy( out_finger, "//", (size_t)2 );
|
||||||
out_finger += 2;
|
out_finger += 2;
|
||||||
memcpy( out_finger, base.hostport.text.buff,
|
memcpy( out_finger, base.hostport.text.buff,
|
||||||
base.hostport.text.size );
|
base.hostport.text.size );
|
||||||
out_finger += base.hostport.text.size;
|
out_finger += base.hostport.text.size;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( rel.path_type == ABS_PATH ) {
|
if( rel.path_type == ( enum pathType ) ABS_PATH ) {
|
||||||
strcpy( out_finger, rel_url );
|
strncpy( out_finger, rel_url, strlen ( rel_url ) );
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
char temp_path = '/';
|
||||||
|
|
||||||
if( base.pathquery.size == 0 ) {
|
if( base.pathquery.size == (size_t)0 ) {
|
||||||
base.pathquery.size = 1;
|
base.pathquery.size = (size_t)1;
|
||||||
base.pathquery.buff = &temp_path;
|
base.pathquery.buff = &temp_path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert( base.scheme.size + (size_t)1 + base.hostport.text.size + (size_t)2
|
||||||
|
+ base.pathquery.size <= strlen ( base_url ) + (size_t)1 /* temp_path */);
|
||||||
finger = out_finger;
|
finger = out_finger;
|
||||||
last_slash = finger;
|
last_slash = finger;
|
||||||
i = 0;
|
i = (size_t)0;
|
||||||
|
|
||||||
while( ( i < base.pathquery.size ) &&
|
while( ( i < base.pathquery.size ) &&
|
||||||
( base.pathquery.buff[i] != '?' ) ) {
|
( base.pathquery.buff[i] != '?' ) ) {
|
||||||
( *finger ) = base.pathquery.buff[i];
|
( *finger ) = base.pathquery.buff[i];
|
||||||
@@ -675,8 +665,7 @@ char *resolve_rel_url(char *base_url, char *rel_url)
|
|||||||
finger++;
|
finger++;
|
||||||
|
|
||||||
}
|
}
|
||||||
i = 0;
|
strncpy( last_slash, rel_url, strlen ( rel_url ) );
|
||||||
strcpy( last_slash, rel_url );
|
|
||||||
if( remove_dots( out_finger,
|
if( remove_dots( out_finger,
|
||||||
strlen( out_finger ) ) !=
|
strlen( out_finger ) ) !=
|
||||||
UPNP_E_SUCCESS ) {
|
UPNP_E_SUCCESS ) {
|
||||||
@@ -705,13 +694,14 @@ char *resolve_rel_url(char *base_url, char *rel_url)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int parse_uri(const char *in, int max, uri_type *out)
|
int parse_uri(const char *in, size_t max, uri_type *out)
|
||||||
{
|
{
|
||||||
int begin_path = 0;
|
int begin_path = 0;
|
||||||
int begin_hostport = 0;
|
size_t begin_hostport = (size_t)0;
|
||||||
int begin_fragment = 0;
|
size_t begin_fragment = (size_t)0;
|
||||||
|
|
||||||
if( ( begin_hostport = parse_scheme( in, max, &out->scheme ) ) ) {
|
begin_hostport = parse_scheme(in, max, &out->scheme);
|
||||||
|
if (begin_hostport) {
|
||||||
out->type = ABSOLUTE;
|
out->type = ABSOLUTE;
|
||||||
out->path_type = OPAQUE_PART;
|
out->path_type = OPAQUE_PART;
|
||||||
begin_hostport++;
|
begin_hostport++;
|
||||||
@@ -719,44 +709,39 @@ int parse_uri(const char *in, int max, uri_type *out)
|
|||||||
out->type = RELATIVE;
|
out->type = RELATIVE;
|
||||||
out->path_type = REL_PATH;
|
out->path_type = REL_PATH;
|
||||||
}
|
}
|
||||||
|
if (begin_hostport + (size_t)1 < max &&
|
||||||
if( ( ( begin_hostport + 1 ) < max ) && ( in[begin_hostport] == '/' )
|
in[begin_hostport] == '/' &&
|
||||||
&& ( in[begin_hostport + 1] == '/' ) ) {
|
in[begin_hostport + (size_t)1] == '/') {
|
||||||
begin_hostport += 2;
|
begin_hostport += (size_t)2;
|
||||||
|
begin_path = parse_hostport(&in[begin_hostport],
|
||||||
if( ( begin_path = parse_hostport( &in[begin_hostport],
|
&out->hostport);
|
||||||
max - begin_hostport,
|
if (begin_path >= 0) {
|
||||||
&out->hostport ) ) >= 0 ) {
|
begin_path += (int)begin_hostport;
|
||||||
begin_path += begin_hostport;
|
|
||||||
} else
|
} else
|
||||||
return begin_path;
|
return begin_path;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
memset( &out->hostport, 0, sizeof(out->hostport) );
|
memset(&out->hostport, 0, sizeof(out->hostport));
|
||||||
begin_path = begin_hostport;
|
begin_path = (int)begin_hostport;
|
||||||
}
|
}
|
||||||
|
begin_fragment = parse_uric(&in[begin_path],
|
||||||
begin_fragment =
|
max - (size_t)begin_path,
|
||||||
parse_uric( &in[begin_path], max - begin_path,
|
&out->pathquery) + (size_t)begin_path;
|
||||||
&out->pathquery ) + begin_path;
|
if (out->pathquery.size && out->pathquery.buff[0] == '/') {
|
||||||
|
|
||||||
if( ( out->pathquery.size ) && ( out->pathquery.buff[0] == '/' ) ) {
|
|
||||||
out->path_type = ABS_PATH;
|
out->path_type = ABS_PATH;
|
||||||
}
|
}
|
||||||
|
if (begin_fragment < max && in[begin_fragment] == '#') {
|
||||||
if( ( begin_fragment < max ) && ( in[begin_fragment] == '#' ) ) {
|
|
||||||
begin_fragment++;
|
begin_fragment++;
|
||||||
parse_uric( &in[begin_fragment], max - begin_fragment,
|
parse_uric(&in[begin_fragment], max - begin_fragment,
|
||||||
&out->fragment );
|
&out->fragment);
|
||||||
} else {
|
} else {
|
||||||
out->fragment.buff = NULL;
|
out->fragment.buff = NULL;
|
||||||
out->fragment.size = 0;
|
out->fragment.size = (size_t)0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return HTTP_SUCCESS;
|
return HTTP_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int parse_uri_and_unescape(char *in, size_t max, uri_type *out)
|
||||||
int parse_uri_and_unescape(char *in, int max, uri_type *out)
|
|
||||||
{
|
{
|
||||||
int ret = parse_uri(in, max, out);
|
int ret = parse_uri(in, max, out);
|
||||||
|
|
||||||
@@ -764,10 +749,10 @@ int parse_uri_and_unescape(char *in, int max, uri_type *out)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (out->pathquery.size > 0) {
|
if (out->pathquery.size > (size_t)0) {
|
||||||
remove_escaped_chars((char *)out->pathquery.buff, &out->pathquery.size);
|
remove_escaped_chars((char *)out->pathquery.buff, &out->pathquery.size);
|
||||||
}
|
}
|
||||||
if (out->fragment.size > 0) {
|
if (out->fragment.size > (size_t)0) {
|
||||||
remove_escaped_chars((char *)out->fragment.buff, &out->fragment.size);
|
remove_escaped_chars((char *)out->fragment.buff, &out->fragment.size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -42,6 +43,7 @@
|
|||||||
|
|
||||||
#ifdef INCLUDE_DEVICE_APIS
|
#ifdef INCLUDE_DEVICE_APIS
|
||||||
|
|
||||||
|
#if EXCLUDE_GENA == 0
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function : copy_subscription
|
* Function : copy_subscription
|
||||||
*
|
*
|
||||||
@@ -52,7 +54,7 @@
|
|||||||
* Description : Makes a copy of the subscription
|
* Description : Makes a copy of the subscription
|
||||||
*
|
*
|
||||||
* Return : int ;
|
* Return : int ;
|
||||||
* HTTP_SUCCESS - On Sucess
|
* HTTP_SUCCESS - On success
|
||||||
*
|
*
|
||||||
* Note :
|
* Note :
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
@@ -135,7 +137,7 @@ subscription *GetSubscriptionSID(const Upnp_SID sid, service_info *service)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if( found ) {
|
if( found ) {
|
||||||
//get the current_time
|
/*get the current_time */
|
||||||
time( ¤t_time );
|
time( ¤t_time );
|
||||||
if( ( found->expireTime != 0 )
|
if( ( found->expireTime != 0 )
|
||||||
&& ( found->expireTime < current_time ) ) {
|
&& ( found->expireTime < current_time ) ) {
|
||||||
@@ -161,7 +163,7 @@ subscription *GetNextSubscription(service_info *service, subscription *current)
|
|||||||
subscription *previous = NULL;
|
subscription *previous = NULL;
|
||||||
int notDone = 1;
|
int notDone = 1;
|
||||||
|
|
||||||
// get the current_time
|
/* get the current_time */
|
||||||
time( ¤t_time );
|
time( ¤t_time );
|
||||||
while( ( notDone ) && ( current ) ) {
|
while( ( notDone ) && ( current ) ) {
|
||||||
previous = current;
|
previous = current;
|
||||||
@@ -195,7 +197,7 @@ subscription *GetFirstSubscription(service_info *service)
|
|||||||
temp.next = service->subscriptionList;
|
temp.next = service->subscriptionList;
|
||||||
next = GetNextSubscription(service, &temp);
|
next = GetNextSubscription(service, &temp);
|
||||||
service->subscriptionList = temp.next;
|
service->subscriptionList = temp.next;
|
||||||
// service->subscriptionList = next;
|
/* service->subscriptionList = next; */
|
||||||
|
|
||||||
return next;
|
return next;
|
||||||
}
|
}
|
||||||
@@ -321,6 +323,7 @@ FindServiceEventURLPath( service_table * table,
|
|||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
#endif /* EXCLUDE_GENA */
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function : FindServiceControlURLPath
|
* Function : FindServiceControlURLPath
|
||||||
@@ -338,6 +341,7 @@ FindServiceEventURLPath( service_table * table,
|
|||||||
*
|
*
|
||||||
* Note :
|
* Note :
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
|
#if EXCLUDE_SOAP == 0
|
||||||
service_info *
|
service_info *
|
||||||
FindServiceControlURLPath( service_table * table,
|
FindServiceControlURLPath( service_table * table,
|
||||||
const char *controlURLPath )
|
const char *controlURLPath )
|
||||||
@@ -369,6 +373,7 @@ FindServiceControlURLPath( service_table * table,
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
#endif /* EXCLUDE_SOAP */
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function : printService
|
* Function : printService
|
||||||
@@ -514,6 +519,7 @@ void printServiceTable(
|
|||||||
printServiceList( table->serviceList, level, module );}
|
printServiceList( table->serviceList, level, module );}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if EXCLUDE_GENA == 0
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function : freeService
|
* Function : freeService
|
||||||
*
|
*
|
||||||
@@ -718,10 +724,10 @@ getSubElement( const char *element_name,
|
|||||||
*
|
*
|
||||||
* Note :
|
* Note :
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
service_info *
|
service_info *getServiceList(
|
||||||
getServiceList( IXML_Node * node,
|
IXML_Node *node,
|
||||||
service_info ** end,
|
service_info **end,
|
||||||
char *URLBase )
|
char *URLBase)
|
||||||
{
|
{
|
||||||
IXML_Node *serviceList = NULL;
|
IXML_Node *serviceList = NULL;
|
||||||
IXML_Node *current_service = NULL;
|
IXML_Node *current_service = NULL;
|
||||||
@@ -737,43 +743,33 @@ getServiceList( IXML_Node * node,
|
|||||||
service_info *current = NULL;
|
service_info *current = NULL;
|
||||||
service_info *previous = NULL;
|
service_info *previous = NULL;
|
||||||
IXML_NodeList *serviceNodeList = NULL;
|
IXML_NodeList *serviceNodeList = NULL;
|
||||||
int NumOfServices = 0;
|
long unsigned int NumOfServices = 0lu;
|
||||||
int i = 0;
|
long unsigned int i = 0lu;
|
||||||
int fail = 0;
|
int fail = 0;
|
||||||
|
|
||||||
if( getSubElement( "UDN", node, &UDN ) &&
|
if (getSubElement("UDN", node, &UDN) &&
|
||||||
getSubElement( "serviceList", node, &serviceList ) ) {
|
getSubElement("serviceList", node, &serviceList)) {
|
||||||
|
serviceNodeList = ixmlElement_getElementsByTagName(
|
||||||
serviceNodeList = ixmlElement_getElementsByTagName( ( IXML_Element
|
(IXML_Element *)serviceList, "service");
|
||||||
* )
|
if (serviceNodeList != NULL) {
|
||||||
serviceList,
|
NumOfServices = ixmlNodeList_length(serviceNodeList);
|
||||||
"service" );
|
for (i = 0lu; i < NumOfServices; i++) {
|
||||||
|
current_service =
|
||||||
if( serviceNodeList != NULL ) {
|
ixmlNodeList_item(serviceNodeList, i);
|
||||||
NumOfServices = ixmlNodeList_length( serviceNodeList );
|
|
||||||
for( i = 0; i < NumOfServices; i++ ) {
|
|
||||||
current_service = ixmlNodeList_item( serviceNodeList, i );
|
|
||||||
fail = 0;
|
fail = 0;
|
||||||
|
if (current) {
|
||||||
if( current ) {
|
current->next = malloc(sizeof(service_info));
|
||||||
current->next =
|
|
||||||
( service_info * )
|
|
||||||
malloc( sizeof( service_info ) );
|
|
||||||
|
|
||||||
previous = current;
|
previous = current;
|
||||||
current = current->next;
|
current = current->next;
|
||||||
} else {
|
} else {
|
||||||
head =
|
head = malloc(sizeof(service_info));
|
||||||
( service_info * )
|
|
||||||
malloc( sizeof( service_info ) );
|
|
||||||
current = head;
|
current = head;
|
||||||
}
|
}
|
||||||
|
if (!current) {
|
||||||
if( !current ) {
|
freeServiceList(head);
|
||||||
freeServiceList( head );
|
ixmlNodeList_free(serviceNodeList);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
current->next = NULL;
|
current->next = NULL;
|
||||||
current->controlURL = NULL;
|
current->controlURL = NULL;
|
||||||
current->eventURL = NULL;
|
current->eventURL = NULL;
|
||||||
@@ -783,99 +779,65 @@ getServiceList( IXML_Node * node,
|
|||||||
current->active = 1;
|
current->active = 1;
|
||||||
current->subscriptionList = NULL;
|
current->subscriptionList = NULL;
|
||||||
current->TotalSubscriptions = 0;
|
current->TotalSubscriptions = 0;
|
||||||
|
if (!(current->UDN = getElementValue(UDN)))
|
||||||
if( !( current->UDN = getElementValue( UDN ) ) )
|
|
||||||
fail = 1;
|
fail = 1;
|
||||||
|
if (!getSubElement("serviceType", current_service, &serviceType) ||
|
||||||
if( ( !getSubElement( "serviceType", current_service,
|
!(current->serviceType = getElementValue(serviceType)))
|
||||||
&serviceType ) ) ||
|
|
||||||
( !( current->serviceType =
|
|
||||||
getElementValue( serviceType ) ) ) )
|
|
||||||
fail = 1;
|
fail = 1;
|
||||||
|
if (!getSubElement("serviceId", current_service, &serviceId) ||
|
||||||
if( ( !getSubElement( "serviceId", current_service,
|
!(current->serviceId = getElementValue(serviceId)))
|
||||||
&serviceId ) ) ||
|
|
||||||
( !
|
|
||||||
( current->serviceId =
|
|
||||||
getElementValue( serviceId ) ) ) )
|
|
||||||
fail = 1;
|
fail = 1;
|
||||||
|
if (!getSubElement("SCPDURL", current_service, &SCPDURL) ||
|
||||||
if( ( !
|
!(tempDOMString = getElementValue(SCPDURL)) ||
|
||||||
( getSubElement
|
!(current->SCPDURL = resolve_rel_url(URLBase, tempDOMString)))
|
||||||
( "SCPDURL", current_service, &SCPDURL ) ) )
|
|
||||||
|| ( !( tempDOMString = getElementValue( SCPDURL ) ) )
|
|
||||||
||
|
|
||||||
( !
|
|
||||||
( current->SCPDURL =
|
|
||||||
resolve_rel_url( URLBase, tempDOMString ) ) ) )
|
|
||||||
fail = 1;
|
fail = 1;
|
||||||
|
ixmlFreeDOMString(tempDOMString);
|
||||||
ixmlFreeDOMString( tempDOMString );
|
|
||||||
tempDOMString = NULL;
|
tempDOMString = NULL;
|
||||||
|
if (!(getSubElement("controlURL", current_service, &controlURL)) ||
|
||||||
if( ( !
|
!(tempDOMString = getElementValue(controlURL)) ||
|
||||||
( getSubElement
|
!(current->controlURL = resolve_rel_url(URLBase, tempDOMString))) {
|
||||||
( "controlURL", current_service, &controlURL ) ) )
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__,
|
||||||
||
|
__LINE__,
|
||||||
( !( tempDOMString = getElementValue( controlURL ) ) )
|
"BAD OR MISSING CONTROL URL");
|
||||||
||
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__,
|
||||||
( !
|
__LINE__,
|
||||||
( current->controlURL =
|
"CONTROL URL SET TO NULL IN SERVICE INFO");
|
||||||
resolve_rel_url( URLBase, tempDOMString ) ) ) ) {
|
|
||||||
UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__,
|
|
||||||
"BAD OR MISSING CONTROL URL" );
|
|
||||||
UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__,
|
|
||||||
"CONTROL URL SET TO NULL IN SERVICE INFO" );
|
|
||||||
current->controlURL = NULL;
|
current->controlURL = NULL;
|
||||||
fail = 0;
|
fail = 0;
|
||||||
}
|
}
|
||||||
|
ixmlFreeDOMString(tempDOMString);
|
||||||
ixmlFreeDOMString( tempDOMString );
|
|
||||||
tempDOMString = NULL;
|
tempDOMString = NULL;
|
||||||
|
if (!getSubElement("eventSubURL", current_service, &eventURL) ||
|
||||||
if( ( !
|
!(tempDOMString = getElementValue(eventURL)) ||
|
||||||
( getSubElement
|
!(current->eventURL = resolve_rel_url(URLBase, tempDOMString))) {
|
||||||
( "eventSubURL", current_service, &eventURL ) ) )
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__,
|
||||||
|| ( !( tempDOMString = getElementValue( eventURL ) ) )
|
__LINE__,
|
||||||
||
|
"BAD OR MISSING EVENT URL");
|
||||||
( !
|
UpnpPrintf(UPNP_INFO, GENA, __FILE__,
|
||||||
( current->eventURL =
|
__LINE__,
|
||||||
resolve_rel_url( URLBase, tempDOMString ) ) ) ) {
|
"EVENT URL SET TO NULL IN SERVICE INFO");
|
||||||
UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__,
|
|
||||||
"BAD OR MISSING EVENT URL" );
|
|
||||||
UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__,
|
|
||||||
"EVENT URL SET TO NULL IN SERVICE INFO" );
|
|
||||||
current->eventURL = NULL;
|
current->eventURL = NULL;
|
||||||
fail = 0;
|
fail = 0;
|
||||||
}
|
}
|
||||||
|
ixmlFreeDOMString(tempDOMString);
|
||||||
ixmlFreeDOMString( tempDOMString );
|
|
||||||
tempDOMString = NULL;
|
tempDOMString = NULL;
|
||||||
|
if (fail) {
|
||||||
if( fail ) {
|
freeServiceList(current);
|
||||||
freeServiceList( current );
|
if (previous)
|
||||||
|
|
||||||
if( previous )
|
|
||||||
previous->next = NULL;
|
previous->next = NULL;
|
||||||
else
|
else
|
||||||
head = NULL;
|
head = NULL;
|
||||||
|
|
||||||
current = previous;
|
current = previous;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
ixmlNodeList_free(serviceNodeList);
|
||||||
ixmlNodeList_free( serviceNodeList );
|
|
||||||
}
|
}
|
||||||
|
(*end) = current;
|
||||||
( *end ) = current;
|
|
||||||
|
|
||||||
return head;
|
return head;
|
||||||
} else {
|
} else {
|
||||||
( *end ) = NULL;
|
(*end) = NULL;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
@@ -905,32 +867,30 @@ getAllServiceList( IXML_Node * node,
|
|||||||
IXML_NodeList *deviceList = NULL;
|
IXML_NodeList *deviceList = NULL;
|
||||||
IXML_Node *currentDevice = NULL;
|
IXML_Node *currentDevice = NULL;
|
||||||
|
|
||||||
int NumOfDevices = 0;
|
long unsigned int NumOfDevices = 0lu;
|
||||||
int i = 0;
|
long unsigned int i = 0lu;
|
||||||
|
|
||||||
( *out_end ) = NULL;
|
(*out_end) = NULL;
|
||||||
|
|
||||||
deviceList =
|
deviceList = ixmlElement_getElementsByTagName(
|
||||||
ixmlElement_getElementsByTagName( ( IXML_Element * ) node,
|
(IXML_Element *)node, "device");
|
||||||
"device" );
|
if (deviceList) {
|
||||||
if( deviceList != NULL ) {
|
NumOfDevices = ixmlNodeList_length(deviceList);
|
||||||
NumOfDevices = ixmlNodeList_length( deviceList );
|
for (i = 0lu; i < NumOfDevices; i++) {
|
||||||
for( i = 0; i < NumOfDevices; i++ ) {
|
currentDevice = ixmlNodeList_item(deviceList, i);
|
||||||
currentDevice = ixmlNodeList_item( deviceList, i );
|
if (head) {
|
||||||
if( head ) {
|
end->next = getServiceList(currentDevice,
|
||||||
end->next =
|
&next_end, URLBase);
|
||||||
getServiceList( currentDevice, &next_end, URLBase );
|
if (next_end)
|
||||||
if ( next_end )
|
|
||||||
end = next_end;
|
end = next_end;
|
||||||
} else
|
} else
|
||||||
head = getServiceList( currentDevice, &end, URLBase );
|
head = getServiceList(currentDevice, &end,
|
||||||
|
URLBase);
|
||||||
|
}
|
||||||
|
ixmlNodeList_free(deviceList);
|
||||||
}
|
}
|
||||||
|
|
||||||
ixmlNodeList_free( deviceList );
|
(*out_end) = end;
|
||||||
}
|
|
||||||
|
|
||||||
( *out_end ) = end;
|
|
||||||
return head;
|
return head;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -959,12 +919,11 @@ removeServiceTable( IXML_Node * node,
|
|||||||
IXML_Node *currentUDN = NULL;
|
IXML_Node *currentUDN = NULL;
|
||||||
DOMString UDN = NULL;
|
DOMString UDN = NULL;
|
||||||
IXML_NodeList *deviceList = NULL;
|
IXML_NodeList *deviceList = NULL;
|
||||||
IXML_Node *currentDevice = NULL;
|
|
||||||
service_info *current_service = NULL;
|
service_info *current_service = NULL;
|
||||||
service_info *start_search = NULL;
|
service_info *start_search = NULL;
|
||||||
service_info *prev_service = NULL;
|
service_info *prev_service = NULL;
|
||||||
int NumOfDevices = 0;
|
long unsigned int NumOfDevices = 0lu;
|
||||||
int i = 0;
|
long unsigned int i = 0lu;
|
||||||
|
|
||||||
if( getSubElement( "root", node, &root ) ) {
|
if( getSubElement( "root", node, &root ) ) {
|
||||||
current_service = in->serviceList;
|
current_service = in->serviceList;
|
||||||
@@ -974,18 +933,18 @@ removeServiceTable( IXML_Node * node,
|
|||||||
"device" );
|
"device" );
|
||||||
if( deviceList != NULL ) {
|
if( deviceList != NULL ) {
|
||||||
NumOfDevices = ixmlNodeList_length( deviceList );
|
NumOfDevices = ixmlNodeList_length( deviceList );
|
||||||
for( i = 0; i < NumOfDevices; i++ ) {
|
for( i = 0lu; i < NumOfDevices; i++ ) {
|
||||||
currentDevice = ixmlNodeList_item( deviceList, i );
|
|
||||||
if( ( start_search )
|
if( ( start_search )
|
||||||
&& ( ( getSubElement( "UDN", node, ¤tUDN ) )
|
&& ( ( getSubElement( "UDN", node, ¤tUDN ) )
|
||||||
&& ( UDN = getElementValue( currentUDN ) ) ) ) {
|
&& ( UDN = getElementValue( currentUDN ) ) ) ) {
|
||||||
current_service = start_search;
|
current_service = start_search;
|
||||||
//Services are put in the service table in the order in which they appear in the
|
/*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
|
/*description document, therefore we go through the list only once to remove a particular */
|
||||||
//root device
|
/*root device */
|
||||||
while( ( current_service )
|
while( ( current_service )
|
||||||
&& ( strcmp( current_service->UDN, UDN ) ) ) {
|
&& ( strcmp( current_service->UDN, UDN ) ) ) {
|
||||||
current_service = current_service->next;
|
current_service = current_service->next;
|
||||||
|
if( current_service != NULL)
|
||||||
prev_service = current_service->next;
|
prev_service = current_service->next;
|
||||||
}
|
}
|
||||||
while( ( current_service )
|
while( ( current_service )
|
||||||
@@ -1001,6 +960,8 @@ removeServiceTable( IXML_Node * node,
|
|||||||
freeService( current_service );
|
freeService( current_service );
|
||||||
current_service = start_search;
|
current_service = start_search;
|
||||||
}
|
}
|
||||||
|
ixmlFreeDOMString( UDN );
|
||||||
|
UDN = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1107,5 +1068,7 @@ getServiceTable( IXML_Node * node,
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif /* EXCLUDE_GENA */
|
||||||
|
|
||||||
|
#endif /* INCLUDE_DEVICE_APIS */
|
||||||
|
|
||||||
#endif // INCLUDE_DEVICE_APIS
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,551 +30,265 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/************************************************************************
|
/*
|
||||||
* Purpose: This file contains functions that operate on memory and
|
* \file
|
||||||
* buffers, allocation, re-allocation, and modification of the memory
|
*
|
||||||
************************************************************************/
|
* \brief This file contains functions that operate on memory and buffers,
|
||||||
|
* allocation, re-allocation, and modification of the memory
|
||||||
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <membuffer.h>
|
#include "membuffer.h"
|
||||||
#include "upnp.h"
|
#include "upnp.h"
|
||||||
#include "unixutil.h"
|
#include "unixutil.h"
|
||||||
|
|
||||||
/************************************************************************
|
char *str_alloc(const char *str, size_t str_len)
|
||||||
* string *
|
|
||||||
************************************************************************/
|
|
||||||
|
|
||||||
/************************************************************************
|
|
||||||
* Function : str_alloc
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* IN const char* str ; input string object
|
|
||||||
* IN size_t str_len ; input string length
|
|
||||||
*
|
|
||||||
* Description : Allocate memory and copy information from the input
|
|
||||||
* string to the newly allocated memory.
|
|
||||||
*
|
|
||||||
* Return : char* ;
|
|
||||||
* Pointer to the newly allocated memory.
|
|
||||||
* NULL if memory cannot be allocated.
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
char *
|
|
||||||
str_alloc( IN const char *str,
|
|
||||||
IN size_t str_len )
|
|
||||||
{
|
{
|
||||||
char *s;
|
char *s;
|
||||||
|
|
||||||
s = ( char * )malloc( str_len + 1 );
|
s = (char *)malloc(str_len + (size_t)1);
|
||||||
if( s == NULL ) {
|
if (s == NULL) {
|
||||||
return NULL; // no mem
|
return NULL; /* no mem */
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy( s, str, str_len );
|
memcpy(s, str, str_len);
|
||||||
s[str_len] = '\0';
|
s[str_len] = '\0';
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int memptr_cmp(memptr * m, const char *s)
|
||||||
* memptr *
|
|
||||||
************************************************************************/
|
|
||||||
|
|
||||||
/************************************************************************
|
|
||||||
* Function : memptr_cmp
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* IN memptr* m ; input memory object
|
|
||||||
* IN const char* s ; constatnt string for the memory object to be
|
|
||||||
* compared with
|
|
||||||
*
|
|
||||||
* Description : Compares characters of strings passed for number of
|
|
||||||
* bytes. If equal for the number of bytes, the length of the bytes
|
|
||||||
* determines which buffer is shorter.
|
|
||||||
*
|
|
||||||
* Return : int ;
|
|
||||||
* < 0 string1 substring less than string2 substring
|
|
||||||
* 0 string1 substring identical to string2 substring
|
|
||||||
* > 0 string1 substring greater than string2 substring
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
int
|
|
||||||
memptr_cmp( IN memptr * m,
|
|
||||||
IN const char *s )
|
|
||||||
{
|
{
|
||||||
int cmp;
|
int cmp;
|
||||||
|
|
||||||
cmp = strncmp( m->buf, s, m->length );
|
cmp = strncmp(m->buf, s, m->length);
|
||||||
|
|
||||||
if( cmp == 0 && m->length < strlen( s ) ) {
|
if (cmp == 0 && m->length < strlen(s)) {
|
||||||
// both strings equal for 'm->length' chars
|
/* both strings equal for 'm->length' chars */
|
||||||
// if m is shorter than s, then s is greater
|
/* if m is shorter than s, then s is greater */
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return cmp;
|
return cmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int memptr_cmp_nocase(memptr * m, const char *s)
|
||||||
* Function : memptr_cmp_nocase
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* IN memptr* m ; input memory object
|
|
||||||
* IN const char* s ; constatnt string for the memory object to be
|
|
||||||
* compared with
|
|
||||||
*
|
|
||||||
* Description : Compares characters of 2 strings irrespective of the
|
|
||||||
* case for a specific count of bytes If the character comparison
|
|
||||||
* is the same the length of the 2 srings determines the shorter
|
|
||||||
* of the 2 strings.
|
|
||||||
*
|
|
||||||
* Return : int ;
|
|
||||||
* < 0 string1 substring less than string2 substring
|
|
||||||
* 0 string1 substring identical to string2 substring
|
|
||||||
* > 0 string1 substring greater than string2 substring
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
int
|
|
||||||
memptr_cmp_nocase( IN memptr * m,
|
|
||||||
IN const char *s )
|
|
||||||
{
|
{
|
||||||
int cmp;
|
int cmp;
|
||||||
|
|
||||||
cmp = strncasecmp( m->buf, s, m->length );
|
cmp = strncasecmp(m->buf, s, m->length);
|
||||||
if( cmp == 0 && m->length < strlen( s ) ) {
|
if (cmp == 0 && m->length < strlen(s)) {
|
||||||
// both strings equal for 'm->length' chars
|
/* both strings equal for 'm->length' chars */
|
||||||
// if m is shorter than s, then s is greater
|
/* if m is shorter than s, then s is greater */
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return cmp;
|
return cmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
/*!
|
||||||
* membuffer *
|
* \brief Initialize the buffer.
|
||||||
************************************************************************/
|
*/
|
||||||
|
static UPNP_INLINE void membuffer_initialize(
|
||||||
/************************************************************************
|
/*! [in,out] Buffer to be initialized. */
|
||||||
* Function : membuffer_initialize
|
membuffer *m)
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer to be initialized
|
|
||||||
*
|
|
||||||
* Description : Initialize the buffer
|
|
||||||
*
|
|
||||||
* Return : void ;
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
static UPNP_INLINE void
|
|
||||||
membuffer_initialize( INOUT membuffer * m )
|
|
||||||
{
|
{
|
||||||
m->buf = NULL;
|
m->buf = NULL;
|
||||||
m->length = 0;
|
m->length = (size_t)0;
|
||||||
m->capacity = 0;
|
m->capacity = (size_t)0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int membuffer_set_size(membuffer *m, size_t new_length)
|
||||||
* Function : membuffer_set_size
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer whose size is to be modified
|
|
||||||
* IN size_t new_length ; new size to which the buffer will be
|
|
||||||
* modified
|
|
||||||
*
|
|
||||||
* Description : Increases or decreases buffer cap so that at least
|
|
||||||
* 'new_length' bytes can be stored
|
|
||||||
*
|
|
||||||
* Return : int ;
|
|
||||||
* UPNP_E_SUCCESS - On Success
|
|
||||||
* UPNP_E_OUTOF_MEMORY - On failure to allocate memory.
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
int
|
|
||||||
membuffer_set_size( INOUT membuffer * m,
|
|
||||||
IN size_t new_length )
|
|
||||||
{
|
{
|
||||||
size_t diff;
|
size_t diff;
|
||||||
size_t alloc_len;
|
size_t alloc_len;
|
||||||
char *temp_buf;
|
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) {
|
||||||
if( new_length <= m->capacity ) {
|
return 0; /* have enough mem; done */
|
||||||
return 0; // have enough mem; done
|
|
||||||
}
|
}
|
||||||
|
|
||||||
diff = new_length - m->length;
|
diff = new_length - m->length;
|
||||||
alloc_len = MAXVAL( m->size_inc, diff ) + m->capacity;
|
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
|
assert(new_length <= m->length);
|
||||||
if( ( m->capacity - new_length ) <= m->size_inc ) {
|
|
||||||
|
/* if diff is 0..m->size_inc, don't free */
|
||||||
|
if ((m->capacity - new_length) <= m->size_inc) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
alloc_len = new_length + m->size_inc;
|
alloc_len = new_length + m->size_inc;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert( alloc_len >= new_length );
|
assert(alloc_len >= new_length);
|
||||||
|
|
||||||
temp_buf = realloc( m->buf, alloc_len + 1 ); //LEAK_FIX_MK
|
temp_buf = realloc(m->buf, alloc_len + (size_t)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 ) {
|
if (temp_buf == NULL) {
|
||||||
// try smaller size
|
/* try smaller size */
|
||||||
alloc_len = new_length;
|
alloc_len = new_length;
|
||||||
temp_buf = realloc( m->buf, alloc_len + 1 ); //LEAK_FIX_MK
|
temp_buf = realloc(m->buf, alloc_len + (size_t)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 ) {
|
if (temp_buf == NULL) {
|
||||||
return UPNP_E_OUTOF_MEMORY;
|
return UPNP_E_OUTOF_MEMORY;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// save
|
/* save */
|
||||||
m->buf = temp_buf;
|
m->buf = temp_buf;
|
||||||
m->capacity = alloc_len;
|
m->capacity = alloc_len;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
void membuffer_init(membuffer *m)
|
||||||
* Function : membuffer_init
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer to be initialized
|
|
||||||
*
|
|
||||||
* Description : Wrapper to membuffer_initialize().
|
|
||||||
* Set the size of the buffer to MEMBUF_DEF_SIZE_INC
|
|
||||||
* Initializes m->buf to NULL, length=0
|
|
||||||
*
|
|
||||||
* Return : void ;
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
void
|
|
||||||
membuffer_init( INOUT membuffer * m )
|
|
||||||
{
|
{
|
||||||
assert( m != NULL );
|
assert(m != NULL);
|
||||||
|
|
||||||
m->size_inc = MEMBUF_DEF_SIZE_INC;
|
m->size_inc = MEMBUF_DEF_SIZE_INC;
|
||||||
membuffer_initialize( m );
|
membuffer_initialize(m);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
void membuffer_destroy(membuffer *m)
|
||||||
* Function : membuffer_destroy
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer to be destroyed
|
|
||||||
*
|
|
||||||
* Description : Free's memory allocated for membuffer* m.
|
|
||||||
*
|
|
||||||
* Return : void ;
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
void
|
|
||||||
membuffer_destroy( INOUT membuffer * m )
|
|
||||||
{
|
{
|
||||||
if( m == NULL ) {
|
if (m == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
free( m->buf );
|
free(m->buf);
|
||||||
membuffer_init( m );
|
membuffer_init(m);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int membuffer_assign(membuffer *m, const void *buf, size_t buf_len)
|
||||||
* Function : membuffer_assign
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer whose memory is to be allocated and
|
|
||||||
* assigned.
|
|
||||||
* IN const void* buf ; source buffer whose contents will be copied
|
|
||||||
* IN size_t buf_len ; length of the source buffer
|
|
||||||
*
|
|
||||||
* Description : Allocate memory to membuffer* m and copy the contents
|
|
||||||
* of the in parameter IN const void* buf.
|
|
||||||
*
|
|
||||||
* Return : int ;
|
|
||||||
* UPNP_E_SUCCESS
|
|
||||||
* UPNP_E_OUTOF_MEMORY
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
int
|
|
||||||
membuffer_assign( INOUT membuffer * m,
|
|
||||||
IN const void *buf,
|
|
||||||
IN size_t buf_len )
|
|
||||||
{
|
{
|
||||||
int return_code;
|
int return_code;
|
||||||
|
|
||||||
assert( m != NULL );
|
assert(m != NULL);
|
||||||
|
|
||||||
// set value to null
|
/* set value to null */
|
||||||
if( buf == NULL ) {
|
if (buf == NULL) {
|
||||||
membuffer_destroy( m );
|
membuffer_destroy(m);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
// alloc mem
|
/* alloc mem */
|
||||||
return_code = membuffer_set_size( m, buf_len );
|
return_code = membuffer_set_size(m, buf_len);
|
||||||
if( return_code != 0 ) {
|
if (return_code != 0)
|
||||||
return return_code;
|
return return_code;
|
||||||
}
|
/* copy */
|
||||||
// copy
|
if (buf_len) {
|
||||||
if( buf_len ) {
|
memcpy(m->buf, buf, 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;
|
m->length = buf_len;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int membuffer_assign_str(membuffer *m, const char *c_str)
|
||||||
* Function : membuffer_assign_str
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer to be allocated and assigned
|
|
||||||
* IN const char* c_str ; source buffer whose contents will be
|
|
||||||
* copied
|
|
||||||
*
|
|
||||||
* Description : Wrapper function for membuffer_assign()
|
|
||||||
*
|
|
||||||
* Return : int ;
|
|
||||||
* UPNP_E_SUCCESS
|
|
||||||
* UPNP_E_OUTOF_MEMORY
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
int
|
|
||||||
membuffer_assign_str( INOUT membuffer * m,
|
|
||||||
IN const char *c_str )
|
|
||||||
{
|
{
|
||||||
return membuffer_assign( m, c_str, strlen( c_str ) );
|
return membuffer_assign(m, c_str, strlen(c_str));
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int membuffer_append(membuffer *m, const void *buf, size_t buf_len)
|
||||||
* Function : membuffer_append
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer whose memory is to be appended.
|
|
||||||
* IN const void* buf ; source buffer whose contents will be
|
|
||||||
* copied
|
|
||||||
* IN size_t buf_len ; length of the source buffer
|
|
||||||
*
|
|
||||||
* Description : Invokes function to appends data from a constant buffer
|
|
||||||
* to the buffer
|
|
||||||
*
|
|
||||||
* Return : int ;
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
int
|
|
||||||
membuffer_append( INOUT membuffer * m,
|
|
||||||
IN const void *buf,
|
|
||||||
IN size_t buf_len )
|
|
||||||
{
|
{
|
||||||
assert( m != NULL );
|
assert(m != NULL);
|
||||||
|
|
||||||
return membuffer_insert( m, buf, buf_len, m->length );
|
return membuffer_insert(m, buf, buf_len, m->length);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int membuffer_append_str(membuffer *m, const char *c_str)
|
||||||
* Function : membuffer_append_str
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer whose memory is to be appended.
|
|
||||||
* IN const char* c_str ; source buffer whose contents will be
|
|
||||||
* copied
|
|
||||||
*
|
|
||||||
* Description : Invokes function to appends data from a constant string
|
|
||||||
* to the buffer
|
|
||||||
*
|
|
||||||
* Return : int ;
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
int
|
|
||||||
membuffer_append_str( INOUT membuffer * m,
|
|
||||||
IN const char *c_str )
|
|
||||||
{
|
{
|
||||||
return membuffer_insert( m, c_str, strlen( c_str ), m->length );
|
return membuffer_insert(m, c_str, strlen(c_str), m->length);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
int membuffer_insert(membuffer * m, const void *buf, size_t buf_len,
|
||||||
* Function : membuffer_insert
|
size_t index)
|
||||||
*
|
|
||||||
* 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;
|
int return_code;
|
||||||
|
|
||||||
assert( m != NULL );
|
assert(m != NULL);
|
||||||
|
|
||||||
if( index < 0 || index > ( int )m->length )
|
if (index > m->length)
|
||||||
return UPNP_E_OUTOF_BOUNDS;
|
return UPNP_E_OUTOF_BOUNDS;
|
||||||
|
if (!buf || !buf_len) {
|
||||||
if( buf == NULL || buf_len == 0 ) {
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
// alloc mem
|
/* alloc mem */
|
||||||
return_code = membuffer_set_size( m, m->length + buf_len );
|
return_code = membuffer_set_size(m, m->length + buf_len);
|
||||||
if( return_code != 0 ) {
|
if (return_code) {
|
||||||
return return_code;
|
return return_code;
|
||||||
}
|
}
|
||||||
// insert data
|
/* insert data */
|
||||||
|
/* move data to right of insertion point */
|
||||||
// move data to right of insertion point
|
memmove(m->buf + index + buf_len, m->buf + index, m->length - index);
|
||||||
memmove( m->buf + index + buf_len, m->buf + index, m->length - index );
|
memcpy(m->buf + index, buf, buf_len);
|
||||||
memcpy( m->buf + index, buf, buf_len );
|
|
||||||
m->length += buf_len;
|
m->length += buf_len;
|
||||||
m->buf[m->length] = 0; // null-terminate
|
/* null-terminate */
|
||||||
|
m->buf[m->length] = 0;
|
||||||
|
|
||||||
return 0;
|
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;
|
int return_value;
|
||||||
int new_length;
|
size_t new_length;
|
||||||
size_t copy_len;
|
size_t copy_len;
|
||||||
|
|
||||||
assert( m != NULL );
|
assert(m != NULL);
|
||||||
|
|
||||||
if (!m) return;
|
if (!m || !m->length)
|
||||||
|
|
||||||
if( m->length == 0 ) {
|
|
||||||
return;
|
return;
|
||||||
}
|
/* shrink count if it goes beyond buffer */
|
||||||
|
if (index + num_bytes > m->length) {
|
||||||
assert( index >= 0 && index < ( int )m->length );
|
num_bytes = m->length - index;
|
||||||
|
/* every thing at and after index purged */
|
||||||
// shrink count if it goes beyond buffer
|
copy_len = (size_t)0;
|
||||||
if( index + num_bytes > m->length ) {
|
|
||||||
num_bytes = m->length - ( size_t ) index;
|
|
||||||
copy_len = 0; // every thing at and after index purged
|
|
||||||
} else {
|
} else {
|
||||||
// calc num bytes after deleted string
|
/* calc num bytes after deleted string */
|
||||||
copy_len = m->length - ( index + num_bytes );
|
copy_len = m->length - (index + num_bytes);
|
||||||
}
|
}
|
||||||
|
memmove(m->buf + index, m->buf + index + num_bytes, copy_len);
|
||||||
memmove( m->buf + index, m->buf + index + num_bytes, copy_len );
|
|
||||||
|
|
||||||
new_length = m->length - num_bytes;
|
new_length = m->length - num_bytes;
|
||||||
return_value = membuffer_set_size( m, new_length ); // trim buffer
|
/* trim buffer */
|
||||||
assert( return_value == 0 ); // shrinking should always work
|
return_value = membuffer_set_size(m, new_length);
|
||||||
|
/* shrinking should always work */
|
||||||
|
assert(return_value == 0);
|
||||||
|
if (return_value != 0)
|
||||||
|
return;
|
||||||
|
|
||||||
// don't modify until buffer is set
|
/* don't modify until buffer is set */
|
||||||
m->length = new_length;
|
m->length = new_length;
|
||||||
m->buf[new_length] = 0;
|
m->buf[new_length] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
char *membuffer_detach(membuffer *m)
|
||||||
* Function : membuffer_detach
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer to be returned and updated.
|
|
||||||
*
|
|
||||||
* Description : Detaches current buffer and returns it. The caller
|
|
||||||
* must free the returned buffer using free().
|
|
||||||
* After this call, length becomes 0.
|
|
||||||
*
|
|
||||||
* Return : char* ;
|
|
||||||
* a pointer to the current buffer
|
|
||||||
*
|
|
||||||
* Note :
|
|
||||||
************************************************************************/
|
|
||||||
char *
|
|
||||||
membuffer_detach( INOUT membuffer * m )
|
|
||||||
{
|
{
|
||||||
char *buf;
|
char *buf;
|
||||||
|
|
||||||
assert( m != NULL );
|
assert(m != NULL);
|
||||||
|
|
||||||
buf = m->buf;
|
buf = m->buf;
|
||||||
|
|
||||||
// free all
|
/* free all */
|
||||||
membuffer_initialize( m );
|
membuffer_initialize(m);
|
||||||
|
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
void membuffer_attach(membuffer *m, char *new_buf, size_t buf_len)
|
||||||
* Function : membuffer_attach
|
|
||||||
*
|
|
||||||
* Parameters :
|
|
||||||
* INOUT membuffer* m ; buffer to be updated
|
|
||||||
* IN char* new_buf ; source buffer which will be assigned to the
|
|
||||||
* buffer to be updated
|
|
||||||
* IN size_t buf_len ; length of the source buffer
|
|
||||||
*
|
|
||||||
* Description : Free existing memory in membuffer and assign the new
|
|
||||||
* buffer in its place.
|
|
||||||
*
|
|
||||||
* Return : void ;
|
|
||||||
*
|
|
||||||
* Note : 'new_buf' must be allocted using malloc or realloc so
|
|
||||||
* that it can be freed using free()
|
|
||||||
************************************************************************/
|
|
||||||
void
|
|
||||||
membuffer_attach( INOUT membuffer * m,
|
|
||||||
IN char *new_buf,
|
|
||||||
IN size_t buf_len )
|
|
||||||
{
|
{
|
||||||
assert( m != NULL );
|
assert(m != NULL);
|
||||||
|
|
||||||
membuffer_destroy( m );
|
membuffer_destroy(m);
|
||||||
m->buf = new_buf;
|
m->buf = new_buf;
|
||||||
m->length = buf_len;
|
m->length = buf_len;
|
||||||
m->capacity = buf_len;
|
m->capacity = buf_len;
|
||||||
|
|||||||
@@ -1,33 +1,33 @@
|
|||||||
///////////////////////////////////////////////////////////////////////////
|
/*******************************************************************************
|
||||||
//
|
*
|
||||||
// Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
// All rights reserved.
|
* All rights reserved.
|
||||||
//
|
*
|
||||||
// Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
// modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
//
|
*
|
||||||
// * Redistributions of source code must retain the above copyright notice,
|
* - Redistributions of source code must retain the above copyright notice,
|
||||||
// this list of conditions and the following disclaimer.
|
* this list of conditions and the following disclaimer.
|
||||||
// * Redistributions in binary form must reproduce the above copyright notice,
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
// this list of conditions and the following disclaimer in the documentation
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
// and/or other materials provided with the distribution.
|
* and/or other materials provided with the distribution.
|
||||||
// * Neither name of Intel Corporation nor the names of its contributors
|
* - Neither name of Intel Corporation nor the names of its contributors
|
||||||
// may be used to endorse or promote products derived from this software
|
* may be used to endorse or promote products derived from this software
|
||||||
// without specific prior written permission.
|
* without specific prior written permission.
|
||||||
//
|
*
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
||||||
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
||||||
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
//
|
*
|
||||||
///////////////////////////////////////////////////////////////////////////
|
******************************************************************************/
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Purpose: This file contains string to integer and integer to string
|
* Purpose: This file contains string to integer and integer to string
|
||||||
@@ -48,7 +48,7 @@
|
|||||||
* matched.
|
* matched.
|
||||||
* IN int num_entries ; number of entries in the table that need
|
* IN int num_entries ; number of entries in the table that need
|
||||||
* to be searched.
|
* to be searched.
|
||||||
* IN xboolean case_sensitive ; whether the case should be case
|
* IN int case_sensitive ; whether the case should be case
|
||||||
* sensitive or not
|
* sensitive or not
|
||||||
*
|
*
|
||||||
* Description : Match the given name with names from the entries in the
|
* 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 size_t name_len,
|
||||||
IN str_int_entry * table,
|
IN str_int_entry * table,
|
||||||
IN int num_entries,
|
IN int num_entries,
|
||||||
IN xboolean case_sensitive )
|
IN int case_sensitive )
|
||||||
{
|
{
|
||||||
int top,
|
int top,
|
||||||
mid,
|
mid,
|
||||||
@@ -82,24 +82,24 @@ map_str_to_int( IN const char *name,
|
|||||||
while( top <= bot ) {
|
while( top <= bot ) {
|
||||||
mid = ( top + bot ) / 2;
|
mid = ( top + bot ) / 2;
|
||||||
if( case_sensitive ) {
|
if( case_sensitive ) {
|
||||||
//cmp = strcmp( name, table[mid].name );
|
/*cmp = strcmp( name, table[mid].name ); */
|
||||||
cmp = memptr_cmp( &name_ptr, table[mid].name );
|
cmp = memptr_cmp( &name_ptr, table[mid].name );
|
||||||
} else {
|
} else {
|
||||||
//cmp = strcasecmp( name, table[mid].name );
|
/*cmp = strcasecmp( name, table[mid].name ); */
|
||||||
cmp = memptr_cmp_nocase( &name_ptr, table[mid].name );
|
cmp = memptr_cmp_nocase( &name_ptr, table[mid].name );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( cmp > 0 ) {
|
if( cmp > 0 ) {
|
||||||
top = mid + 1; // look below mid
|
top = mid + 1; /* look below mid */
|
||||||
} else if( cmp < 0 ) {
|
} else if( cmp < 0 ) {
|
||||||
bot = mid - 1; // look above mid
|
bot = mid - 1; /* look above mid */
|
||||||
} else // cmp == 0
|
} 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 */
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,90 +30,39 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/************************************************************************
|
/*!
|
||||||
* Purpose: This file contains functions for copying strings based on
|
* \file
|
||||||
* different options.
|
*
|
||||||
************************************************************************/
|
* Purpose: This file contains functions for copying strings based on
|
||||||
|
* different options.
|
||||||
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "upnp.h"
|
#include "upnp.h"
|
||||||
#include "util.h"
|
#include "upnputil.h"
|
||||||
|
|
||||||
|
|
||||||
#include <string.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 );
|
strncpy(dest, src, LINE_SIZE - (size_t)1);
|
||||||
dest[LINE_SIZE - 1] = '\0'; // null-terminate if len(src) >= LINE_SIZE
|
/* null-terminate if len(src) >= LINE_SIZE. */
|
||||||
|
dest[LINE_SIZE - 1] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
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 );
|
strncpy(dest, src, NAME_SIZE - (size_t)1);
|
||||||
dest[NAME_SIZE - 1] = '\0'; // null-terminate if len(src) >= NAME_SIZE
|
/* null-terminate if len(src) >= NAME_SIZE. */
|
||||||
|
dest[NAME_SIZE - 1] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************
|
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 )
|
|
||||||
{
|
{
|
||||||
int len;
|
size_t len;
|
||||||
|
|
||||||
len = srclen < ( LINE_SIZE - 1 ) ? srclen : ( LINE_SIZE - 1 );
|
len = srclen < (LINE_SIZE - (size_t)1) ? srclen : (LINE_SIZE - (size_t)1);
|
||||||
strncpy( dest, src, len );
|
strncpy(dest, src, len);
|
||||||
dest[len] = '\0';
|
dest[len] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -125,7 +126,7 @@
|
|||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define THREAD_STACK_SIZE 0
|
#define THREAD_STACK_SIZE (size_t)0
|
||||||
/* @} */
|
/* @} */
|
||||||
|
|
||||||
|
|
||||||
@@ -178,7 +179,7 @@
|
|||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define SSDP_PAUSE 100
|
#define SSDP_PAUSE 100u
|
||||||
/* @} */
|
/* @} */
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@@ -189,7 +190,7 @@
|
|||||||
*
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define WEB_SERVER_BUF_SIZE (1024*1024)
|
#define WEB_SERVER_BUF_SIZE (size_t)(1024*1024)
|
||||||
/* @} */
|
/* @} */
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@@ -294,6 +295,50 @@
|
|||||||
/* @} */
|
/* @} */
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \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
|
||||||
*
|
*
|
||||||
@@ -391,11 +436,34 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* configure --enable-webserver --enable-device */
|
/* configure --enable-webserver */
|
||||||
#if UPNP_HAVE_WEBSERVER
|
#if UPNP_HAVE_WEBSERVER
|
||||||
# define INTERNAL_WEB_SERVER 1
|
# define INTERNAL_WEB_SERVER 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* configure --enable-ssdp */
|
||||||
|
#undef EXCLUDE_SSDP
|
||||||
|
#if UPNP_HAVE_SSDP
|
||||||
|
# define EXCLUDE_SSSDP 0
|
||||||
|
#else
|
||||||
|
# define EXCLUDE_SSSDP 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* configure --enable-soap */
|
||||||
|
#undef EXCLUDE_SOAP
|
||||||
|
#if UPNP_HAVE_SOAP
|
||||||
|
# define EXCLUDE_SOAP 0
|
||||||
|
#else
|
||||||
|
# define EXCLUDE_SOAP 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* configure --enable-gena */
|
||||||
|
#undef EXCLUDE_GENA
|
||||||
|
#if UPNP_HAVE_GENA
|
||||||
|
# define EXCLUDE_GENA 0
|
||||||
|
#else
|
||||||
|
# define EXCLUDE_GENA 1
|
||||||
|
#endif
|
||||||
|
|
||||||
#undef EXCLUDE_WEB_SERVER
|
#undef EXCLUDE_WEB_SERVER
|
||||||
#undef EXCLUDE_MINISERVER
|
#undef EXCLUDE_MINISERVER
|
||||||
|
|||||||
@@ -29,11 +29,9 @@
|
|||||||
*
|
*
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef GLOBAL_H
|
#ifndef GLOBAL_H
|
||||||
#define GLOBAL_H
|
#define GLOBAL_H
|
||||||
|
|
||||||
|
|
||||||
/* GLOBAL.H - RSAREF types and constants */
|
/* GLOBAL.H - RSAREF types and constants */
|
||||||
/* PROTOTYPES should be set to one if and only if the compiler supports
|
/* PROTOTYPES should be set to one if and only if the compiler supports
|
||||||
function argument prototyping.
|
function argument prototyping.
|
||||||
@@ -42,7 +40,6 @@
|
|||||||
been defined with C compiler flags.
|
been defined with C compiler flags.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef PROTOTYPES
|
#ifndef PROTOTYPES
|
||||||
#define PROTOTYPES 1
|
#define PROTOTYPES 1
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are met:
|
* modification, are permitted provided that the following conditions are met:
|
||||||
@@ -29,49 +30,45 @@
|
|||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef GENLIB_NET_HTTP_HTTPPARSER_H
|
#ifndef GENLIB_NET_HTTP_HTTPPARSER_H
|
||||||
#define GENLIB_NET_HTTP_HTTPPARSER_H
|
#define GENLIB_NET_HTTP_HTTPPARSER_H
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \file
|
* \file
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "LinkedList.h"
|
#include "LinkedList.h"
|
||||||
#include "membuffer.h"
|
#include "membuffer.h"
|
||||||
#include "uri.h"
|
#include "uri.h"
|
||||||
#include "util.h"
|
#include "upnputil.h"
|
||||||
|
|
||||||
|
/* private types */
|
||||||
|
|
||||||
////// private types ////////////
|
/* scanner */
|
||||||
|
|
||||||
|
/* Used to represent different types of tokens in input. */
|
||||||
//////////////////////
|
typedef enum
|
||||||
// scanner
|
|
||||||
///////////////////////
|
|
||||||
// Used to represent different types of tokens in input
|
|
||||||
typedef enum // token_type_t
|
|
||||||
{
|
{
|
||||||
TT_IDENTIFIER,
|
TT_IDENTIFIER,
|
||||||
TT_WHITESPACE,
|
TT_WHITESPACE,
|
||||||
TT_CRLF,
|
TT_CRLF,
|
||||||
TT_CTRL, // needed ??
|
TT_CTRL,
|
||||||
TT_SEPARATOR, // ??
|
TT_SEPARATOR,
|
||||||
TT_QUOTEDSTRING, // ??
|
TT_QUOTEDSTRING,
|
||||||
} token_type_t;
|
} token_type_t;
|
||||||
|
|
||||||
typedef struct // scanner_t
|
typedef struct
|
||||||
{
|
{
|
||||||
membuffer* msg; // raw http msg
|
/*! raw http msg. */
|
||||||
size_t cursor; // current position in buffer
|
membuffer* msg;
|
||||||
xboolean entire_msg_loaded; // set this to TRUE if the entire msg is loaded in
|
/*! current position in buffer. */
|
||||||
// in 'msg'; else FALSE if only partial msg in 'msg'
|
size_t cursor;
|
||||||
// (default is FALSE)
|
/*! set this to TRUE if the entire msg is loaded in 'msg';
|
||||||
|
* else FALSE if only partial msg in 'msg' (default is FALSE). */
|
||||||
|
int entire_msg_loaded;
|
||||||
} scanner_t;
|
} scanner_t;
|
||||||
|
|
||||||
typedef enum // parser_pos_t
|
typedef enum
|
||||||
{
|
{
|
||||||
POS_REQUEST_LINE,
|
POS_REQUEST_LINE,
|
||||||
POS_RESPONSE_LINE,
|
POS_RESPONSE_LINE,
|
||||||
@@ -80,7 +77,6 @@ typedef enum // parser_pos_t
|
|||||||
POS_COMPLETE,
|
POS_COMPLETE,
|
||||||
} parser_pos_t;
|
} parser_pos_t;
|
||||||
|
|
||||||
|
|
||||||
#define ENTREAD_DETERMINE_READ_METHOD 1
|
#define ENTREAD_DETERMINE_READ_METHOD 1
|
||||||
#define ENTREAD_USING_CLEN 2
|
#define ENTREAD_USING_CLEN 2
|
||||||
#define ENTREAD_USING_CHUNKED 3
|
#define ENTREAD_USING_CHUNKED 3
|
||||||
@@ -88,13 +84,10 @@ typedef enum // parser_pos_t
|
|||||||
#define ENTREAD_CHUNKY_BODY 5
|
#define ENTREAD_CHUNKY_BODY 5
|
||||||
#define ENTREAD_CHUNKY_HEADERS 6
|
#define ENTREAD_CHUNKY_HEADERS 6
|
||||||
|
|
||||||
|
/* end of private section. */
|
||||||
|
|
||||||
// end of private section
|
/* method in a HTTP request. */
|
||||||
//////////////////
|
typedef enum
|
||||||
// ##################################################################################
|
|
||||||
|
|
||||||
// method in a HTTP request
|
|
||||||
typedef enum // http_method_t
|
|
||||||
{
|
{
|
||||||
HTTPMETHOD_POST,
|
HTTPMETHOD_POST,
|
||||||
HTTPMETHOD_MPOST,
|
HTTPMETHOD_MPOST,
|
||||||
@@ -105,11 +98,11 @@ typedef enum // http_method_t
|
|||||||
HTTPMETHOD_HEAD,
|
HTTPMETHOD_HEAD,
|
||||||
HTTPMETHOD_MSEARCH,
|
HTTPMETHOD_MSEARCH,
|
||||||
HTTPMETHOD_UNKNOWN,
|
HTTPMETHOD_UNKNOWN,
|
||||||
SOAPMETHOD_POST, //murari
|
SOAPMETHOD_POST,
|
||||||
HTTPMETHOD_SIMPLEGET
|
HTTPMETHOD_SIMPLEGET
|
||||||
} http_method_t;
|
} http_method_t;
|
||||||
|
|
||||||
// different types of HTTP headers
|
/* different types of HTTP headers */
|
||||||
#define HDR_UNKNOWN -1
|
#define HDR_UNKNOWN -1
|
||||||
#define HDR_CACHE_CONTROL 1
|
#define HDR_CACHE_CONTROL 1
|
||||||
#define HDR_CALLBACK 2
|
#define HDR_CALLBACK 2
|
||||||
@@ -118,9 +111,9 @@ typedef enum // http_method_t
|
|||||||
#define HDR_DATE 5
|
#define HDR_DATE 5
|
||||||
#define HDR_EXT 6
|
#define HDR_EXT 6
|
||||||
#define HDR_HOST 7
|
#define HDR_HOST 7
|
||||||
//#define HDR_IF_MODIFIED_SINCE 8
|
/*define HDR_IF_MODIFIED_SINCE 8 */
|
||||||
//#define HDR_IF_UNMODIFIED_SINCE 9
|
/*define HDR_IF_UNMODIFIED_SINCE 9 */
|
||||||
//#define HDR_LAST_MODIFIED 10
|
/*define HDR_LAST_MODIFIED 10 */
|
||||||
#define HDR_LOCATION 11
|
#define HDR_LOCATION 11
|
||||||
#define HDR_MAN 12
|
#define HDR_MAN 12
|
||||||
#define HDR_MX 13
|
#define HDR_MX 13
|
||||||
@@ -136,7 +129,7 @@ typedef enum // http_method_t
|
|||||||
#define HDR_USN 23
|
#define HDR_USN 23
|
||||||
#define HDR_USER_AGENT 24
|
#define HDR_USER_AGENT 24
|
||||||
|
|
||||||
//Adding new header difinition//Beg_Murari
|
/* Adding new header difinition */
|
||||||
#define HDR_ACCEPT 25
|
#define HDR_ACCEPT 25
|
||||||
#define HDR_ACCEPT_ENCODING 26
|
#define HDR_ACCEPT_ENCODING 26
|
||||||
#define HDR_ACCEPT_CHARSET 27
|
#define HDR_ACCEPT_CHARSET 27
|
||||||
@@ -149,89 +142,92 @@ typedef enum // http_method_t
|
|||||||
#define HDR_IF_RANGE 34
|
#define HDR_IF_RANGE 34
|
||||||
#define HDR_RANGE 35
|
#define HDR_RANGE 35
|
||||||
#define HDR_TE 36
|
#define HDR_TE 36
|
||||||
//End_Murari
|
|
||||||
|
|
||||||
// status of parsing
|
/*! status of parsing */
|
||||||
typedef enum // parse_status_t
|
typedef enum {
|
||||||
{
|
/*! msg was parsed successfully. */
|
||||||
PARSE_SUCCESS = 0, // msg was parsed successfully
|
PARSE_SUCCESS = 0,
|
||||||
PARSE_INCOMPLETE, // need more data to continue
|
/*! need more data to continue. */
|
||||||
PARSE_INCOMPLETE_ENTITY, // for responses that don't have length specified
|
PARSE_INCOMPLETE,
|
||||||
PARSE_FAILURE, // parse failed; check status code for details
|
/*! for responses that don't have length specified. */
|
||||||
PARSE_OK, // done partial
|
PARSE_INCOMPLETE_ENTITY,
|
||||||
PARSE_NO_MATCH, // token not matched
|
/*! parse failed; check status code for details. */
|
||||||
|
PARSE_FAILURE,
|
||||||
// private
|
/*! done partial. */
|
||||||
|
PARSE_OK,
|
||||||
|
/*! token not matched. */
|
||||||
|
PARSE_NO_MATCH,
|
||||||
|
/*! private. */
|
||||||
PARSE_CONTINUE_1
|
PARSE_CONTINUE_1
|
||||||
} parse_status_t;
|
} parse_status_t;
|
||||||
|
|
||||||
typedef struct // http_header_t
|
typedef struct {
|
||||||
{
|
/*! header name as a string. */
|
||||||
memptr name; // header name as a string
|
memptr name;
|
||||||
int name_id; // header name id (for a selective group of headers only)
|
/*! header name id (for a selective group of headers only). */
|
||||||
membuffer value; // raw-value; could be multi-lined; min-length = 0
|
int name_id;
|
||||||
|
/*! raw-value; could be multi-lined; min-length = 0. */
|
||||||
// private
|
membuffer value;
|
||||||
|
/* private. */
|
||||||
membuffer name_buf;
|
membuffer name_buf;
|
||||||
} http_header_t;
|
} http_header_t;
|
||||||
|
|
||||||
typedef struct // http_message_t
|
typedef struct {
|
||||||
{
|
|
||||||
int initialized;
|
int initialized;
|
||||||
// request only
|
/*! request only. */
|
||||||
http_method_t method;
|
http_method_t method;
|
||||||
|
/*! request only. */
|
||||||
uri_type uri;
|
uri_type uri;
|
||||||
|
/*! response only. */
|
||||||
// response only
|
|
||||||
http_method_t request_method;
|
http_method_t request_method;
|
||||||
|
/*! response only. */
|
||||||
int status_code;
|
int status_code;
|
||||||
|
/*! response only. */
|
||||||
membuffer status_msg;
|
membuffer status_msg;
|
||||||
|
/*! response only. the amount of data that's been read by the user, that's no
|
||||||
// fields used in both request or response messages
|
* longer in the raw message buffer.
|
||||||
xboolean is_request; // if TRUE, msg is a request, else response
|
*/
|
||||||
|
size_t amount_discarded;
|
||||||
int major_version; // http major.minor version
|
/* fields used in both request or response messages. */
|
||||||
|
/*! if TRUE, msg is a request, else response. */
|
||||||
|
int is_request;
|
||||||
|
/* http major version. */
|
||||||
|
int major_version;
|
||||||
|
/* http minor version. */
|
||||||
int minor_version;
|
int minor_version;
|
||||||
|
/*! . */
|
||||||
|
|
||||||
LinkedList headers;
|
LinkedList headers;
|
||||||
//NNS: dlist headers; // dlist<http_header_t *>
|
/*! message body(entity). */
|
||||||
memptr entity; // message body(entity)
|
memptr entity;
|
||||||
|
/* private fields. */
|
||||||
// private fields
|
/*! entire raw message. */
|
||||||
membuffer msg; // entire raw message
|
membuffer msg;
|
||||||
char *urlbuf; // storage for url string
|
/*! storage for url string. */
|
||||||
size_t entity_offset;
|
char *urlbuf;
|
||||||
} http_message_t;
|
} http_message_t;
|
||||||
|
|
||||||
typedef struct // http_parser_t
|
typedef struct {
|
||||||
{
|
|
||||||
http_message_t msg;
|
http_message_t msg;
|
||||||
int http_error_code; // read-only; in case of parse error, this
|
/*! read-only; in case of parse error, this
|
||||||
// contains the HTTP error code (4XX or 5XX)
|
* contains the HTTP error code (4XX or 5XX). */
|
||||||
|
int http_error_code;
|
||||||
// read-only; this is set to true if a NOTIFY request has no content-length.
|
/*! read-only; this is set to true if a NOTIFY request has no
|
||||||
// used to read valid sspd notify msg.
|
* content-length. used to read valid sspd notify msg. */
|
||||||
xboolean valid_ssdp_notify_hack;
|
int valid_ssdp_notify_hack;
|
||||||
|
/* private data -- don't touch. */
|
||||||
// private data -- don't touch
|
|
||||||
parser_pos_t position;
|
parser_pos_t position;
|
||||||
int ent_position;
|
int ent_position;
|
||||||
unsigned int content_length;
|
unsigned int content_length;
|
||||||
int chunk_size;
|
size_t chunk_size;
|
||||||
|
/*! offset in the the raw message buffer, which contains the message body.
|
||||||
|
* preceding this are the headers of the messsage. */
|
||||||
size_t entity_start_position;
|
size_t entity_start_position;
|
||||||
scanner_t scanner;
|
scanner_t scanner;
|
||||||
} http_parser_t;
|
} http_parser_t;
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------
|
|
||||||
//////////////// functions /////////////////////////
|
|
||||||
//--------------------------------------------------
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif // __cplusplus
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function : httpmsg_init
|
* Function : httpmsg_init
|
||||||
@@ -273,7 +269,6 @@ void httpmsg_destroy( INOUT http_message_t* msg );
|
|||||||
*
|
*
|
||||||
* Return : http_header_t* - Pointer to a header on success;
|
* Return : http_header_t* - Pointer to a header on success;
|
||||||
* NULL on failure
|
* NULL on failure
|
||||||
*
|
|
||||||
* Note :
|
* Note :
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
http_header_t* httpmsg_find_hdr_str( IN http_message_t* msg,
|
http_header_t* httpmsg_find_hdr_str( IN http_message_t* msg,
|
||||||
@@ -289,7 +284,7 @@ http_header_t* httpmsg_find_hdr_str( IN http_message_t* msg,
|
|||||||
*
|
*
|
||||||
* Description : Finds header from a list, with the given 'name_id'.
|
* Description : Finds header from a list, with the given 'name_id'.
|
||||||
*
|
*
|
||||||
* Return : http_header_t* - Pointer to a header on success; *
|
* Return : http_header_t* - Pointer to a header on success;
|
||||||
* NULL on failure
|
* NULL on failure
|
||||||
*
|
*
|
||||||
* Note :
|
* Note :
|
||||||
@@ -435,11 +430,7 @@ parse_status_t parser_append( INOUT http_parser_t* parser,
|
|||||||
* PARSE_NO_MATCH -- failure to match pattern 'fmt'
|
* PARSE_NO_MATCH -- failure to match pattern 'fmt'
|
||||||
* PARSE_FAILURE -- 'str' is bad input
|
* PARSE_FAILURE -- 'str' is bad input
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
int matchstr( IN char *str, IN size_t slen, IN const char* fmt, ... );
|
parse_status_t matchstr( IN char *str, IN size_t slen, IN const char* fmt, ... );
|
||||||
|
|
||||||
// ====================================================
|
|
||||||
// misc functions
|
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function: raw_to_int
|
* Function: raw_to_int
|
||||||
@@ -481,26 +472,28 @@ int raw_find_str( IN memptr* raw_value, IN const char* str );
|
|||||||
* nameConverts a http_method id stored in the HTTP Method
|
* nameConverts a http_method id stored in the HTTP Method
|
||||||
*
|
*
|
||||||
* Returns:
|
* Returns:
|
||||||
* const char* ptr - Ptr to the HTTP Method *
|
* const char* ptr - Ptr to the HTTP Method
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
const char* method_to_str( IN http_method_t method );
|
const char* method_to_str( IN http_method_t method );
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Print the HTTP headers.
|
* \brief Print the HTTP headers.
|
||||||
*/
|
*/
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
void print_http_headers(
|
void print_http_headers(
|
||||||
/*! [in] HTTP Message object. */
|
/*! [in] HTTP Message object. */
|
||||||
http_message_t *hmsg );
|
http_message_t *hmsg);
|
||||||
#else
|
#else
|
||||||
static UPNP_INLINE void print_http_headers(http_message_t *hmsg) {}
|
static UPNP_INLINE void print_http_headers(http_message_t *hmsg)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
hmsg = hmsg;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} /* extern "C" */
|
} /* extern "C" */
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
|
||||||
#endif /* GENLIB_NET_HTTP_HTTPPARSER_H */
|
#endif /* GENLIB_NET_HTTP_HTTPPARSER_H */
|
||||||
|
|
||||||
|
|||||||
@@ -1,105 +1,97 @@
|
|||||||
///////////////////////////////////////////////////////////////////////////
|
/*******************************************************************************
|
||||||
//
|
*
|
||||||
// Copyright (c) 2000-2003 Intel Corporation
|
* Copyright (c) 2000-2003 Intel Corporation
|
||||||
// All rights reserved.
|
* All rights reserved.
|
||||||
//
|
* Copyright (c) 2012 France Telecom All rights reserved.
|
||||||
// Redistribution and use in source and binary forms, with or without
|
*
|
||||||
// modification, are permitted provided that the following conditions are met:
|
* 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 of source code must retain the above copyright notice,
|
||||||
// * Redistributions in binary form must reproduce the above copyright notice,
|
* this list of conditions and the following disclaimer.
|
||||||
// this list of conditions and the following disclaimer in the documentation
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
// and/or other materials provided with the distribution.
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
// * Neither name of Intel Corporation nor the names of its contributors
|
* and/or other materials provided with the distribution.
|
||||||
// may be used to endorse or promote products derived from this software
|
* - Neither name of Intel Corporation nor the names of its contributors
|
||||||
// without specific prior written permission.
|
* 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
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
||||||
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
||||||
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
//
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
///////////////////////////////////////////////////////////////////////////
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
#ifndef GENLIB_NET_HTTP_HTTPREADWRITE_H
|
#ifndef GENLIB_NET_HTTP_HTTPREADWRITE_H
|
||||||
#define GENLIB_NET_HTTP_HTTPREADWRITE_H
|
#define GENLIB_NET_HTTP_HTTPREADWRITE_H
|
||||||
|
|
||||||
|
/*
|
||||||
|
* \file
|
||||||
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "util.h"
|
#include "upnputil.h"
|
||||||
#include "sock.h"
|
#include "sock.h"
|
||||||
#include "httpparser.h"
|
#include "httpparser.h"
|
||||||
|
|
||||||
// timeout in secs
|
/*! timeout in secs. */
|
||||||
#define HTTP_DEFAULT_TIMEOUT 30
|
#define HTTP_DEFAULT_TIMEOUT 30
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
#extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int
|
int http_CancelHttpGet(IN void *Handle);
|
||||||
http_CancelHttpGet( IN void *Handle );
|
|
||||||
|
|
||||||
/************************************************************************
|
/*!
|
||||||
* Function: http_FixUrl
|
* \brief Validates URL.
|
||||||
*
|
*
|
||||||
* Parameters:
|
* \return
|
||||||
* IN uri_type* url; URL to be validated and fixed
|
* \li \c UPNP_E_INVALID_URL
|
||||||
* OUT uri_type* fixed_url; URL after being fixed.
|
* \li \c UPNP_E_SUCCESS
|
||||||
*
|
*/
|
||||||
* Description:
|
int http_FixUrl(
|
||||||
* Validates URL
|
/*! [in] URL to be validated and fixed. */
|
||||||
*
|
uri_type *url,
|
||||||
* Returns:
|
/*! [out] URL after being fixed. */
|
||||||
* UPNP_E_INVALID_URL
|
uri_type *fixed_url);
|
||||||
* UPNP_E_SUCCESS
|
|
||||||
************************************************************************/
|
|
||||||
int http_FixUrl( IN uri_type* url, OUT uri_type* fixed_url );
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Parses URL and then validates URL.
|
||||||
|
*
|
||||||
|
* \return
|
||||||
|
* \li \c UPNP_E_INVALID_URL
|
||||||
|
* \li \c UPNP_E_SUCCESS
|
||||||
|
*/
|
||||||
|
int http_FixStrUrl(
|
||||||
|
/*! [in] Character string as a URL. */
|
||||||
|
const char *urlstr,
|
||||||
|
/*! [in] Length of the character string. */
|
||||||
|
size_t urlstrlen,
|
||||||
|
/*! [out] Fixed and corrected URL. */
|
||||||
|
uri_type *fixed_url);
|
||||||
|
|
||||||
/************************************************************************
|
/*!
|
||||||
* Function: http_FixStrUrl
|
* \brief Gets destination address from URL and then connects to the
|
||||||
|
* remote end.
|
||||||
*
|
*
|
||||||
* Parameters:
|
* \return Socket descriptor on success, or on error:
|
||||||
* IN char* urlstr ; Character string as a URL
|
* \li \c UPNP_E_OUTOF_SOCKET
|
||||||
* IN int urlstrlen ; Length of the character string
|
* \li \c UPNP_E_SOCKET_CONNECT
|
||||||
* OUT uri_type* fixed_url ; Fixed and corrected URL
|
*/
|
||||||
*
|
SOCKET http_Connect(
|
||||||
* Description:
|
/*! [in] URL containing destination information. */
|
||||||
* Parses URL and then validates URL
|
uri_type *destination_url,
|
||||||
*
|
/*! [out] Fixed and corrected URL. */
|
||||||
* Returns:
|
uri_type *url);
|
||||||
* UPNP_E_INVALID_URL
|
|
||||||
* UPNP_E_SUCCESS
|
|
||||||
************************************************************************/
|
|
||||||
int http_FixStrUrl( IN const char* urlstr, IN int urlstrlen, OUT uri_type* fixed_url );
|
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
|
||||||
* Function: http_Connect
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
* IN uri_type* destination_url; URL containing destination information
|
|
||||||
* OUT uri_type *url; Fixed and corrected URL
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Gets destination address from URL and then connects to the remote end
|
|
||||||
*
|
|
||||||
* Returns:
|
|
||||||
* socket descriptor on sucess
|
|
||||||
* UPNP_E_OUTOF_SOCKET
|
|
||||||
* UPNP_E_SOCKET_CONNECT on error
|
|
||||||
************************************************************************/
|
|
||||||
int http_Connect( IN uri_type* destination_url, OUT uri_type *url );
|
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
@@ -128,37 +120,37 @@ int http_RecvMessage( IN SOCKINFO *info, OUT http_parser_t* parser,
|
|||||||
OUT int* http_error_code );
|
OUT int* http_error_code );
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
/*!
|
||||||
* Function: http_SendMessage
|
* \brief Sends a message to the destination based on the format parameter.
|
||||||
*
|
*
|
||||||
* Parameters:
|
|
||||||
* IN SOCKINFO *info ; Socket information object
|
|
||||||
* IN OUT int * TimeOut ; time out value
|
|
||||||
* IN const char* fmt, ... Pattern format to take actions upon
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Sends a message to the destination based on the
|
|
||||||
* IN const char* fmt parameter
|
|
||||||
* fmt types:
|
* fmt types:
|
||||||
* 'f': arg = const char * file name
|
* \li \c 'f': arg = "const char *" file name
|
||||||
* 'm': arg1 = const char * mem_buffer; arg2= size_t buf_length
|
* \li \c 'b': arg1 = "const char *" mem_buffer; arg2 = "size_t" buffer length.
|
||||||
* E.g.:
|
* \li \c 'I': arg = "struct SendInstruction *"
|
||||||
* char *buf = "POST /xyz.cgi http/1.1\r\n\r\n";
|
|
||||||
* char *filename = "foo.dat";
|
|
||||||
* int status = http_SendMessage( tcpsock, "mf",
|
|
||||||
* buf, strlen(buf), // args for memory buffer
|
|
||||||
* filename ); // arg for file
|
|
||||||
*
|
*
|
||||||
* Returns:
|
* E.g.:
|
||||||
* UPNP_E_OUTOF_MEMORY
|
\verbatim
|
||||||
* UPNP_E_FILE_READ_ERROR
|
char *buf = "POST /xyz.cgi http/1.1\r\n\r\n";
|
||||||
* UPNP_E_SUCCESS
|
char *filename = "foo.dat";
|
||||||
************************************************************************/
|
int status = http_SendMessage(tcpsock, "bf",
|
||||||
|
buf, strlen(buf), // args for memory buffer
|
||||||
|
filename); // arg for file
|
||||||
|
\endverbatim
|
||||||
|
*
|
||||||
|
* \return
|
||||||
|
* \li \c UPNP_E_OUTOF_MEMORY
|
||||||
|
* \li \c UPNP_E_FILE_READ_ERROR
|
||||||
|
* \li \c UPNP_E_SUCCESS
|
||||||
|
*/
|
||||||
int http_SendMessage(
|
int http_SendMessage(
|
||||||
IN SOCKINFO *info,
|
/* [in] Socket information object. */
|
||||||
IN OUT int* timeout_secs,
|
SOCKINFO *info,
|
||||||
IN const char* fmt, ... );
|
/* [in,out] Time out value. */
|
||||||
|
int* timeout_secs,
|
||||||
|
/* [in] Pattern format to take actions upon. */
|
||||||
|
const char* fmt,
|
||||||
|
/* [in] Variable parameter list. */
|
||||||
|
...);
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function: http_RequestAndResponse
|
* Function: http_RequestAndResponse
|
||||||
@@ -212,7 +204,7 @@ int http_RequestAndResponse(
|
|||||||
* IN int timeout_secs; time out value
|
* IN int timeout_secs; time out value
|
||||||
* OUT char** document; buffer to store the document extracted
|
* OUT char** document; buffer to store the document extracted
|
||||||
* from the donloaded message.
|
* from the donloaded message.
|
||||||
* OUT int* doc_length; length of the extracted document
|
* OUT size_t* doc_length; length of the extracted document
|
||||||
* OUT char* content_type; Type of content
|
* OUT char* content_type; Type of content
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
@@ -227,7 +219,7 @@ int http_Download(
|
|||||||
IN const char* url,
|
IN const char* url,
|
||||||
IN int timeout_secs,
|
IN int timeout_secs,
|
||||||
OUT char** document,
|
OUT char** document,
|
||||||
OUT int* doc_length,
|
OUT size_t *doc_length,
|
||||||
OUT char* content_type );
|
OUT char* content_type );
|
||||||
|
|
||||||
|
|
||||||
@@ -238,7 +230,7 @@ int http_Download(
|
|||||||
* IN void *Handle: Handle to the http post object
|
* IN void *Handle: Handle to the http post object
|
||||||
* IN char *buf: Buffer to send to peer, if format used
|
* IN char *buf: Buffer to send to peer, if format used
|
||||||
* is not UPNP_USING_CHUNKED,
|
* is not UPNP_USING_CHUNKED,
|
||||||
* IN unsigned int *size: Size of the data to be sent.
|
* IN size_t *size: Size of the data to be sent.
|
||||||
* IN int timeout: time out value
|
* IN int timeout: time out value
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
@@ -252,7 +244,7 @@ int http_Download(
|
|||||||
************************************************************************/
|
************************************************************************/
|
||||||
int http_WriteHttpPost(IN void *Handle,
|
int http_WriteHttpPost(IN void *Handle,
|
||||||
IN char *buf,
|
IN char *buf,
|
||||||
IN unsigned int *size,
|
IN size_t *size,
|
||||||
IN int timeout);
|
IN int timeout);
|
||||||
|
|
||||||
|
|
||||||
@@ -271,7 +263,7 @@ int http_WriteHttpPost(IN void *Handle,
|
|||||||
* associated memory. Frees handle associated with the HTTP POST msg.
|
* associated memory. Frees handle associated with the HTTP POST msg.
|
||||||
*
|
*
|
||||||
* Return: int
|
* Return: int
|
||||||
* UPNP_E_SUCCESS - On Sucess
|
* UPNP_E_SUCCESS - On success
|
||||||
* UPNP_E_INVALID_PARAM - Invalid Parameter
|
* UPNP_E_INVALID_PARAM - Invalid Parameter
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
int http_CloseHttpPost(IN void *Handle,
|
int http_CloseHttpPost(IN void *Handle,
|
||||||
@@ -296,7 +288,7 @@ int http_CloseHttpPost(IN void *Handle,
|
|||||||
* such handles
|
* such handles
|
||||||
*
|
*
|
||||||
* Return : int;
|
* Return : int;
|
||||||
* UPNP_E_SUCCESS - On Sucess
|
* UPNP_E_SUCCESS - On success
|
||||||
* UPNP_E_INVALID_PARAM - Invalid Parameter
|
* UPNP_E_INVALID_PARAM - Invalid Parameter
|
||||||
* UPNP_E_OUTOF_MEMORY
|
* UPNP_E_OUTOF_MEMORY
|
||||||
* UPNP_E_SOCKET_ERROR
|
* UPNP_E_SOCKET_ERROR
|
||||||
@@ -315,7 +307,7 @@ int http_OpenHttpPost(IN const char *url_str,
|
|||||||
* Parameters:
|
* Parameters:
|
||||||
* IN void *Handle; Handle to the HTTP get object
|
* IN void *Handle; Handle to the HTTP get object
|
||||||
* IN OUT char *buf; Buffer to get the read and parsed data
|
* IN OUT char *buf; Buffer to get the read and parsed data
|
||||||
* IN OUT unsigned int *size; Size of the buffer passed
|
* IN OUT size_t *size; Size of the buffer passed
|
||||||
* IN int timeout; time out value
|
* IN int timeout; time out value
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
@@ -323,7 +315,7 @@ int http_OpenHttpPost(IN const char *url_str,
|
|||||||
* Parses and extracts information from the new data.
|
* Parses and extracts information from the new data.
|
||||||
*
|
*
|
||||||
* Return: int
|
* Return: int
|
||||||
* UPNP_E_SUCCESS - On Sucess
|
* UPNP_E_SUCCESS - On success
|
||||||
* UPNP_E_INVALID_PARAM - Invalid Parameter
|
* UPNP_E_INVALID_PARAM - Invalid Parameter
|
||||||
* UPNP_E_BAD_RESPONSE
|
* UPNP_E_BAD_RESPONSE
|
||||||
* UPNP_E_BAD_HTTPMSG
|
* UPNP_E_BAD_HTTPMSG
|
||||||
@@ -332,7 +324,7 @@ int http_OpenHttpPost(IN const char *url_str,
|
|||||||
int http_ReadHttpGet(
|
int http_ReadHttpGet(
|
||||||
IN void *Handle,
|
IN void *Handle,
|
||||||
IN OUT char *buf,
|
IN OUT char *buf,
|
||||||
IN OUT unsigned int *size,
|
IN OUT size_t *size,
|
||||||
IN int timeout);
|
IN int timeout);
|
||||||
|
|
||||||
|
|
||||||
@@ -341,8 +333,8 @@ int http_ReadHttpGet(
|
|||||||
*
|
*
|
||||||
* Parameters:
|
* Parameters:
|
||||||
* IN void *Handle; Handle to the HTTP get object
|
* IN void *Handle; Handle to the HTTP get object
|
||||||
* OUT unsigned int *length; Buffer to get the read and parsed data
|
* OUT size_t *length; Buffer to get the read and parsed data
|
||||||
* OUT unsigned int *total; Size of tge buffer passed
|
* OUT size_t *total; Size of tge buffer passed
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Extracts information from the Handle to the HTTP get object.
|
* Extracts information from the Handle to the HTTP get object.
|
||||||
@@ -353,9 +345,8 @@ int http_ReadHttpGet(
|
|||||||
************************************************************************/
|
************************************************************************/
|
||||||
int http_HttpGetProgress(
|
int http_HttpGetProgress(
|
||||||
IN void *Handle,
|
IN void *Handle,
|
||||||
OUT unsigned int *length,
|
OUT size_t *length,
|
||||||
OUT unsigned int *total );
|
OUT size_t *total);
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* Function: http_CloseHttpGet
|
* Function: http_CloseHttpGet
|
||||||
@@ -373,74 +364,61 @@ int http_HttpGetProgress(
|
|||||||
************************************************************************/
|
************************************************************************/
|
||||||
int http_CloseHttpGet(IN void *Handle);
|
int http_CloseHttpGet(IN void *Handle);
|
||||||
|
|
||||||
|
/*!
|
||||||
/************************************************************************
|
* \brief Makes the HTTP GET message, connects to the peer,
|
||||||
* Function: http_OpenHttpGet
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
* IN const char *url_str: String as a URL
|
|
||||||
* IN OUT void **Handle: Pointer to buffer to store HTTP
|
|
||||||
* post handle
|
|
||||||
* IN OUT char **contentType: Type of content
|
|
||||||
* OUT int *contentLength: length of content
|
|
||||||
* OUT int *httpStatus: HTTP status returned on receiving a
|
|
||||||
* response message
|
|
||||||
* IN int timeout: time out value
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Makes the HTTP GET message, connects to the peer,
|
|
||||||
* sends the HTTP GET request, gets the response and parses the
|
|
||||||
* response.
|
|
||||||
*
|
|
||||||
* Return: int
|
|
||||||
* UPNP_E_SUCCESS - On Success
|
|
||||||
* UPNP_E_INVALID_PARAM - Invalid Paramters
|
|
||||||
* UPNP_E_OUTOF_MEMORY
|
|
||||||
* UPNP_E_SOCKET_ERROR
|
|
||||||
* UPNP_E_BAD_RESPONSE
|
|
||||||
************************************************************************/
|
|
||||||
int http_OpenHttpGet(
|
|
||||||
IN const char *url_str,
|
|
||||||
IN OUT void **Handle,
|
|
||||||
IN OUT char **contentType,
|
|
||||||
OUT int *contentLength,
|
|
||||||
OUT int *httpStatus,
|
|
||||||
IN int timeout);
|
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
|
||||||
* Function: http_OpenHttpGetProxy
|
|
||||||
*
|
|
||||||
* Parameters:
|
|
||||||
* IN const char *url_str; String as a URL
|
|
||||||
* IN const char *proxy_str; String as a URL
|
|
||||||
* IN OUT void **Handle; Pointer to buffer to store HTTP
|
|
||||||
* post handle
|
|
||||||
* IN OUT char **contentType; Type of content
|
|
||||||
* OUT int *contentLength; length of content
|
|
||||||
* OUT int *httpStatus; HTTP status returned on receiving a
|
|
||||||
* response message
|
|
||||||
* IN int timeout: time out value
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Makes the HTTP GET message, connects to the peer,
|
|
||||||
* sends the HTTP GET request, gets the response and parses the response.
|
* sends the HTTP GET request, gets the response and parses the response.
|
||||||
|
*
|
||||||
* If a proxy URL is defined then the connection is made there.
|
* If a proxy URL is defined then the connection is made there.
|
||||||
*
|
*
|
||||||
* Return: int
|
* \return integer
|
||||||
* UPNP_E_SUCCESS - On Success
|
* \li \c UPNP_E_SUCCESS - On Success
|
||||||
* UPNP_E_INVALID_PARAM - Invalid Paramters
|
* \li \c UPNP_E_INVALID_PARAM - Invalid Paramters
|
||||||
* UPNP_E_OUTOF_MEMORY
|
* \li \c UPNP_E_OUTOF_MEMORY
|
||||||
* UPNP_E_SOCKET_ERROR
|
* \li \c UPNP_E_SOCKET_ERROR
|
||||||
* UPNP_E_BAD_RESPONSE
|
* \li \c UPNP_E_BAD_RESPONSE
|
||||||
************************************************************************/
|
*/
|
||||||
int http_OpenHttpGetProxy(IN const char *url_str,
|
int http_OpenHttpGet(
|
||||||
IN const char *proxy_str,
|
/* [in] String as a URL. */
|
||||||
IN OUT void **Handle,
|
const char *url_str,
|
||||||
IN OUT char **contentType,
|
/* [in,out] Pointer to buffer to store HTTP post handle. */
|
||||||
OUT int *contentLength,
|
void **Handle,
|
||||||
OUT int *httpStatus,
|
/* [in,out] Type of content. */
|
||||||
IN int timeout);
|
char **contentType,
|
||||||
|
/* [out] length of content. */
|
||||||
|
int *contentLength,
|
||||||
|
/* [out] HTTP status returned on receiving a response message. */
|
||||||
|
int *httpStatus,
|
||||||
|
/* [in] time out value. */
|
||||||
|
int timeout);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Makes the HTTP GET message, connects to the peer,
|
||||||
|
* sends the HTTP GET request, gets the response and parses the response.
|
||||||
|
*
|
||||||
|
* If a proxy URL is defined then the connection is made there.
|
||||||
|
*
|
||||||
|
* \return integer
|
||||||
|
* \li \c UPNP_E_SUCCESS - On Success
|
||||||
|
* \li \c UPNP_E_INVALID_PARAM - Invalid Paramters
|
||||||
|
* \li \c UPNP_E_OUTOF_MEMORY
|
||||||
|
* \li \c UPNP_E_SOCKET_ERROR
|
||||||
|
* \li \c UPNP_E_BAD_RESPONSE
|
||||||
|
*/
|
||||||
|
int http_OpenHttpGetProxy(
|
||||||
|
/* [in] String as a URL. */
|
||||||
|
const char *url_str,
|
||||||
|
/* [in] String as a URL. */
|
||||||
|
const char *proxy_str,
|
||||||
|
/* [in,out] Pointer to buffer to store HTTP post handle. */
|
||||||
|
void **Handle,
|
||||||
|
/* [in,out] Type of content. */
|
||||||
|
char **contentType,
|
||||||
|
/* [out] length of content. */
|
||||||
|
int *contentLength,
|
||||||
|
/* [out] HTTP status returned on receiving a response message. */
|
||||||
|
int *httpStatus,
|
||||||
|
/* [in] time out value. */
|
||||||
|
int timeout);
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
@@ -469,61 +447,55 @@ int http_SendStatusResponse(
|
|||||||
IN int request_major_version,
|
IN int request_major_version,
|
||||||
IN int request_minor_version );
|
IN int request_minor_version );
|
||||||
|
|
||||||
|
/*!
|
||||||
/************************************************************************
|
* \brief Generate an HTTP message based on the format that is specified in
|
||||||
* Function: http_MakeMessage
|
* the input parameters.
|
||||||
*
|
*
|
||||||
* Parameters:
|
\verbatim
|
||||||
* INOUT membuffer* buf; buffer with the contents of the
|
Format types:
|
||||||
* message
|
'B': arg = int status_code -- appends content-length, content-type and HTML body for given code.
|
||||||
* IN int http_major_version; HTTP major version
|
'b': arg1 = const char *buf;
|
||||||
* IN int http_minor_version; HTTP minor version
|
arg2 = size_t buf_length memory ptr
|
||||||
* IN const char* fmt; Pattern format
|
'C': (no args) -- appends a HTTP CONNECTION: close header depending on major, minor version.
|
||||||
* ...;
|
'c': (no args) -- appends CRLF "\r\n"
|
||||||
|
'D': (no args) -- appends HTTP DATE: header
|
||||||
|
'd': arg = int number -- appends decimal number
|
||||||
|
'G': arg = range information -- add range header
|
||||||
|
'h': arg = off_t number -- appends off_t number
|
||||||
|
'K': (no args) -- add chunky header
|
||||||
|
'L': arg = language information -- add Content-Language header if Accept-Language header is not empty and if
|
||||||
|
WEB_SERVER_CONTENT_LANGUAGE is not empty
|
||||||
|
'N': arg1 = off_t content_length -- content-length header
|
||||||
|
'q': arg1 = http_method_t -- request start line and HOST header
|
||||||
|
arg2 = (uri_type *)
|
||||||
|
'Q': arg1 = http_method_t; -- start line of request
|
||||||
|
arg2 = char* url;
|
||||||
|
arg3 = size_t url_length
|
||||||
|
'R': arg = int status_code -- adds a response start line
|
||||||
|
'S': (no args) -- appends HTTP SERVER: header
|
||||||
|
's': arg = const char * -- C_string
|
||||||
|
'T': arg = char * content_type; -- format e.g: "text/html"; content-type header
|
||||||
|
't': arg = time_t * gmt_time -- appends time in RFC 1123 fmt
|
||||||
|
'U': (no args) -- appends HTTP USER-AGENT: header
|
||||||
|
'X': arg = const char * -- useragent; "redsonic" HTTP X-User-Agent: useragent
|
||||||
|
\endverbatim
|
||||||
*
|
*
|
||||||
* Description:
|
* \return
|
||||||
* Generate an HTTP message based on the format that is specified
|
* \li \c 0 - On Success
|
||||||
* in the input parameters.
|
* \li \c UPNP_E_OUTOF_MEMORY
|
||||||
*
|
* \li \c UPNP_E_INVALID_URL
|
||||||
* fmt types:
|
*/
|
||||||
* 'B': arg = int status_code
|
|
||||||
* appends content-length, content-type and HTML body
|
|
||||||
* for given code
|
|
||||||
* 'b': arg1 = const char* buf;
|
|
||||||
* arg2 = size_t buf_length memory ptr
|
|
||||||
* 'C': (no args) appends a HTTP CONNECTION: close header
|
|
||||||
* depending on major,minor version
|
|
||||||
* 'c': (no args) appends CRLF "\r\n"
|
|
||||||
* 'D': (no args) appends HTTP DATE: header
|
|
||||||
* 'd': arg = int number // appends decimal number
|
|
||||||
* 'G': arg = range information // add range header
|
|
||||||
* 'h': arg = off_t number // appends off_t number
|
|
||||||
* 'K': (no args) // add chunky header
|
|
||||||
* 'N': arg1 = off_t content_length // content-length header
|
|
||||||
* 'q': arg1 = http_method_t // request start line and HOST header
|
|
||||||
* arg2 = (uri_type *)
|
|
||||||
* 'Q': arg1 = http_method_t; // start line of request
|
|
||||||
* arg2 = char* url;
|
|
||||||
* arg3 = size_t url_length
|
|
||||||
* 'R': arg = int status_code // adds a response start line
|
|
||||||
* 'S': (no args) appends HTTP SERVER: header
|
|
||||||
* 's': arg = const char* C_string
|
|
||||||
* 'T': arg = char * content_type; format
|
|
||||||
* e.g: "text/html"; content-type header
|
|
||||||
* 't': arg = time_t * gmt_time // appends time in RFC 1123 fmt
|
|
||||||
* 'U': (no args) appends HTTP USER-AGENT: header
|
|
||||||
* 'X': arg = const char useragent; "redsonic" HTTP X-User-Agent: useragent
|
|
||||||
*
|
|
||||||
* Return: int
|
|
||||||
* 0 - On Success
|
|
||||||
* UPNP_E_OUTOF_MEMORY
|
|
||||||
* UPNP_E_INVALID_URL
|
|
||||||
************************************************************************/
|
|
||||||
int http_MakeMessage(
|
int http_MakeMessage(
|
||||||
|
/* [in,out] Buffer with the contents of the message. */
|
||||||
INOUT membuffer* buf,
|
INOUT membuffer* buf,
|
||||||
|
/* [in] HTTP major version. */
|
||||||
IN int http_major_version,
|
IN int http_major_version,
|
||||||
|
/* [in] HTTP minor version. */
|
||||||
IN int http_minor_version,
|
IN int http_minor_version,
|
||||||
IN const char* fmt, ... );
|
/* [in] Pattern format. */
|
||||||
|
IN const char* fmt,
|
||||||
|
/* [in] Format arguments. */
|
||||||
|
... );
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
@@ -587,6 +559,7 @@ int http_OpenHttpGetEx(IN const char *url_str,
|
|||||||
*
|
*
|
||||||
* Parameters:
|
* Parameters:
|
||||||
* OUT char *info; buffer to store the operating system information
|
* OUT char *info; buffer to store the operating system information
|
||||||
|
* IN size_t infoSize; size of buffer
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Returns the server information for the operating system
|
* Returns the server information for the operating system
|
||||||
@@ -594,12 +567,12 @@ int http_OpenHttpGetEx(IN const char *url_str,
|
|||||||
* Return:
|
* Return:
|
||||||
* UPNP_INLINE void
|
* UPNP_INLINE void
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
void get_sdk_info( OUT char *info );
|
void get_sdk_info( OUT char *info, IN size_t infoSize );
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} // #extern "C"
|
} /* #extern "C" */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif // GENLIB_NET_HTTP_HTTPREADWRITE_H
|
#endif /* GENLIB_NET_HTTP_HTTPREADWRITE_H */
|
||||||
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user