X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fmeta_engine%2Ffolder.c;h=e6493e0e2e8d5545a72a26397196d8cba7843f78;hb=e16a922a514fa4d5adcb2bbd4b17ef6b1791035e;hp=00f3288959c4e14a8cd7ba870cd566705a7cb8ae;hpb=e398a81bd261feaada934e7b402b5fed57646593;p=vlc diff --git a/modules/meta_engine/folder.c b/modules/meta_engine/folder.c index 00f3288959..e6493e0e2e 100644 --- a/modules/meta_engine/folder.c +++ b/modules/meta_engine/folder.c @@ -24,14 +24,18 @@ /***************************************************************************** * Preamble *****************************************************************************/ -#define _GNU_SOURCE -#include /* malloc(), free() */ -#include -#include -#include +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include +#include +#include #include -#include +#include +#include +#include #ifdef HAVE_SYS_STAT_H # include @@ -51,12 +55,10 @@ static int FindMeta( vlc_object_t * ); *****************************************************************************/ vlc_module_begin(); -/* set_category( CAT_INTERFACE ); - set_subcategory( SUBCAT_INTERFACE_CONTROL );*/ set_shortname( N_( "Folder" ) ); - set_description( _("Folder meta data") ); + set_description( N_("Folder meta data") ); - set_capability( "art finder", 10 ); + set_capability( "art finder", 90 ); set_callbacks( FindMeta, NULL ); vlc_module_end(); @@ -64,71 +66,66 @@ vlc_module_end(); *****************************************************************************/ static int FindMeta( vlc_object_t *p_this ) { - meta_engine_t *p_me = (meta_engine_t *)p_this; - input_item_t *p_item = p_me->p_item; - vlc_bool_t b_have_art = VLC_FALSE; - uint32_t i_meta; - - if( !p_item->p_meta ) return VLC_EGENERIC; + playlist_t *p_playlist = (playlist_t *)p_this; + input_item_t *p_item = (input_item_t *)(p_playlist->p_private); + bool b_have_art = false; + + int i = 0; + struct stat a; + char psz_filename[MAX_PATH]; + if( !p_item ) + return VLC_EGENERIC; + char *psz_dir = input_item_GetURI( p_item ); + if( !psz_dir ) + return VLC_EGENERIC; - if( p_me->i_mandatory & VLC_META_ENGINE_ART_URL - || p_me->i_optional & VLC_META_ENGINE_ART_URL ) + char *psz_buf = strrchr( psz_dir, '/' ); + if( psz_buf ) + { + psz_buf++; + *psz_buf = '\0'; + } + else { - int i = 0; - struct stat a; - char psz_filename[MAX_PATH]; - char *psz_dir = strdup( p_item->psz_uri ); - char *psz_buf = strrchr( psz_dir, '/' ); + *psz_dir = '\0'; + } - if( psz_buf ) - { - psz_buf++; - *psz_buf = '\0'; - } - else + char *psz_path = psz_dir; + if( !strncmp( psz_path, "file://", 7 ) ) + psz_path += 7; + + for( i = 0; b_have_art == false && i < 3; i++ ) + { + switch( i ) { - *psz_dir = '\0'; + case 0: + /* Windows Folder.jpg */ + snprintf( psz_filename, MAX_PATH, + "file://%sFolder.jpg", psz_path ); + break; + + case 1: + /* Windows AlbumArtSmall.jpg == small version of Folder.jpg */ + snprintf( psz_filename, MAX_PATH, + "file://%sAlbumArtSmall.jpg", psz_path ); + break; + + case 2: + /* KDE (?) .folder.png */ + snprintf( psz_filename, MAX_PATH, + "file://%s.folder.png", psz_path ); + break; } - for( i = 0; b_have_art == VLC_FALSE && i < 3; i++ ) + if( utf8_stat( psz_filename+7, &a ) != -1 ) { - switch( i ) - { - case 0: - /* Windows Folder.jpg */ - snprintf( psz_filename, MAX_PATH, - "file://%sFolder.jpg", psz_dir ); - break; - - case 1: - /* Windows AlbumArtSmall.jpg == small version of Folder.jpg */ - snprintf( psz_filename, MAX_PATH, - "file://%sAlbumArtSmall.jpg", psz_dir ); - break; - - case 2: - /* KDE (?) .folder.png */ - snprintf( psz_filename, MAX_PATH, - "file://%s.folder.png", psz_dir ); - break; - } - - if( utf8_stat( psz_filename+7, &a ) != -1 ) - { - vlc_meta_SetArtURL( p_item->p_meta, psz_filename ); - b_have_art = VLC_TRUE; - } + input_item_SetArtURL( p_item, psz_filename ); + b_have_art = true; } - - free( psz_dir ); } - i_meta = input_GetMetaEngineFlags( p_item->p_meta ); - p_me->i_mandatory &= ~i_meta; - p_me->i_optional &= ~i_meta; - if( p_me->i_mandatory ) - return VLC_EGENERIC; - else - return VLC_SUCCESS; + free( psz_dir ); + + return b_have_art ? VLC_SUCCESS : VLC_EGENERIC; }