Commit ce2b15e3 authored by Rémi Duraffort's avatar Rémi Duraffort

audioScrobbler: cleanup and respect last.fm specifications

(and don't forgot to release object when an error occure)
(cherry picked from commit 83ec2a0e)
Signed-off-by: default avatarRémi Duraffort <ivoire@videolan.org>
parent 85f6917c
...@@ -91,7 +91,7 @@ struct intf_sys_t ...@@ -91,7 +91,7 @@ struct intf_sys_t
int i_nowp_port; /**< port to which submit */ int i_nowp_port; /**< port to which submit */
char *psz_nowp_file; /**< file to which submit */ char *psz_nowp_file; /**< file to which submit */
#endif #endif
bool b_handshaked; /**< are we authenticated ? */ bool b_handshaked; /**< are we authenticated ? */
char psz_auth_token[33]; /**< Authentication token */ char psz_auth_token[33]; /**< Authentication token */
/* data about song currently playing */ /* data about song currently playing */
...@@ -100,12 +100,12 @@ struct intf_sys_t ...@@ -100,12 +100,12 @@ struct intf_sys_t
mtime_t time_pause; /**< time when vlc paused */ mtime_t time_pause; /**< time when vlc paused */
mtime_t time_total_pauses; /**< total time in pause */ mtime_t time_total_pauses; /**< total time in pause */
bool b_submit; /**< do we have to submit ? */ bool b_submit; /**< do we have to submit ? */
bool b_state_cb; /**< if we registered the bool b_state_cb; /**< if we registered the
* "state" callback */ * "state" callback */
bool b_meta_read; /**< if we read the song's bool b_meta_read; /**< if we read the song's
* metadata already */ * metadata already */
}; };
...@@ -574,30 +574,31 @@ static void AddToQueue ( intf_thread_t *p_this ) ...@@ -574,30 +574,31 @@ static void AddToQueue ( intf_thread_t *p_this )
p_sys->time_total_pauses; p_sys->time_total_pauses;
played_time /= 1000000; /* µs → s */ played_time /= 1000000; /* µs → s */
if( ( played_time < 60 ) && /*HACK: it seam that the preparsing sometime fail,
( played_time < ( p_sys->p_current_song.i_l / 2 ) ) ) so use the playing time as the song length */
if( p_sys->p_current_song.i_l == 0 )
p_sys->p_current_song.i_l = played_time;
/* Don't send song shorter than 30s */
if( p_sys->p_current_song.i_l < 30 )
{ {
msg_Dbg( p_this, "Song not listened long enough, not submitting" ); msg_Dbg( p_this, "Song too short (< 30s), not submitting" );
goto end; goto end;
} }
if( p_sys->p_current_song.i_l < 30 ) /* Send if the user had listen more than 240s OR half the track length */
if( ( played_time < 240 ) &&
( played_time < ( p_sys->p_current_song.i_l / 2 ) ) )
{ {
if( played_time < 30 ) msg_Dbg( p_this, "Song not listened long enough, not submitting" );
{ goto end;
msg_Dbg( p_this, "Song too short (< 30s), not submitting" );
goto end;
}
else
/* This is a HACK to avoid length = 0 (seems to be rejected by audioscrobbler) */
p_sys->p_current_song.i_l = played_time;
} }
/* Check that all meta are present */
if( !p_sys->p_current_song.psz_a || !*p_sys->p_current_song.psz_a || if( !p_sys->p_current_song.psz_a || !*p_sys->p_current_song.psz_a ||
!p_sys->p_current_song.psz_t || !*p_sys->p_current_song.psz_t ) !p_sys->p_current_song.psz_t || !*p_sys->p_current_song.psz_t )
{ {
msg_Dbg( p_this, "Missing artist or title, not submitting" ); msg_Dbg( p_this, "Missing artist or title, not submitting" );
/*XXX*/ msg_Dbg( p_this, "%s %s", p_sys->p_current_song.psz_a, p_sys->p_current_song.psz_t );
goto end; goto end;
} }
...@@ -951,6 +952,8 @@ static int ReadMetaData( intf_thread_t *p_this ) ...@@ -951,6 +952,8 @@ static int ReadMetaData( intf_thread_t *p_this )
a = encode_URI_component( psz_meta ); \ a = encode_URI_component( psz_meta ); \
if( !a ) \ if( !a ) \
{ \ { \
vlc_mutex_unlock( &p_sys->lock ); \
vlc_object_release( p_input ); \
free( psz_meta ); \ free( psz_meta ); \
return VLC_ENOMEM; \ return VLC_ENOMEM; \
} \ } \
......
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