#include "omnplay.h"
#include "ui.h"
+#include "timecode.h"
+
+static int load_file_ply(omnplay_instance_t* app, char* filename)
+{
+ FILE* f;
+ char *ID, *CH, *B, *IN, *OUT, *DUR, *REST, *l;
+ int count = 0, i;
+ playlist_item_t* items;
+
+ /* allocate space for strings and items */
+ items = malloc(sizeof(playlist_item_t) * MAX_PLAYLIST_ITEMS);
+ memset(items, 0, sizeof(playlist_item_t) * MAX_PLAYLIST_ITEMS);
+ ID = malloc(PATH_MAX);
+ CH = malloc(PATH_MAX);
+ B = malloc(PATH_MAX);
+ IN = malloc(PATH_MAX);
+ OUT = malloc(PATH_MAX);
+ DUR = malloc(PATH_MAX);
+ REST = malloc(PATH_MAX);
+ l = malloc(PATH_MAX);
+
+ /* open and process file */
+ f = fopen(filename, "rt");
+ if(f)
+ {
+ while( !feof(f) )
+ {
+ char* s;
+
+ /* load string */
+ memset(l, 0, PATH_MAX);
+ fgets(l, PATH_MAX, f);
+
+ /* remove newlines */
+ if( (s = strchr(l, '\n')) ) *s = 0;
+ if( (s = strchr(l, '\r')) ) *s = 0;
+ if( (s = strchr(l, '\t')) ) *s = 0;
+
+ /* check for empty line */
+ if(l[0] && l[0] != '#')
+ {
+ if (6 != sscanf(l, "%128[^,],%128[^,],%128[^,],%128[^,],%128[^,],%128[^,],%s",
+ ID, CH, B, IN, OUT, DUR, REST))
+ {
+ /* setup item */
+ tc2frames(IN, 25.0, &items[count].in);
+ tc2frames(DUR, 25.0, &items[count].dur);
+ strncpy(items[count].id, ID, PATH_MAX);
+ items[count].player = atol(CH) - 1;
+ switch(atol(B))
+ {
+ case 1: items[count].type = OMNPLAY_PLAYLIST_ITEM_BLOCK_SINGLE; break;
+ case 2: items[count].type = OMNPLAY_PLAYLIST_ITEM_LOOP_BEGIN; break;
+ case 3: items[count].type = OMNPLAY_PLAYLIST_ITEM_LOOP_BODY; break;
+ case 4: items[count].type = OMNPLAY_PLAYLIST_ITEM_LOOP_END; break;
+ case 6: items[count].type = OMNPLAY_PLAYLIST_ITEM_BLOCK_END; break;
+ case 0:
+ if(!count)
+ items[count].type = OMNPLAY_PLAYLIST_ITEM_BLOCK_BEGIN;
+ else if(items[count - 1].type == OMNPLAY_PLAYLIST_ITEM_BLOCK_BEGIN ||
+ items[count - 1].type == OMNPLAY_PLAYLIST_ITEM_BLOCK_BODY)
+ items[count].type = OMNPLAY_PLAYLIST_ITEM_BLOCK_BODY;
+ else
+ items[count].type = OMNPLAY_PLAYLIST_ITEM_BLOCK_BEGIN;
+ break;
+ };
+#if 0
+ {
+ char* n;
+ switch(items[count].type)
+ {
+ case OMNPLAY_PLAYLIST_ITEM_BLOCK_BEGIN: n = "BLOCK_BEGIN"; break;
+ case OMNPLAY_PLAYLIST_ITEM_BLOCK_BODY: n = "BLOCK_BODY"; break;
+ case OMNPLAY_PLAYLIST_ITEM_BLOCK_END: n = "BLOCK_END"; break;
+ case OMNPLAY_PLAYLIST_ITEM_BLOCK_SINGLE: n = "BLOCK_SINGLE"; break;
+ case OMNPLAY_PLAYLIST_ITEM_LOOP_BEGIN: n = "LOOP_BEGIN"; break;
+ case OMNPLAY_PLAYLIST_ITEM_LOOP_BODY: n = "LOOP_BODY"; break;
+ case OMNPLAY_PLAYLIST_ITEM_LOOP_END: n = "LOOP_END"; break;
+ case OMNPLAY_PLAYLIST_ITEM_LOOP_SINGLE: n = "LOOP_SINGLE"; break;
+ };
+ fprintf(stderr, "src=[%s]\ndst=[idx=%d,block=%s,block_id=%d,in=%d,out=%d]\n",
+ l, count, n, items[count].type, items[count].in, items[count].dur);
+ };
+#endif
+
+ count++;
+ }
+ };
+ }
+
+ fclose(f);
+ }
+
+ /* add loaded items to playlist */
+ if(count)
+ {
+ pthread_mutex_lock(&app->playlist.lock);
+ for(i = 0; i < count && app->playlist.count + 1 < MAX_PLAYLIST_ITEMS; i++)
+ {
+ omnplay_library_normalize_item(app, &items[i]);
+ app->playlist.item[app->playlist.count++] = items[i];
+ };
+ app->playlist.ver_curr++;
+ pthread_mutex_unlock(&app->playlist.lock);
+ }
+
+ /* free data */
+ free(items);
+ free(ID);
+ free(CH);
+ free(IN);
+ free(OUT);
+ free(DUR);
+ free(REST);
+ free(l);
+
+ return count;
+};
void omnplay_playlist_load(omnplay_instance_t* app)
{
+ int r;
+ GtkWidget *dialog;
+
+ dialog = gtk_file_chooser_dialog_new("Open File",
+ GTK_WINDOW (app->window),
+ GTK_FILE_CHOOSER_ACTION_OPEN,
+ GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
+ GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT,
+ NULL);
+
+ gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog),
+ (app->playlist.path)?app->playlist.path:getenv("HOME"));
+
+ r = gtk_dialog_run(GTK_DIALOG(dialog));
+
+ if(r == GTK_RESPONSE_ACCEPT)
+ {
+ char *filename;
+
+ filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
+
+ r = load_file_ply(app, filename);
+
+ if(r)
+ omnplay_playlist_draw(app);
+
+ if(app->playlist.path)
+ g_free(app->playlist.path);
+ if((app->playlist.path = filename))
+ {
+ char* e = strrchr(app->playlist.path, '/');
+ if(e) *e = 0;
+ }
+ }
+
+ gtk_widget_destroy (dialog);
};
void omnplay_playlist_save(omnplay_instance_t* app)
{
};
+void omnplay_playlist_draw(omnplay_instance_t* app)
+{
+ int i;
+ char tc1[12], tc2[12];
+ GtkListStore *list_store;
+ GtkTreeIter iter;
+
+ list_store = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(app->playlist_grid)));
+ gtk_list_store_clear(list_store);
+
+ pthread_mutex_lock(&app->playlist.lock);
+
+ for(i = 0;i < app->playlist.count; i++)
+ {
+ gtk_list_store_append(list_store, &iter);
+
+ gtk_list_store_set(list_store, &iter,
+ 0, "",
+ 1, app->playlist.block_icons[app->playlist.item[i].type],
+ 2, (0 == app->playlist.item[i].player)?"A":"B",
+ 3, app->playlist.item[i].id,
+ 4, frames2tc(app->playlist.item[i].in, 25.0, tc1),
+ 5, frames2tc(app->playlist.item[i].dur, 25.0, tc2),
+ 6, app->playlist.item[i].title,
+ 7, i,
+ -1 );
+ }
+
+ app->playlist.ver_prev = app->playlist.ver_curr;
+
+ pthread_mutex_unlock(&app->playlist.lock);
+};
+
+typedef struct omnplay_playlist_draw_item_desc
+{
+ GtkListStore *list_store;
+ omnplay_instance_t* app;
+ int idx;
+} omnplay_playlist_draw_item_t;
+
+static gboolean omnplay_playlist_draw_item_proc(
+ GtkTreeModel *model, GtkTreePath *path, GtkTreeIter *iter, gpointer user_data)
+{
+ int i;
+ char tc1[12], tc2[12];
+ omnplay_playlist_draw_item_t* item = (omnplay_playlist_draw_item_t*)user_data;
+ omnplay_instance_t* app = item->app;
+
+ gtk_tree_model_get(model, iter, 7, &i, -1);
+
+ if(i != item->idx) return FALSE;
+
+ gtk_list_store_set(item->list_store, iter,
+ 0, "",
+ 1, app->playlist.block_icons[app->playlist.item[i].type],
+ 2, (0 == app->playlist.item[i].player)?"A":"B",
+ 3, app->playlist.item[i].id,
+ 4, frames2tc(app->playlist.item[i].in, 25.0, tc1),
+ 5, frames2tc(app->playlist.item[i].dur, 25.0, tc2),
+ 6, app->playlist.item[i].title,
+ 7, i,
+ -1 );
+
+ return TRUE;
+};
+
+void omnplay_playlist_draw_item(omnplay_instance_t* app, int idx)
+{
+ GtkListStore *list_store;
+ omnplay_playlist_draw_item_t item;
+
+ list_store = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(app->playlist_grid)));
+
+ pthread_mutex_lock(&app->playlist.lock);
+
+ item.idx = idx;
+ item.app = app;
+ item.list_store = list_store;
+ gtk_tree_model_foreach(GTK_TREE_MODEL(list_store), omnplay_playlist_draw_item_proc, &item);
+
+ pthread_mutex_unlock(&app->playlist.lock);
+};
+
+static gboolean omnplay_playlist_draw_item_rem_proc(
+ GtkTreeModel *model, GtkTreePath *path, GtkTreeIter *iter, gpointer user_data)
+{
+ int i;
+ void** args = (void**)user_data;
+ GtkListStore *list_store = (GtkListStore *)args[1];
+ int idx = (int)args[2];
+ char* rem = (char*)args[3];
+
+ gtk_tree_model_get(model, iter, 7, &i, -1);
+
+ if(i != idx) return FALSE;
+
+ gtk_list_store_set(list_store, iter, 0, rem, -1);
+
+ return TRUE;
+};
+
+void omnplay_playlist_draw_item_rem(omnplay_instance_t* app, int idx, char* rem)
+{
+ void* item[4];
+ GtkListStore *list_store;
+
+ list_store = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(app->playlist_grid)));
+
+ item[0] = (void*)app;
+ item[1] = (void*)list_store;
+ item[2] = (void*)idx;
+ item[3] = (void*)rem;
+
+ gtk_tree_model_foreach(GTK_TREE_MODEL(list_store), omnplay_playlist_draw_item_rem_proc, item);
+};