Commit d37194a3 authored by Antoine Cellerier's avatar Antoine Cellerier

Genre standardisation patch by Jonas A. Larsen

This (and previous patch) still needs some work as genres containing spaces
aren't parsed correctly
parent 24c07775
...@@ -153,7 +153,7 @@ static int Demux( demux_t *p_demux ) ...@@ -153,7 +153,7 @@ static int Demux( demux_t *p_demux )
p_bitrate = playlist_NodeCreate( p_playlist, p_current->pp_parents[0]->i_view, "Bitrate", p_current ); p_bitrate = playlist_NodeCreate( p_playlist, p_current->pp_parents[0]->i_view, "Bitrate", p_current );
playlist_CopyParents( p_current, p_bitrate ); playlist_CopyParents( p_current, p_bitrate );
} }
p_xml = p_sys->p_xml = xml_Create( p_demux ); p_xml = p_sys->p_xml = xml_Create( p_demux );
if( !p_xml ) return -1; if( !p_xml ) return -1;
...@@ -245,7 +245,7 @@ static int Demux( demux_t *p_demux ) ...@@ -245,7 +245,7 @@ static int Demux( demux_t *p_demux )
if( psz_elname ) free( psz_elname ); if( psz_elname ) free( psz_elname );
psz_elname = xml_ReaderName( p_xml_reader ); psz_elname = xml_ReaderName( p_xml_reader );
if( !psz_elname ) return -1; if( !psz_elname ) return -1;
// Read the attributes // Read the attributes
while( xml_ReaderNextAttr( p_xml_reader ) == VLC_SUCCESS ) while( xml_ReaderNextAttr( p_xml_reader ) == VLC_SUCCESS )
...@@ -358,25 +358,41 @@ static int Demux( demux_t *p_demux ) ...@@ -358,25 +358,41 @@ static int Demux( demux_t *p_demux )
/* We need to declare the parents of the node as the /* We need to declare the parents of the node as the
* * same of the parent's ones */ * * same of the parent's ones */
playlist_CopyParents( p_current, p_item ); playlist_CopyParents( p_current, p_item );
vlc_input_item_CopyOptions( &p_current->input, vlc_input_item_CopyOptions( &p_current->input,
&p_item->input ); &p_item->input );
if( b_shoutcast ) if( b_shoutcast )
{ {
char *psz_genreToken; char *psz_genreToken;
char *psz_otherToken; char *psz_otherToken;
int i = 0;
psz_genreToken = psz_genre; psz_genreToken = psz_genre;
while ( psz_genreToken && ( psz_otherToken = get_next_token(psz_genreToken ))) /* split up the combined genre string form
{ shoutcast and add the individual genres */
ShoutcastAdd( p_playlist, p_genre, p_bitrate, p_item, while ( psz_genreToken &&
psz_genreToken, psz_bitrate ); ( psz_otherToken = get_next_token(psz_genreToken )))
{
psz_genreToken = psz_otherToken; if( strlen(psz_genreToken)>2 )
} /* We dont want genres below 2 letters,
} this gets rid of alot of junk*/
{
/* lowercase everything */
for( i=0; psz_genreToken[i]!=0; i++ )
psz_genreToken[i] =
tolower(psz_genreToken[i]);
/* Make first letter uppercase, purely cosmetical */
psz_genreToken[0] =
toupper( psz_genreToken[0] );
ShoutcastAdd( p_playlist, p_genre,
p_bitrate, p_item,
psz_genreToken, psz_bitrate );
psz_genreToken = psz_otherToken;
}
}
}
#define FREE(a) if( a ) free( a ); a = NULL; #define FREE(a) if( a ) free( a ); a = NULL;
FREE( psz_name ); FREE( psz_name );
......
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