X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Flibrary.c;h=700d5bfe341f5d706fc4896fc4e87ef4a9b2ae7a;hb=5a2f0a475dfa74cb43b5abeb69dce4fd386e2fdb;hp=eefce46050a53bd464a38b17e5db84623b3db8f1;hpb=a4397d674b2f7ea33653ff1137193835c668c7de;p=melted_gui diff --git a/src/library.c b/src/library.c index eefce46..700d5bf 100644 --- a/src/library.c +++ b/src/library.c @@ -48,8 +48,9 @@ playlist_item_t* omnplay_library_find(omnplay_instance_t* app, char* id) return item; }; -void omnplay_library_normalize_item(omnplay_instance_t* app, playlist_item_t* item) +int omnplay_library_normalize_item(omnplay_instance_t* app, playlist_item_t* item) { + int r = 0; playlist_item_t* lib; pthread_mutex_lock(&app->library.lock); @@ -62,18 +63,27 @@ void omnplay_library_normalize_item(omnplay_instance_t* app, playlist_item_t* it { if(!item->title[0]) + { strcpy(item->title, lib->title); + r = 1; + }; - if(!item->dur) + if(!item->dur || item->in < lib->in || (item->in + item->dur) > (lib->in + lib->dur)) { item->dur = lib->dur; item->in = lib->in; + r = 1; }; } else + { + r = 1; item->error = PLAYLIST_ITEM_ERROR_LIB; + }; pthread_mutex_unlock(&app->library.lock); + + return r; }; void omnplay_library_sort(omnplay_instance_t* app) @@ -217,7 +227,6 @@ void omnplay_library_refresh(omnplay_instance_t* app) int count, i; playlist_item_t* items; - items = (playlist_item_t*)malloc(sizeof(playlist_item_t) * MAX_LIBRARY_ITEMS); count = omnplay_get_content(app, items, MAX_LIBRARY_ITEMS, omnplay_get_content_cb, NULL); @@ -242,6 +251,8 @@ void omnplay_library_refresh(omnplay_instance_t* app) }; free(items); + + omnplay_playlist_normalize(app); }; void omnplay_library_draw(omnplay_instance_t* app)