static inline void input_item_SetMeta( input_item_t *p_i, vlc_meta_type_t meta_type, const char *psz_val )
{
vlc_event_t event;
- vlc_mutex_lock( &p_i->p_lock );
+
+ vlc_mutex_lock( &p_i->lock );
if( !p_i->p_meta )
p_i->p_meta = vlc_meta_New();
vlc_meta_Set( p_i->p_meta, meta_type, psz_val );
- vlc_mutex_unlock( &p_i->p_lock );
+ vlc_mutex_unlock( &p_i->lock );
/* Notify interested third parties */
event.type = vlc_InputItemMetaChanged;
static inline char * input_item_GetMeta( input_item_t *p_i, vlc_meta_type_t meta_type )
{
- vlc_mutex_lock( &p_i->p_lock );
+ char * psz = NULL;
+ vlc_mutex_lock( &p_i->lock );
+
if( !p_i->p_meta )
{
- vlc_mutex_unlock( &p_i->p_lock );
+ vlc_mutex_unlock( &p_i->lock );
return NULL;
}
- char *psz_s = strdup( vlc_meta_Get( p_i->p_meta, meta_type ) );
- vlc_mutex_unlock( &p_i->p_lock );
- return psz_s;
+
+ if( vlc_meta_Get( p_i->p_meta, meta_type ) )
+ psz = strdup( vlc_meta_Get( p_i->p_meta, meta_type ) );
+
+ vlc_mutex_unlock( &p_i->lock );
+ return psz;
}
static inline char * input_item_GetName( input_item_t *p_i )
{
- vlc_mutex_lock( &p_i->p_lock );
- char *psz_s = strdup( p_i->psz_name );
- vlc_mutex_unlock( &p_i->p_lock );
+ vlc_mutex_lock( &p_i->lock );
+ char *psz_s = p_i->psz_name ? strdup( p_i->psz_name ) : NULL;
+ vlc_mutex_unlock( &p_i->lock );
return psz_s;
}