{
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;
+ g_warning("%s: [%s] title=[%s]->[%s]", __FUNCTION__, item->id, prev.title, item->title);
+ 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;
+ g_warning("%s: [%s] (item->in=[%d] < lib->in=[%d] || item->in=[%d] >= (lib->in=[%d] + lib->dur=[%d]))",
+ __FUNCTION__, item->id,
+ item->in, lib->in, item->in, lib->in, lib->dur);
+
item->in = lib->in;
- r = 1;
+
+ g_warning("%s: [%s] in=[%d]->[%d]", __FUNCTION__, item->id, prev.in, item->in);
+
+ r++;
+ };
+
+ if(!item->dur || (item->in + item->dur) > (lib->in + lib->dur))
+ {
+ g_warning("%s: [%s] (!item->dur=[%d] || (item->in=[%d] + item->dur=[%d]) > (lib->in=[%d] + lib->dur=[%d])",
+ __FUNCTION__, item->id,
+ item->dur, item->in, item->dur, lib->in, lib->dur);
+
+ item->dur = lib->in + lib->dur - item->in;
+
+ g_warning("%s: [%s] dur=[%d]->[%d]", __FUNCTION__, item->id, prev.dur, item->dur);
+
+ r++;
};
}
else
return r;
};
+int omnplay_library_relink_item(omnplay_instance_t* app, playlist_item_t* item)
+{
+ int r = 0;
+ playlist_item_t* lib;
+
+ pthread_mutex_lock(&app->library.lock);
+
+ lib = omnplay_library_find(app, item->id);
+
+ item->error = 0;
+
+ if(lib)
+ {
+ r = 1;
+ strcpy(item->title, lib->title);
+ item->dur = lib->dur;
+ item->in = lib->in;
+ }
+ 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)
{
int i, j, m;
/* open and process file */
if((f = fopen(filename, "rt")))
{
- while( !feof(f) && c < (limit -1))
+ while(!feof(f) && c < limit)
{
char *s, *sp_r, *sp_b;
{
memset(&item, 0, sizeof(playlist_item_t));
+ g_warning("%s: [%s]", __FUNCTION__, l);
+
for(i = 0, sp_b = l; (NULL != (sp_r = strtok(sp_b, "\t"))); i++, sp_b = NULL)
{
+ g_warning("%s: [%d]=[%s]", __FUNCTION__, i, sp_r);
+
switch(i)
{
case 0: strncpy(item.id, sp_r, PATH_MAX); break;
/* insert item */
items[c++] = item;
- };
+ g_warning("%s: id=[%s], in=[%d], dur=[%d]", __FUNCTION__, item.id, item.in, item.dur);
+ }
+ else
+ g_warning("omnplay_library_load_file: ignored line [%s]\n", l);
}
fclose(f);
*pcount = c;
+ g_warning("omnplay_library_load_file: loaded [%d] items from [%s] file, limit [%d]\n", c, filename, limit);
+
return r;
};
frames2tc(item[i].in, 25.0, tc_in),
frames2tc(item[i].dur, 25.0, tc_dur),
item[i].title);
-
fclose(f);
+ g_warning("omnplay_library_save_file: written [%d] lines to file [%s]\n", count, filename);
};
};
static void omnplay_get_content_cb(omnplay_instance_t* app, playlist_item_t* item, void* data)
{
- omnplay_set_status(app, item->id);
+ if(!(app->library.id_display_idx % app->library.id_display_rate))
+ omnplay_set_status(app, item->id);
+ app->library.id_display_idx++;
};
static void* omnplay_library_refresh_proc(void* data)