[vlc-devel] commit: probe: helpers for services discovery ( Rémi Denis-Courmont )
git version control
git at videolan.org
Mon Dec 21 20:46:03 CET 2009
vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Sun Dec 20 01:51:38 2009 +0200| [ace8442cc7b676b95aac14c6b93985657e020aa6] | committer: Rémi Denis-Courmont
probe: helpers for services discovery
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=ace8442cc7b676b95aac14c6b93985657e020aa6
---
include/vlc_services_discovery.h | 23 ++++++++++++++++++++---
src/libvlccore.sym | 1 +
src/playlist/services_discovery.c | 19 +++++++++++++++++--
3 files changed, 38 insertions(+), 5 deletions(-)
diff --git a/include/vlc_services_discovery.h b/include/vlc_services_discovery.h
index f6eaa0e..7094def 100644
--- a/include/vlc_services_discovery.h
+++ b/include/vlc_services_discovery.h
@@ -24,6 +24,10 @@
#ifndef VLC_SERVICES_DISCOVERY_H_
#define VLC_SERVICES_DISCOVERY_H_
+#include <vlc_input.h>
+#include <vlc_events.h>
+#include <vlc_probe.h>
+
/**
* \file
* This file functions and structures for service discovery in vlc
@@ -37,9 +41,6 @@ extern "C" {
* @{
*/
-#include <vlc_input.h>
-#include <vlc_events.h>
-
struct services_discovery_t
{
VLC_COMMON_MEMBERS
@@ -88,6 +89,22 @@ VLC_EXPORT( vlc_event_manager_t *, services_discovery_EventManager, ( services_
VLC_EXPORT( void, services_discovery_AddItem, ( services_discovery_t * p_this, input_item_t * p_item, const char * psz_category ) );
VLC_EXPORT( void, services_discovery_RemoveItem, ( services_discovery_t * p_this, input_item_t * p_item ) );
+
+/* SD probing */
+
+VLC_EXPORT(int, vlc_sd_probe_Add, (vlc_probe_t *, const char *, const char *));
+
+#define VLC_SD_PROBE_SUBMODULE \
+ add_submodule() \
+ set_capability( "services probe", 100 ) \
+ set_callbacks( vlc_sd_probe_Open, NULL )
+
+#define VLC_SD_PROBE_HELPER(name, longname) \
+static int vlc_sd_probe_Open (vlc_object_t *obj) \
+{ \
+ return vlc_sd_probe_Add ((struct vlc_probe_t *)obj, name, longname); \
+}
+
/** @} */
# ifdef __cplusplus
}
diff --git a/src/libvlccore.sym b/src/libvlccore.sym
index fb1480a..5b895e4 100644
--- a/src/libvlccore.sym
+++ b/src/libvlccore.sym
@@ -537,6 +537,7 @@ vlc_rwlock_wrlock
vlc_savecancel
vlc_sd_Create
vlc_sd_GetNames
+vlc_sd_probe_Add
vlc_sdp_Start
vlc_sd_Start
vlc_sd_Stop
diff --git a/src/playlist/services_discovery.c b/src/playlist/services_discovery.c
index 35547c8..355dffb 100644
--- a/src/playlist/services_discovery.c
+++ b/src/playlist/services_discovery.c
@@ -33,14 +33,29 @@
#include "playlist_internal.h"
#include "../libvlc.h"
-#undef vlc_sd_GetNames
-
typedef struct
{
char *name;
char *longname;
} vlc_sd_probe_t;
+int vlc_sd_probe_Add (vlc_probe_t *probe, const char *name,
+ const char *longname)
+{
+ vlc_sd_probe_t names = { strdup(name), strdup(longname) };
+
+ if (unlikely (names.name == NULL || names.longname == NULL
+ || vlc_probe_add (probe, &names, sizeof (names))))
+ {
+ free (names.name);
+ free (names.longname);
+ return VLC_ENOMEM;
+ }
+ return VLC_PROBE_CONTINUE;
+}
+
+#undef vlc_sd_GetNames
+
/**
* Gets the list of available services discovery plugins.
*/
More information about the vlc-devel
mailing list