Commit 5423c650 authored by Clément Stenac's avatar Clément Stenac

Fix a bunch of bugs in the MSN plugin (duplicated in the Growl plugin)

parent e1c2a990
...@@ -99,7 +99,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -99,7 +99,7 @@ static int Open( vlc_object_t *p_this )
if( !p_playlist ) if( !p_playlist )
{ {
msg_Err( p_intf, "could not find playlist object" ); msg_Err( p_intf, "could not find playlist object" );
return -1; return VLC_ENOOBJ;
} }
var_AddCallback( p_playlist, "playlist-current", ItemChange, p_intf ); var_AddCallback( p_playlist, "playlist-current", ItemChange, p_intf );
...@@ -108,7 +108,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -108,7 +108,7 @@ static int Open( vlc_object_t *p_this )
RegisterToGrowl( p_this ); RegisterToGrowl( p_this );
p_intf->pf_run = Run; p_intf->pf_run = Run;
return 0; return VLC_SUCCESS;
} }
/***************************************************************************** /*****************************************************************************
...@@ -116,6 +116,17 @@ static int Open( vlc_object_t *p_this ) ...@@ -116,6 +116,17 @@ static int Open( vlc_object_t *p_this )
*****************************************************************************/ *****************************************************************************/
static void Close( vlc_object_t *p_this ) static void Close( vlc_object_t *p_this )
{ {
playlist_t *p_playlist = (playlist_t *)vlc_object_find(
p_this, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist )
{
var_DelCallback( p_playlist, "playlist-current", ItemChange, p_this );
vlc_object_release( p_playlist );
return VLC_EGENERIC;
}
} }
/***************************************************************************** /*****************************************************************************
...@@ -133,23 +144,32 @@ static int ItemChange( vlc_object_t *p_this, const char *psz_var, ...@@ -133,23 +144,32 @@ static int ItemChange( vlc_object_t *p_this, const char *psz_var,
vlc_value_t oldval, vlc_value_t newval, void *param ) vlc_value_t oldval, vlc_value_t newval, void *param )
{ {
char psz_tmp[GROWL_MAX_LENGTH]; char psz_tmp[GROWL_MAX_LENGTH];
playlist_t *p_playlist;
char *psz_title = NULL; char *psz_title = NULL;
char *psz_artist = NULL; char *psz_artist = NULL;
char *psz_album = NULL; char *psz_album = NULL;
input_thread_t *p_input;
input_thread_t *p_input = p_playlist = (playlist_t *)vlc_object_find( p_this, VLC_OBJECT_INPUT,
(input_thread_t *)vlc_object_find( p_this, VLC_OBJECT_INPUT,
FIND_ANYWHERE ); FIND_ANYWHERE );
if( !p_input || p_input->b_dead || !p_input->input.p_item->psz_name ) if( !p_playlist ) return VLC_EGENERIC;
p_input = p_playlist->p_input;
vlc_object_release( p_playlist );
if( !p_input ) return VLC_SUCCESS;
vlc_object_yield( p_input );
if( p_input->b_dead || !p_input->input.p_item->psz_name )
{ {
/* Not playing anything ... */ /* Not playing anything ... */
vlc_object_release( p_input );
return VLC_SUCCESS; return VLC_SUCCESS;
} }
/* Playing something ... */ /* Playing something ... */
psz_artist = vlc_input_item_GetInfo( p_input->input.p_item, psz_artist = vlc_input_item_GetInfo( p_input->input.p_item,
_("Meta-information"), _("Meta-information"),
VLC_META_ARTIST); _(VLC_META_ARTIST) );
psz_album = vlc_input_item_GetInfo( p_input->input.p_item, psz_album = vlc_input_item_GetInfo( p_input->input.p_item,
_("Meta-information"), _("Meta-information"),
_("Album/movie/show title" ) ); _("Album/movie/show title" ) );
......
...@@ -93,10 +93,6 @@ static int Open( vlc_object_t *p_this ) ...@@ -93,10 +93,6 @@ static int Open( vlc_object_t *p_this )
return -1; return -1;
} }
p_playlist = (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
FIND_ANYWHERE );
p_intf->p_sys->psz_format = config_GetPsz( p_intf, "msn-format" ); p_intf->p_sys->psz_format = config_GetPsz( p_intf, "msn-format" );
if( !p_intf->p_sys->psz_format ) if( !p_intf->p_sys->psz_format )
{ {
...@@ -105,12 +101,15 @@ static int Open( vlc_object_t *p_this ) ...@@ -105,12 +101,15 @@ static int Open( vlc_object_t *p_this )
} }
msg_Dbg( p_intf, "using format: %s", p_intf->p_sys->psz_format ); msg_Dbg( p_intf, "using format: %s", p_intf->p_sys->psz_format );
p_playlist = (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
FIND_ANYWHERE );
if( !p_playlist ) if( !p_playlist )
{ {
msg_Err( p_intf, "could not find playlist object" ); msg_Err( p_intf, "could not find playlist object" );
free( p_intf->p_sys->psz_format ); free( p_intf->p_sys->psz_format );
free( p_intf->p_sys ); free( p_intf->p_sys );
return -1; return VLC_ENOOBJ;
} }
var_AddCallback( p_playlist, "item-change", ItemChange, p_intf ); var_AddCallback( p_playlist, "item-change", ItemChange, p_intf );
...@@ -118,7 +117,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -118,7 +117,7 @@ static int Open( vlc_object_t *p_this )
p_intf->pf_run = Run; p_intf->pf_run = Run;
return 0; return VLC_SUCCESS;
} }
/***************************************************************************** /*****************************************************************************
...@@ -127,11 +126,19 @@ static int Open( vlc_object_t *p_this ) ...@@ -127,11 +126,19 @@ static int Open( vlc_object_t *p_this )
static void Close( vlc_object_t *p_this ) static void Close( vlc_object_t *p_this )
{ {
intf_thread_t *p_intf = (intf_thread_t *)p_this; intf_thread_t *p_intf = (intf_thread_t *)p_this;
playlist_t *p_playlist = (playlist_t *)vlc_object_find(
p_this, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
/* clear the MSN stuff ... else it looks like we're still playing /* clear the MSN stuff ... else it looks like we're still playing
* something although VLC (or the MSN plugin) is closed */ * something although VLC (or the MSN plugin) is closed */
SendToMSN( "\\0Music\\01\\0\\0\\0\\0\\0\\0\\0" ); SendToMSN( "\\0Music\\01\\0\\0\\0\\0\\0\\0\\0" );
if( p_playlist )
{
var_DellCallback( p_playlist, "playlist-current", ItemChange, p_intf );
}
/* Destroy structure */ /* Destroy structure */
free( p_intf->p_sys->psz_format ); free( p_intf->p_sys->psz_format );
free( p_intf->p_sys ); free( p_intf->p_sys );
...@@ -152,30 +159,39 @@ static int ItemChange( vlc_object_t *p_this, const char *psz_var, ...@@ -152,30 +159,39 @@ static int ItemChange( vlc_object_t *p_this, const char *psz_var,
vlc_value_t oldval, vlc_value_t newval, void *param ) vlc_value_t oldval, vlc_value_t newval, void *param )
{ {
intf_thread_t *p_intf = (intf_thread_t *)param; intf_thread_t *p_intf = (intf_thread_t *)param;
playlist_t *p_playlist;
char psz_tmp[MSN_MAX_LENGTH]; char psz_tmp[MSN_MAX_LENGTH];
char *psz_title = NULL; char *psz_title = NULL;
char *psz_artist = NULL; char *psz_artist = NULL;
char *psz_album = NULL; char *psz_album = NULL;
input_thread_t *p_input;
int i,j; int i,j;
if( !p_intf->p_sys ) return VLC_SUCCESS; if( !p_intf->p_sys ) return VLC_SUCCESS;
input_thread_t *p_input = p_playlist = (playlist_t *)vlc_object_find( p_this, VLC_OBJECT_INPUT,
(input_thread_t *)vlc_object_find( p_this, VLC_OBJECT_INPUT,
FIND_ANYWHERE ); FIND_ANYWHERE );
if( !p_input || p_input->b_dead || !p_input->input.p_item->psz_name )
if( !p_playlist ) return VLC_EGENERIC;
p_input = p_playlist->p_input;
vlc_object_release( p_playlist );
if( !p_input ) return VLC_SUCCESS;
vlc_object_yield( p_input );
if( p_input->b_dead || !p_input->input.p_item->psz_name )
{ {
/* Not playing anything ... */ /* Not playing anything ... */
SendToMSN( "\\0Music\\01\\0\\0\\0\\0\\0\\0\\0" ); SendToMSN( "\\0Music\\01\\0\\0\\0\\0\\0\\0\\0" );
vlc_object_release( p_input );
return VLC_SUCCESS; return VLC_SUCCESS;
} }
/* Playing something ... */ /* Playing something ... */
psz_artist = vlc_input_item_GetInfo( p_input->input.p_item, psz_artist = vlc_input_item_GetInfo( p_input->input.p_item,
_("Meta-information"), _("Meta-information"),
VLC_META_ARTIST); _(VLC_META_ARTIST) );
psz_album = vlc_input_item_GetInfo( p_input->input.p_item, psz_album = vlc_input_item_GetInfo( p_input->input.p_item,
_("Meta-information"), _("Meta-information"),
_("Album/movie/show title" ) ); _("Album/movie/show title" ) );
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment