demux: adaptive: handle obsolete http header line folding
[vlc.git] / include / vlc_renderer_discovery.h
blob6193e4862586f5bb0590e1b1ceb898ac8d8de5b4
1 /*****************************************************************************
2 * vlc_renderer_discovery.h : Renderer Discovery functions
3 *****************************************************************************
4 * Copyright (C) 2016 VLC authors and VideoLAN
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU Lesser General Public License as published by
8 * the Free Software Foundation; either version 2.1 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public License
17 * along with this program; if not, write to the Free Software Foundation,
18 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
19 *****************************************************************************/
21 #ifndef VLC_RENDERER_DISCOVERY_H
22 #define VLC_RENDERER_DISCOVERY_H 1
24 #include <vlc_input.h>
25 #include <vlc_probe.h>
26 #include <vlc_url.h>
28 /**
29 * @defgroup vlc_renderer VLC renderer discovery
30 * @{
32 * @file
33 * This file declares VLC renderer discvoery structures and functions
35 * @defgroup vlc_renderer_item VLC renderer items returned by the discovery
36 * @{
39 #define VLC_RENDERER_CAN_AUDIO 0x0001
40 #define VLC_RENDERER_CAN_VIDEO 0x0002
42 /**
43 * Create a new renderer item
45 * @param psz_type type of the item
46 * @param psz_name name of the item
47 * @param psz_uri uri of the renderer item, must contains a valid protocol and
48 * a valid host
49 * @param psz_extra_sout extra sout options
50 * @param psz_demux_filter demux filter to use with the renderer
51 * @param psz_icon_uri icon uri of the renderer item
52 * @param i_flags flags for the item
53 * @return a renderer item or NULL in case of error
55 VLC_API vlc_renderer_item_t *
56 vlc_renderer_item_new(const char *psz_type, const char *psz_name,
57 const char *psz_uri, const char *psz_extra_sout,
58 const char *psz_demux_filter, const char *psz_icon_uri,
59 int i_flags) VLC_USED;
61 /**
62 * Hold a renderer item, i.e. creates a new reference
64 VLC_API vlc_renderer_item_t *
65 vlc_renderer_item_hold(vlc_renderer_item_t *p_item);
67 /**
68 * Releases a renderer item, i.e. decrements its reference counter
70 VLC_API void
71 vlc_renderer_item_release(vlc_renderer_item_t *p_item);
73 /**
74 * Get the human readable name of a renderer item
76 VLC_API const char *
77 vlc_renderer_item_name(const vlc_renderer_item_t *p_item);
79 /**
80 * Get the type (not translated) of a renderer item. For now, the type can only
81 * be "chromecast" ("upnp", "airplay" may come later).
83 VLC_API const char *
84 vlc_renderer_item_type(const vlc_renderer_item_t *p_item);
86 /**
87 * Get the demux filter to use with a renderer item
89 VLC_API const char *
90 vlc_renderer_item_demux_filter(const vlc_renderer_item_t *p_item);
92 /**
93 * Get the sout command of a renderer item
95 VLC_API const char *
96 vlc_renderer_item_sout(const vlc_renderer_item_t *p_item);
98 /**
99 * Get the icon uri of a renderer item
101 VLC_API const char *
102 vlc_renderer_item_icon_uri(const vlc_renderer_item_t *p_item);
105 * Get the flags of a renderer item
107 VLC_API int
108 vlc_renderer_item_flags(const vlc_renderer_item_t *p_item);
111 * @}
112 * @defgroup vlc_renderer_discovery VLC renderer discovery interface
113 * @{
116 typedef struct vlc_renderer_discovery_sys vlc_renderer_discovery_sys;
117 struct vlc_renderer_discovery_owner;
120 * Return a list of renderer discovery modules
122 * @param pppsz_names a pointer to a list of module name, NULL terminated
123 * @param pppsz_longnames a pointer to a list of module longname, NULL
124 * terminated
126 * @return VLC_SUCCESS on success, or VLC_EGENERIC on error
128 VLC_API int
129 vlc_rd_get_names(vlc_object_t *p_obj, char ***pppsz_names,
130 char ***pppsz_longnames) VLC_USED;
131 #define vlc_rd_get_names(a, b, c) \
132 vlc_rd_get_names(VLC_OBJECT(a), b, c)
135 * Create a new renderer discovery module
137 * @param psz_name name of the module to load, see vlc_rd_get_names() to get
138 * the list of names
140 * @return a valid vlc_renderer_discovery, need to be released with
141 * vlc_rd_release()
143 VLC_API vlc_renderer_discovery_t *
144 vlc_rd_new(vlc_object_t *p_obj, const char *psz_name,
145 const struct vlc_renderer_discovery_owner *owner) VLC_USED;
147 VLC_API void vlc_rd_release(vlc_renderer_discovery_t *p_rd);
150 * @}
151 * @defgroup vlc_renderer_discovery_module VLC renderer module
152 * @{
155 struct vlc_renderer_discovery_owner
157 void *sys;
158 void (*item_added)(struct vlc_renderer_discovery_t *,
159 struct vlc_renderer_item_t *);
160 void (*item_removed)(struct vlc_renderer_discovery_t *,
161 struct vlc_renderer_item_t *);
164 struct vlc_renderer_discovery_t
166 VLC_COMMON_MEMBERS
167 module_t * p_module;
169 struct vlc_renderer_discovery_owner owner;
171 char * psz_name;
172 config_chain_t * p_cfg;
174 vlc_renderer_discovery_sys *p_sys;
178 * Add a new renderer item
180 * This will send the vlc_RendererDiscoveryItemAdded event
182 static inline void vlc_rd_add_item(vlc_renderer_discovery_t * p_rd,
183 vlc_renderer_item_t * p_item)
185 p_rd->owner.item_added(p_rd, p_item);
189 * Add a new renderer item
191 * This will send the vlc_RendererDiscoveryItemRemoved event
193 static inline void vlc_rd_remove_item(vlc_renderer_discovery_t * p_rd,
194 vlc_renderer_item_t * p_item)
196 p_rd->owner.item_removed(p_rd, p_item);
200 * Renderer Discovery proble helpers
202 VLC_API int
203 vlc_rd_probe_add(vlc_probe_t *p_probe, const char *psz_name,
204 const char *psz_longname);
206 #define VLC_RD_PROBE_HELPER(name, longname) \
207 static int vlc_rd_probe_open(vlc_object_t *obj) \
209 return vlc_rd_probe_add((struct vlc_probe_t *)obj, name, longname); \
212 #define VLC_RD_PROBE_SUBMODULE \
213 add_submodule() \
214 set_capability("renderer probe", 100) \
215 set_callbacks(vlc_rd_probe_open, NULL)
217 /** @} @} */
219 #endif