Make the iTunes XML scanner more flexible when trying to match paths

in the XML file with paths in the library. Also simplyfies the code.
This commit is contained in:
ejurgensen 2013-08-20 22:46:21 +02:00
parent 6e9cf3a243
commit 0abc9f04f2

View File

@ -260,20 +260,20 @@ check_meta(plist_t dict)
return 0; return 0;
} }
/* Best-effort attempt at locating the file:
* - first exact location given in itml
* - somewhere under the location of itml
* - anywhere (filename only)
*/
static int static int
find_track_file(char *location, char *base) find_track_file(char *location)
{ {
char *filename;
int plen; int plen;
int mfi_id; int mfi_id;
char *filename;
location = evhttp_decode_uri(location); location = evhttp_decode_uri(location);
if (!location)
{
DPRINTF(E_LOG, L_SCAN, "Could not decode iTunes XML playlist url.\n");
return 0;
}
plen = strlen("file://localhost/"); plen = strlen("file://localhost/");
@ -287,52 +287,30 @@ find_track_file(char *location, char *base)
else else
plen -= 1; plen -= 1;
/* Try exact path first */ /* Now look for location in the library, first using full path, gradually shorten, finally just with filename */
filename = m_realpath(location + plen); filename = location + plen;
if (filename) while (filename && !(mfi_id = db_file_id_bypathpattern(filename)))
{ {
mfi_id = db_file_id_bypath(filename); DPRINTF(E_SPAM, L_SCAN, "XML playlist filename is now %s\n", filename);
filename = strchr(filename + 1, '/');
free(filename);
if (mfi_id > 0)
{
free(location);
return mfi_id;
}
} }
filename = strrchr(location, '/'); /* Found */
if (!filename) if (filename && mfi_id > 0)
{ {
DPRINTF(E_WARN, L_SCAN, "Could not extract filename from location\n"); DPRINTF(E_DBG, L_SCAN, "Found iTunes XML playlist entry match, id is %d, filename is %s\n", mfi_id, filename);
free(location); free(location);
return 0;
}
filename++;
/* Try to locate the file under the playlist location */
mfi_id = db_file_id_byfilebase(filename, base);
if (mfi_id > 0)
{
free(location);
return mfi_id; return mfi_id;
} }
/* Last resort, filename only */ /* Not found */
mfi_id = db_file_id_byfile(filename);
free(location); free(location);
return 0;
return mfi_id;
} }
static int static int
process_track_file(plist_t trk, char *base) process_track_file(plist_t trk)
{ {
char *location; char *location;
struct media_file_info *mfi; struct media_file_info *mfi;
@ -354,7 +332,7 @@ process_track_file(plist_t trk, char *base)
return 0; return 0;
} }
mfi_id = find_track_file(location, base); mfi_id = find_track_file(location);
if (mfi_id <= 0) if (mfi_id <= 0)
{ {
@ -466,7 +444,7 @@ process_track_stream(plist_t trk)
} }
static int static int
process_tracks(plist_t tracks, char *base) process_tracks(plist_t tracks)
{ {
plist_t trk; plist_t trk;
plist_dict_iter iter; plist_dict_iter iter;
@ -537,7 +515,7 @@ process_tracks(plist_t tracks, char *base)
if (strcmp(str, "URL") == 0) if (strcmp(str, "URL") == 0)
mfi_id = process_track_stream(trk); mfi_id = process_track_stream(trk);
else if (strcmp(str, "File") == 0) else if (strcmp(str, "File") == 0)
mfi_id = process_track_file(trk, base); mfi_id = process_track_file(trk);
else else
{ {
DPRINTF(E_LOG, L_SCAN, "Unknown track type: %s\n", str); DPRINTF(E_LOG, L_SCAN, "Unknown track type: %s\n", str);
@ -853,7 +831,7 @@ scan_itunes_itml(char *file)
*ptr = '\0'; *ptr = '\0';
ret = process_tracks(node, file); ret = process_tracks(node);
if (ret <= 0) if (ret <= 0)
{ {
DPRINTF(E_WARN, L_SCAN, "No tracks loaded\n"); DPRINTF(E_WARN, L_SCAN, "No tracks loaded\n");