#include "vlc_events.h"
#include <vlc_services_discovery.h>
#include <vlc_probe.h>
+#include <vlc_modules.h>
#include "playlist_internal.h"
#include "../libvlc.h"
* That's how the playlist get's Service Discovery information
*/
-/***********************************************************************
- * Create
+/*******************************************************************//**
+ * Create a Service discovery
***********************************************************************/
services_discovery_t *vlc_sd_Create( vlc_object_t *p_super,
const char *cfg )
{
services_discovery_t *p_sd;
- p_sd = vlc_custom_create( p_super, sizeof( *p_sd ), VLC_OBJECT_GENERIC,
- "services discovery" );
+ p_sd = vlc_custom_create( p_super, sizeof( *p_sd ), "services discovery" );
if( !p_sd )
return NULL;
free(config_ChainCreate( &p_sd->psz_name, &p_sd->p_cfg, cfg ));
vlc_event_manager_t *em = &p_sd->event_manager;
- vlc_event_manager_init( em, p_sd, (vlc_object_t *)p_sd );
+ vlc_event_manager_init( em, p_sd );
vlc_event_manager_register_event_type(em, vlc_ServicesDiscoveryItemAdded);
vlc_event_manager_register_event_type(em, vlc_ServicesDiscoveryItemRemoved);
vlc_event_manager_register_event_type(em, vlc_ServicesDiscoveryStarted);
vlc_event_manager_register_event_type(em, vlc_ServicesDiscoveryEnded);
vlc_object_set_destructor( p_sd, services_discovery_Destructor );
- vlc_object_attach( p_sd, p_super );
-
return p_sd;
}
-/***********************************************************************
- * Stop
+/*******************************************************************//**
+ * Start a Service Discovery
***********************************************************************/
bool vlc_sd_Start ( services_discovery_t * p_sd )
{
return true;
}
-/***********************************************************************
- * Stop
+/*******************************************************************//**
+ * Stop a Service Discovery
***********************************************************************/
void vlc_sd_Stop ( services_discovery_t * p_sd )
{
p_sd->p_module = NULL;
}
+/*******************************************************************//**
+ * Destroy a Service Discovery
+ ***********************************************************************/
void vlc_sd_Destroy( services_discovery_t *p_sd )
{
config_ChainDestroy( p_sd->p_cfg );
vlc_object_release( p_sd );
}
-/***********************************************************************
- * Destructor
+/*******************************************************************//**
+ * Destructor of the Service Discovery
***********************************************************************/
static void services_discovery_Destructor ( vlc_object_t *p_obj )
{
vlc_event_manager_fini( &p_sd->event_manager );
}
-/***********************************************************************
- * GetLocalizedName
+/*******************************************************************//**
+ * Get the Localized Name
+ *
+ * This is useful for interfaces and libVLC
***********************************************************************/
char *
services_discovery_GetLocalizedName ( services_discovery_t * p_sd )
return strdup( module_get_name( p_sd->p_module, true ) );
}
-/***********************************************************************
- * EventManager
+/*******************************************************************//**
+ * Getter for the EventManager
+ *
+ * You can receive event notification
+ * This is the preferred way to get new items
***********************************************************************/
vlc_event_manager_t *
services_discovery_EventManager ( services_discovery_t * p_sd )
return &p_sd->event_manager;
}
-/***********************************************************************
- * AddItem
+/*******************************************************************//**
+ * Add an item to the Service Discovery listing
***********************************************************************/
void
services_discovery_AddItem ( services_discovery_t * p_sd, input_item_t * p_item,
vlc_event_send( &p_sd->event_manager, &event );
}
-/***********************************************************************
- * RemoveItem
+/*******************************************************************//**
+ * Remove an item from the Service Discovery listing
***********************************************************************/
void
services_discovery_RemoveItem ( services_discovery_t * p_sd, input_item_t * p_item )
if( !p_cat )
{
p_cat = playlist_NodeCreate( p_playlist, psz_cat,
- p_parent, 0, NULL );
+ p_parent, PLAYLIST_END, 0, NULL );
p_cat->i_flags &= ~PLAYLIST_SKIP_FLAG;
}
p_parent = p_cat;
PL_LOCK;
p_node = playlist_NodeCreate( p_playlist, psz_longname,
- p_playlist->p_root, 0, NULL );
+ p_playlist->p_root, PLAYLIST_END, 0, NULL );
PL_UNLOCK;
vlc_event_manager_t *em = services_discovery_EventManager( p_sd );
return VLC_EGENERIC;
}
- /* We want tree-view for service directory */
- p_node->p_input->b_prefers_tree = true;
p_sds->p_sd = p_sd;
p_sds->p_node = p_node;
p_sds->psz_name = strdup( psz_name );
return found;
}
+int playlist_ServicesDiscoveryControl( playlist_t *p_playlist, const char *psz_name, int i_control, ... )
+{
+ playlist_private_t *priv = pl_priv( p_playlist );
+ int i_ret = VLC_EGENERIC;
+ int i;
+
+ PL_LOCK;
+ for( i = 0; i < priv->i_sds; i++ )
+ {
+ vlc_sd_internal_t *sd = priv->pp_sds[i];
+ if( sd->psz_name && !strcmp( psz_name, sd->psz_name ) )
+ {
+ va_list args;
+ va_start( args, i_control );
+ i_ret = vlc_sd_control( sd->p_sd, i_control, args );
+ va_end( args );
+ break;
+ }
+ }
+
+ assert( i != priv->i_sds );
+ PL_UNLOCK;
+
+ return i_ret;
+}
+
void playlist_ServicesDiscoveryKillAll( playlist_t *p_playlist )
{
playlist_private_t *priv = pl_priv( p_playlist );