Commit 22532b5c authored by Francois Cartegnie's avatar Francois Cartegnie

podcasts: ensure saved urls are loaded before change. fix #4337

Podcast module does not have previous session urls loaded when a
change request is called first. As this list is also saved on any
change, the original list is lost.
parent 7fab4e77
...@@ -100,6 +100,7 @@ struct services_discovery_sys_t ...@@ -100,6 +100,7 @@ struct services_discovery_sys_t
vlc_mutex_t lock; vlc_mutex_t lock;
vlc_cond_t wait; vlc_cond_t wait;
bool b_update; bool b_update;
bool b_savedurls_loaded;
char *psz_request; char *psz_request;
int update_type; int update_type;
}; };
...@@ -136,6 +137,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -136,6 +137,7 @@ static int Open( vlc_object_t *p_this )
vlc_mutex_init( &p_sys->lock ); vlc_mutex_init( &p_sys->lock );
vlc_cond_init( &p_sys->wait ); vlc_cond_init( &p_sys->wait );
p_sys->b_update = true; p_sys->b_update = true;
p_sys->b_savedurls_loaded = false;
p_sys->psz_request = NULL; p_sys->psz_request = NULL;
p_sys->update_type = UPDATE_URLS; p_sys->update_type = UPDATE_URLS;
...@@ -293,6 +295,7 @@ static void ParseUrls( services_discovery_t *p_sd, char *psz_urls ) ...@@ -293,6 +295,7 @@ static void ParseUrls( services_discovery_t *p_sd, char *psz_urls )
int i_new_urls = 0; int i_new_urls = 0;
char **ppsz_new_urls = NULL; char **ppsz_new_urls = NULL;
p_sys->b_savedurls_loaded = true;
int i, j; int i, j;
...@@ -363,6 +366,14 @@ static void ParseRequest( services_discovery_t *p_sd ) ...@@ -363,6 +366,14 @@ static void ParseRequest( services_discovery_t *p_sd )
char *psz_tok = strchr( psz_request, ':' ); char *psz_tok = strchr( psz_request, ':' );
if( !psz_tok ) return; if( !psz_tok ) return;
*psz_tok = '\0'; *psz_tok = '\0';
if ( ! p_sys->b_savedurls_loaded )
{
char* psz_urls = var_GetNonEmptyString( p_sd, "podcast-urls" );
ParseUrls( p_sd, psz_urls );
free( psz_urls );
}
if( !strcmp( psz_request, "ADD" ) ) if( !strcmp( psz_request, "ADD" ) )
{ {
psz_request = psz_tok + 1; psz_request = psz_tok + 1;
......
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