[vlc-devel] commit: folder meta data retriver: some enhancements ( Rafaël Carré )

git version control git at videolan.org
Tue Jul 7 01:55:59 CEST 2009


vlc | branch: master | Rafaël Carré <rafael.carre at gmail.com> | Tue Jul  7 01:52:36 2009 +0200| [0af7d430b683d44c1eacbbcf378570af292d3ac6] | committer: Rafaël Carré 

folder meta data retriver: some enhancements

Add rockbox's cover.jpg to the list of known files
Give the possibility to add a custom filename with --album-art-filename
Properly handle URIs on Win32 and other
Cleaner code

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=0af7d430b683d44c1eacbbcf378570af292d3ac6
---

 modules/meta_engine/folder.c |   69 ++++++++++++++++++++++-------------------
 1 files changed, 37 insertions(+), 32 deletions(-)

diff --git a/modules/meta_engine/folder.c b/modules/meta_engine/folder.c
index 5a0c3a0..ae0091d 100644
--- a/modules/meta_engine/folder.c
+++ b/modules/meta_engine/folder.c
@@ -43,6 +43,15 @@
 #   define MAX_PATH 250
 #endif
 
+static const char* cover_files[] = {
+    "Folder.jpg",           /* Windows */
+    "AlbumArtSmall.jpg",    /* Windows */
+    ".folder.png",          /* KDE?    */
+    "cover.jpg",            /* rockbox */
+};
+
+static const int i_covers = (sizeof(cover_files)/sizeof(cover_files[0]));
+
 /*****************************************************************************
  * Local prototypes
  *****************************************************************************/
@@ -55,7 +64,8 @@ static int FindMeta( vlc_object_t * );
 vlc_module_begin ()
     set_shortname( N_( "Folder" ) )
     set_description( N_("Folder meta data") )
-
+    add_file( "album-art-filename", NULL, NULL,
+        N_("Album art filename"), N_("Filename to look for album art in current directory"), false );
     set_capability( "art finder", 90 )
     set_callbacks( FindMeta, NULL )
 vlc_module_end ()
@@ -67,9 +77,10 @@ static int FindMeta( vlc_object_t *p_this )
     input_item_t *p_item = (input_item_t *)p_this->p_private;
     bool b_have_art = false;
 
-    int i = 0;
+    int i;
     struct stat a;
     char psz_filename[MAX_PATH];
+
     if( !p_item )
         return VLC_EGENERIC;
 
@@ -77,43 +88,37 @@ static int FindMeta( vlc_object_t *p_this )
     if( !psz_dir )
         return VLC_EGENERIC;
 
-    char *psz_buf = strrchr( psz_dir, '/' );
-    if( psz_buf )
-    {
-        psz_buf++;
-        *psz_buf = '\0';
-    }
-    else
+    char *psz_path = psz_dir;
+    if( strncmp( psz_path, "file://", 7 ) || !decode_URI( psz_path + 7 ) )
     {
-        *psz_dir = '\0';
+        free( psz_dir );
+        return VLC_EGENERIC;
     }
 
-    char *psz_path = psz_dir;
-    if( !strncmp( psz_path, "file://", 7 ) )
-        psz_path += 7;
+#if defined(WIN32) && !defined(UNDER_CE)
+    psz_path += 8;
+#else
+    psz_path += 7;
+#endif
+
+    char *psz_buf = strrchr( psz_path, '/' );
+    if( psz_buf )
+        *++psz_buf = '\0';
+    else
+        *psz_path = '\0'; /* relative path */
 
-    for( i = 0; b_have_art == false && i < 3; i++ )
+    for( i = -1; !b_have_art && i < i_covers; i++ )
     {
-        switch( i )
+        if( i == -1 ) /* higher priority : configured filename */
         {
-            case 0:
-            /* Windows Folder.jpg */
-            snprintf( psz_filename, MAX_PATH,
-                      "%sFolder.jpg", psz_path );
-            break;
-
-            case 1:
-            /* Windows AlbumArtSmall.jpg == small version of Folder.jpg */
-            snprintf( psz_filename, MAX_PATH,
-                  "%sAlbumArtSmall.jpg", psz_path );
-            break;
-
-            case 2:
-            /* KDE (?) .folder.png */
-            snprintf( psz_filename, MAX_PATH,
-                  "%s.folder.png", psz_path );
-            break;
+            char *psz_userfile = config_GetPsz( p_this, "filename" );
+            if( !psz_userfile )
+                continue;
+            snprintf( psz_filename, MAX_PATH, "%s%s", psz_path, psz_userfile );
+            free( psz_userfile );
         }
+        else
+            snprintf( psz_filename, MAX_PATH, "%s%s", psz_path, cover_files[i] );
 
         if( utf8_stat( psz_filename, &a ) != -1 )
         {




More information about the vlc-devel mailing list