VLC  3.0.15
vlc_renderer_discovery.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * vlc_renderer_discovery.h : Renderer Discovery functions
3  *****************************************************************************
4  * Copyright (C) 2016 VLC authors and VideoLAN
5  *
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.
10  *
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.
15  *
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  *****************************************************************************/
20 
21 #ifndef VLC_RENDERER_DISCOVERY_H
22 #define VLC_RENDERER_DISCOVERY_H 1
23 
24 #include <vlc_input.h>
25 #include <vlc_probe.h>
26 #include <vlc_url.h>
27 
28 /**
29  * @defgroup vlc_renderer VLC renderer discovery
30  * @{
31  *
32  * @file
33  * This file declares VLC renderer discvoery structures and functions
34  *
35  * @defgroup vlc_renderer_item VLC renderer items returned by the discovery
36  * @{
37  */
38 
39 #define VLC_RENDERER_CAN_AUDIO 0x0001
40 #define VLC_RENDERER_CAN_VIDEO 0x0002
41 
42 /**
43  * Create a new renderer item
44  *
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
54  */
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;
60 
61 /**
62  * Hold a renderer item, i.e. creates a new reference
63  */
66 
67 /**
68  * Releases a renderer item, i.e. decrements its reference counter
69  */
70 VLC_API void
72 
73 /**
74  * Get the human readable name of a renderer item
75  */
76 VLC_API const char *
78 
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).
82  */
83 VLC_API const char *
85 
86 /**
87  * Get the demux filter to use with a renderer item
88  */
89 VLC_API const char *
91 
92 /**
93  * Get the sout command of a renderer item
94  */
95 VLC_API const char *
97 
98 /**
99  * Get the icon uri of a renderer item
100  */
101 VLC_API const char *
103 
104 /**
105  * Get the flags of a renderer item
106  */
107 VLC_API int
109 
110 /**
111  * @}
112  * @defgroup vlc_renderer_discovery VLC renderer discovery interface
113  * @{
114  */
115 
118 
119 /**
120  * Return a list of renderer discovery modules
121  *
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
125  *
126  * @return VLC_SUCCESS on success, or VLC_EGENERIC on error
127  */
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)
133 
134 /**
135  * Create a new renderer discovery module
136  *
137  * @param psz_name name of the module to load, see vlc_rd_get_names() to get
138  * the list of names
139  *
140  * @return a valid vlc_renderer_discovery, need to be released with
141  * vlc_rd_release()
142  */
144 vlc_rd_new(vlc_object_t *p_obj, const char *psz_name,
145  const struct vlc_renderer_discovery_owner *owner) VLC_USED;
146 
148 
149 /**
150  * @}
151  * @defgroup vlc_renderer_discovery_module VLC renderer module
152  * @{
153  */
154 
156 {
157  void *sys;
159  struct vlc_renderer_item_t *);
161  struct vlc_renderer_item_t *);
162 };
163 
165 {
168 
170 
171  char * psz_name;
173 
175 };
176 
177 /**
178  * Add a new renderer item
179  *
180  * This will send the vlc_RendererDiscoveryItemAdded event
181  */
182 static inline void vlc_rd_add_item(vlc_renderer_discovery_t * p_rd,
183  vlc_renderer_item_t * p_item)
184 {
185  p_rd->owner.item_added(p_rd, p_item);
186 }
187 
188 /**
189  * Add a new renderer item
190  *
191  * This will send the vlc_RendererDiscoveryItemRemoved event
192  */
194  vlc_renderer_item_t * p_item)
195 {
196  p_rd->owner.item_removed(p_rd, p_item);
197 }
198 
199 /**
200  * Renderer Discovery proble helpers
201  */
202 VLC_API int
203 vlc_rd_probe_add(vlc_probe_t *p_probe, const char *psz_name,
204  const char *psz_longname);
205 
206 #define VLC_RD_PROBE_HELPER(name, longname) \
207 static int vlc_rd_probe_open(vlc_object_t *obj) \
208 { \
209  return vlc_rd_probe_add((struct vlc_probe_t *)obj, name, longname); \
210 }
211 
212 #define VLC_RD_PROBE_SUBMODULE \
213  add_submodule() \
214  set_capability("renderer probe", 100) \
215  set_callbacks(vlc_rd_probe_open, NULL)
216 
217 /** @} @} */
218 
219 #endif
VLC_API
#define VLC_API
Definition: fourcc_gen.c:30
VLC_COMMON_MEMBERS
#define VLC_COMMON_MEMBERS
Backward compatibility macro.
Definition: vlc_common.h:453
vlc_common.h
vlc_probe_t
Definition: vlc_probe.h:39
vlc_renderer_item_release
void vlc_renderer_item_release(vlc_renderer_item_t *p_item)
Releases a renderer item, i.e.
Definition: renderer_discovery.c:166
vlc_rd_probe_add
int vlc_rd_probe_add(vlc_probe_t *p_probe, const char *psz_name, const char *psz_longname)
Renderer Discovery proble helpers.
Definition: renderer_discovery.c:184
vlc_rd_get_names
#define vlc_rd_get_names(a, b, c)
Definition: vlc_renderer_discovery.h:131
vlc_renderer_item_type
const char * vlc_renderer_item_type(const vlc_renderer_item_t *p_item)
Get the type (not translated) of a renderer item.
Definition: renderer_discovery.c:117
vlc_renderer_item_hold
vlc_renderer_item_t * vlc_renderer_item_hold(vlc_renderer_item_t *p_item)
Hold a renderer item, i.e.
Definition: renderer_discovery.c:157
vlc_input.h
vlc_renderer_item_sout
const char * vlc_renderer_item_sout(const vlc_renderer_item_t *p_item)
Get the sout command of a renderer item.
Definition: renderer_discovery.c:125
vlc_renderer_discovery_owner::item_added
void(* item_added)(struct vlc_renderer_discovery_t *, struct vlc_renderer_item_t *)
Definition: vlc_renderer_discovery.h:158
vlc_renderer_discovery_t::p_cfg
config_chain_t * p_cfg
Definition: vlc_renderer_discovery.h:172
config_chain_t
Definition: vlc_configuration.h:155
module_t
Internal module descriptor.
Definition: modules.h:79
vlc_renderer_item_flags
int vlc_renderer_item_flags(const vlc_renderer_item_t *p_item)
Get the flags of a renderer item.
Definition: renderer_discovery.c:149
vlc_renderer_item_new
vlc_renderer_item_t * vlc_renderer_item_new(const char *psz_type, const char *psz_name, const char *psz_uri, const char *psz_extra_sout, const char *psz_demux_filter, const char *psz_icon_uri, int i_flags)
Create a new renderer item.
Definition: renderer_discovery.c:56
psz_name
const char * psz_name
Definition: vlc_codecs.h:315
vlc_renderer_discovery_t::p_module
module_t * p_module
Definition: vlc_renderer_discovery.h:167
vlc_renderer_discovery_owner::item_removed
void(* item_removed)(struct vlc_renderer_discovery_t *, struct vlc_renderer_item_t *)
Definition: vlc_renderer_discovery.h:160
vlc_renderer_discovery_owner::sys
void * sys
Definition: vlc_renderer_discovery.h:157
vlc_renderer_item_demux_filter
const char * vlc_renderer_item_demux_filter(const vlc_renderer_item_t *p_item)
Get the demux filter to use with a renderer item.
Definition: renderer_discovery.c:141
vlc_rd_release
void vlc_rd_release(vlc_renderer_discovery_t *p_rd)
Definition: renderer_discovery.c:236
vlc_rd_new
vlc_renderer_discovery_t * vlc_rd_new(vlc_object_t *p_obj, const char *psz_name, const struct vlc_renderer_discovery_owner *owner)
Create a new renderer discovery module.
vlc_rd_remove_item
static void vlc_rd_remove_item(vlc_renderer_discovery_t *p_rd, vlc_renderer_item_t *p_item)
Add a new renderer item.
Definition: vlc_renderer_discovery.h:193
vlc_url.h
vlc_object_t
The main vlc_object_t structure.
Definition: vlc_objects.h:39
vlc_probe.h
vlc_renderer_item_icon_uri
const char * vlc_renderer_item_icon_uri(const vlc_renderer_item_t *p_item)
Get the icon uri of a renderer item.
Definition: renderer_discovery.c:133
VLC_USED
#define VLC_USED
Definition: fourcc_gen.c:31
vlc_renderer_item_t
Definition: renderer_discovery.c:33
vlc_renderer_discovery_t::p_sys
vlc_renderer_discovery_sys * p_sys
Definition: vlc_renderer_discovery.h:174
vlc_renderer_discovery_t::psz_name
char * psz_name
Definition: vlc_renderer_discovery.h:171
vlc_renderer_discovery_t::owner
struct vlc_renderer_discovery_owner owner
Definition: vlc_renderer_discovery.h:169
vlc_renderer_discovery_sys
struct vlc_renderer_discovery_sys vlc_renderer_discovery_sys
Definition: vlc_renderer_discovery.h:116
vlc_rd_add_item
static void vlc_rd_add_item(vlc_renderer_discovery_t *p_rd, vlc_renderer_item_t *p_item)
Add a new renderer item.
Definition: vlc_renderer_discovery.h:182
vlc_renderer_item_name
const char * vlc_renderer_item_name(const vlc_renderer_item_t *p_item)
Get the human readable name of a renderer item.
Definition: renderer_discovery.c:109
vlc_renderer_discovery_owner
Definition: vlc_renderer_discovery.h:155
vlc_renderer_discovery_t
Definition: vlc_renderer_discovery.h:164