X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Flibrary.c;h=62bed435c418ee05c2fe3b150fa8e78994b5a161;hb=1c89c188a41c41440a606b17b3baae58c0dbc793;hp=148f720aad6a9b64412db185e17e4b969f9c5fac;hpb=8a535461da984c7a3f80445a41a092d6f37b5b4b;p=melted_gui diff --git a/src/library.c b/src/library.c index 148f720..62bed43 100644 --- a/src/library.c +++ b/src/library.c @@ -57,28 +57,39 @@ int omnplay_library_normalize_item(omnplay_instance_t* app, playlist_item_t* ite { int r = 0; playlist_item_t* lib; + playlist_item_t prev; pthread_mutex_lock(&app->library.lock); + prev = *item; + lib = omnplay_library_find(app, item->id); item->error = 0; if(lib) { - if(!item->title[0]) { strcpy(item->title, lib->title); - r = 1; + r++; }; - if(!item->dur || item->in < lib->in || (item->in + item->dur) > (lib->in + lib->dur)) + if(item->in < lib->in || item->in >= (lib->in + lib->dur)) { - item->dur = lib->dur; item->in = lib->in; - r = 1; + r++; + }; + + if(!item->dur || (item->in + item->dur) > (lib->in + lib->dur)) + { + item->dur = lib->in + lib->dur - item->in; + r++; }; + + if(r) + g_warning("omnplay_library_normalize_item: [%s,%d,%d]->[%s,%d,%d]\n", + prev.title, prev.in, prev.dur, item->title, item->in, item->dur); } else {