MiniDLNA update: 1.0.19.1 to 1.0.20
[tomato.git] / release / src / router / minidlna / minidlnatypes.h
blob539202d27685d0aeaa599f31b279f7b511274674
1 /* MiniUPnP project
2 * http://miniupnp.free.fr/ or http://miniupnp.tuxfamily.org/
4 * Copyright (c) 2006-2007, Thomas Bernard
5 * All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are met:
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * * Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * * The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
17 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 * POSSIBILITY OF SUCH DAMAGE.
29 #ifndef __MINIDLNATYPES_H__
30 #define __MINIDLNATYPES_H__
32 #include "config.h"
33 #include <netinet/in.h>
35 /* structure for storing lan addresses
36 * with ascii representation and mask */
37 struct lan_addr_s {
38 char str[16]; /* example: 192.168.0.1 */
39 struct in_addr addr, mask; /* ip/mask */
42 struct runtime_vars_s {
43 int port; /* HTTP Port */
44 int notify_interval; /* seconds between SSDP announces */
47 struct string_s {
48 char *data; // ptr to start of memory area
49 int off;
50 int size;
53 enum media_types {
54 ALL_MEDIA,
55 AUDIO_ONLY,
56 VIDEO_ONLY,
57 IMAGES_ONLY,
58 NO_MEDIA
61 enum file_types {
62 TYPE_UNKNOWN,
63 TYPE_DIR,
64 TYPE_FILE
67 enum client_types {
68 EXbox = 1,
69 EPS3,
70 ESamsungTV,
71 EDenonReceiver,
72 EFreeBox,
73 EPopcornHour,
74 EMediaRoom,
75 ESonyBDP,
76 ESonyBravia,
77 ERokuSoundBridge,
78 EToshibaTV,
79 ELGDevice,
80 ENetgearEVA2000,
81 ESamsungSeriesA,
82 EStandardDLNA150 = 100
85 struct media_dir_s {
86 char * path; /* Base path */
87 enum media_types type; /* type of files to scan */
88 struct media_dir_s * next;
91 struct album_art_name_s {
92 char * name; /* Base path */
93 uint8_t wildcard;
94 struct album_art_name_s * next;
97 struct client_cache_s {
98 struct in_addr addr;
99 unsigned char mac[6];
100 enum client_types type;
101 uint32_t flags;
102 time_t age;
105 #endif