#include <unistd.h>
#include <string.h>
#include <stdio.h>
+#include <stdlib.h>
#include <gdk/gdkkeysyms.h>
#include <gtk/gtk.h>
G_TYPE_STRING
},
{
- "ID",
+ "TITLE",
G_TYPE_STRING
},
{
G_TYPE_STRING
},
{
- "TITLE",
+ "ID",
G_TYPE_STRING
},
{
0, "",
1, app->playlist.block_icons[app->playlist.item[i].type],
2, ch,
- 3, app->playlist.item[i].id,
+ 3, app->playlist.item[i].title,
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,
+ 6, app->playlist.item[i].id,
7, i,
8, (app->playlist.item[i].error != 0),
9, (app->playlist.item[i].error & PLAYLIST_ITEM_ERROR_LIB)?"red":"orange",
0, "",
1, app->playlist.block_icons[app->playlist.item[i].type],
2, ch,
- 3, app->playlist.item[i].id,
+ 3, app->playlist.item[i].title,
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,
+ 6, app->playlist.item[i].id,
7, i,
8, (app->playlist.item[i].error != 0),
9, (app->playlist.item[i].error & PLAYLIST_ITEM_ERROR_LIB)?"red":"orange",
pthread_mutex_unlock(&app->playlist.lock);
};
-void ui_set_status(instance_t* app, char* str)
+void ui_set_status(instance_t* app, char* str, int lock)
{
- gdk_threads_enter();
+ if(lock)
+ gdk_threads_enter();
gtk_label_set_text(GTK_LABEL(app->status_label), str);
gdk_flush();
- gdk_threads_leave();
+ if(lock)
+ gdk_threads_leave();
+};
+
+void ui_show_error(GtkWidget *window, char* title, char* message)
+{
+ GtkWidget *dialog;
+ dialog = gtk_message_dialog_new
+ (
+ GTK_WINDOW(window),
+ GTK_DIALOG_DESTROY_WITH_PARENT,
+ GTK_MESSAGE_ERROR,
+ GTK_BUTTONS_OK,
+ message
+ );
+
+ gtk_window_set_title(GTK_WINDOW(dialog), title);
+ gtk_dialog_run(GTK_DIALOG(dialog));
+ gtk_widget_destroy(dialog);
};
int ui_playlist_load(instance_t* app, char* path, struct ui_playlist_io_funcs* procs)
{
int r, i;
-
GtkWidget *dialog;
GtkFileFilter *filter;
+ char error_message[1024];
dialog = gtk_file_chooser_dialog_new("Open File",
GTK_WINDOW (app->window),
if(r == GTK_RESPONSE_ACCEPT)
{
- char *filename;
+ int l;
+ char *filename, *filename2;
filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
i = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(gtk_file_chooser_get_filter(GTK_FILE_CHOOSER(dialog))), "id"));
- r = procs[i].load(app, filename);
+ filename2 = (char*)malloc(PATH_MAX);
+ strncpy(filename2, filename, PATH_MAX);
+ l = strlen(filename2);
+ if(l < 4 || strcasecmp(filename2 + l - 4, procs[i].ext + 1))
+ strcat(filename2, procs[i].ext + 1);
+
+ r = procs[i].load(app, filename2, error_message, sizeof(error_message));
+
+ if(r)
+ ui_show_error(dialog, "Playlist loading error", error_message);
+
+ free(filename2);
ui_playlist_draw(app);
int r, i;
GtkWidget *dialog;
GtkFileFilter *filter;
+ char error_message[1024];
dialog = gtk_file_chooser_dialog_new("Save File",
GTK_WINDOW (app->window),
if(r == GTK_RESPONSE_ACCEPT)
{
- char *filename;
+ int l;
+ char *filename, *filename2;
filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
i = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(gtk_file_chooser_get_filter(GTK_FILE_CHOOSER(dialog))), "id"));
- r = procs[i].save(app, filename);
+ filename2 = (char*)malloc(PATH_MAX);
+ strncpy(filename2, filename, PATH_MAX);
+ l = strlen(filename2);
+ if(l < 4 || strcasecmp(filename2 + l - 4, procs[i].ext + 1))
+ strcat(filename2, procs[i].ext + 1);
+
+ r = procs[i].save(app, filename2, error_message, sizeof(error_message));
+
+ if(r)
+ ui_show_error(dialog, "Playlist saving error", error_message);
+
+ free(filename2);
if(app->playlist.path)
g_free(app->playlist.path);