+
+//---------------------------------------------------------------------------
+// DemuxOpen: initialize demux
+//---------------------------------------------------------------------------
+static int DemuxOpen( vlc_object_t *p_this )
+{
+ demux_t *p_demux = (demux_t*)p_this;
+ intf_thread_t *p_intf;
+ char *ext;
+
+ // Needed callbacks
+ p_demux->pf_demux = Demux;
+ p_demux->pf_control = DemuxControl;
+
+ // Test that we have a valid .vlt or .wsz file, based on the extension
+ // TODO: an actual check of the contents would be better...
+ if( ( ext = strchr( p_demux->psz_path, '.' ) ) == NULL ||
+ ( strcasecmp( ext, ".vlt" ) && strcasecmp( ext, ".wsz" ) ) )
+ {
+ return VLC_EGENERIC;
+ }
+
+ p_intf = (intf_thread_t *)vlc_object_find( p_this, VLC_OBJECT_INTF,
+ FIND_ANYWHERE );
+ if( p_intf != NULL )
+ {
+ // Do nothing is skins2 is not the main interface
+ if( var_Type( p_intf, "skin-to-load" ) == VLC_VAR_STRING )
+ {
+ playlist_t *p_playlist =
+ (playlist_t *) vlc_object_find( p_this, VLC_OBJECT_PLAYLIST,
+ FIND_ANYWHERE );
+ if( p_playlist != NULL )
+ {
+ // Make sure the item is deleted afterwards
+ /// \bug does not always work
+ p_playlist->status.p_item->i_flags |= PLAYLIST_REMOVE_FLAG;
+ vlc_object_release( p_playlist );
+ }
+
+ vlc_value_t val;
+ val.psz_string = p_demux->psz_path;
+ var_Set( p_intf, "skin-to-load", val );
+ }
+ else
+ {
+ msg_Warn( p_this,
+ "skin could not be loaded (not using skins2 intf)" );
+ }
+
+ vlc_object_release( p_intf );
+ }
+
+ return VLC_SUCCESS;
+}
+
+
+//---------------------------------------------------------------------------
+// Demux: return EOF
+//---------------------------------------------------------------------------
+static int Demux( demux_t *p_demux )
+{
+ return 0;
+}
+
+
+//---------------------------------------------------------------------------
+// DemuxControl
+//---------------------------------------------------------------------------
+static int DemuxControl( demux_t *p_demux, int i_query, va_list args )
+{
+ return demux2_vaControlHelper( p_demux->s, 0, 0, 0, 1, i_query, args );
+}
+
+
+//---------------------------------------------------------------------------
+// Callbacks
+//---------------------------------------------------------------------------
+
+/// Callback for the systray configuration option
+static int onSystrayChange( vlc_object_t *pObj, const char *pVariable,
+ vlc_value_t oldVal, vlc_value_t newVal,
+ void *pParam )
+{
+ intf_thread_t *pIntf =
+ (intf_thread_t*)vlc_object_find( pObj, VLC_OBJECT_INTF, FIND_ANYWHERE );
+
+ if( pIntf == NULL )
+ {
+ return VLC_EGENERIC;
+ }
+
+ // Check that we found the correct interface (same check as for the demux)
+ if( var_Type( pIntf, "skin-to-load" ) == VLC_VAR_STRING )
+ {
+ AsyncQueue *pQueue = AsyncQueue::instance( pIntf );
+ if( newVal.b_bool )
+ {
+ CmdAddInTray *pCmd = new CmdAddInTray( pIntf );
+ pQueue->push( CmdGenericPtr( pCmd ) );
+ }
+ else
+ {
+ CmdRemoveFromTray *pCmd = new CmdRemoveFromTray( pIntf );
+ pQueue->push( CmdGenericPtr( pCmd ) );
+ }
+ }
+
+ vlc_object_release( pIntf );
+ return VLC_SUCCESS;
+}
+
+
+/// Callback for the systray configuration option
+static int onTaskBarChange( vlc_object_t *pObj, const char *pVariable,
+ vlc_value_t oldVal, vlc_value_t newVal,
+ void *pParam )
+{
+ intf_thread_t *pIntf =
+ (intf_thread_t*)vlc_object_find( pObj, VLC_OBJECT_INTF, FIND_ANYWHERE );
+
+ if( pIntf == NULL )
+ {
+ return VLC_EGENERIC;
+ }
+
+ // Check that we found the correct interface (same check as for the demux)
+ if( var_Type( pIntf, "skin-to-load" ) == VLC_VAR_STRING )
+ {
+ AsyncQueue *pQueue = AsyncQueue::instance( pIntf );
+ if( newVal.b_bool )
+ {
+ CmdAddInTaskBar *pCmd = new CmdAddInTaskBar( pIntf );
+ pQueue->push( CmdGenericPtr( pCmd ) );
+ }
+ else
+ {
+ CmdRemoveFromTaskBar *pCmd = new CmdRemoveFromTaskBar( pIntf );
+ pQueue->push( CmdGenericPtr( pCmd ) );
+ }
+ }
+
+ vlc_object_release( pIntf );
+ return VLC_SUCCESS;
+}
+
+