]> Dogcows Code - chaz/tint2/blobdiff - src/tint2conf/main.c
*add* include svn revision in the VERSION_STRING if building with cmake
[chaz/tint2] / src / tint2conf / main.c
index cf43dcd8ca63639ef1cf1d3cff17033753e40c58..d419e4601f2bcf39d49443259070e48db3e34406 100644 (file)
 #include <glib/gstdio.h>
 #include <glib/gi18n.h>
 
-#include "../version.h"
+#ifdef BUILD_CMAKE
+  #include "version.h"
+#else
+  #include "../version.h"
+#endif
 #include "common.h"
 #include "theme_view.h"
 
+#define SNAPSHOT_TICK 190
 
 
 // default config file and directory
 char *g_path_config = NULL;
 char *g_path_dir = NULL;
 char *g_default_theme = NULL;
+char *g_cmd_property = NULL;
 int g_width, g_height;
 
 GtkWidget *g_window;
-GtkWidget *g_theme_view;
 
 static GtkUIManager *globalUIManager = NULL;
 
@@ -55,7 +60,6 @@ static void menuProperties();
 static void menuQuit();
 static void menuRefresh();
 static void menuRefreshAll();
-static void menuPreferences();
 static void menuApply();
 static void menuAbout();
 
@@ -66,10 +70,12 @@ static void viewRowActivated(GtkTreeView *tree_view, GtkTreePath *path, GtkTreeV
 
 
 // theme files
+static void selectTheme(const gchar *name);
+static gboolean searchTheme(const gchar *name_theme, GtkTreeModel *model, GtkTreeIter *iter);
 static void load_theme();
+static void initTheme();
 static void read_config();
 static void write_config();
-static void check_theme();
 
 
 // define menubar, toolbar and popup
@@ -136,7 +142,7 @@ int main (int argc, char ** argv)
        gtk_init (&argc, &argv);
        g_thread_init( NULL );
        read_config();
-       check_theme();
+       initTheme();
 
        // define main layout : container, menubar, toolbar
        g_window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
@@ -169,10 +175,6 @@ int main (int argc, char ** argv)
    // load themes
        load_theme(g_theme_view);
 
-       // rig up idle/thread routines
-       //Glib::Thread::create(sigc::mem_fun(window.view, &Thumbview::load_cache_images), true);
-       //Glib::Thread::create(sigc::mem_fun(window.view, &Thumbview::create_cache_images), true);
-
        gtk_widget_show_all(g_window);
        gtk_main ();
        return 0;
@@ -220,30 +222,52 @@ static void menuAdd()
        gtk_file_filter_add_pattern(filter, "*.tint2rc");
        gtk_file_chooser_add_filter(chooser, filter);
 
-       if (gtk_dialog_run (GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT) {
-               GSList *l, *list = gtk_file_chooser_get_filenames(chooser);
-
-               gchar *file, *pt1, *name, *path;
-               for (l = list; l ; l = l->next) {
-                       file = (char *)l->data;
-                       pt1 = strrchr (file, '/');
-                       if (pt1) {
-                               pt1++;
-                               if (*pt1) {
-                                       name = g_strdup(pt1);
-                                       path = g_build_filename (g_get_user_config_dir(), "tint2", name, NULL);
-                                       copy_file(file, path);
-                             custom_list_append(path);
-                                       g_free(path);
-                                       g_free(name);
-                               }
-                       }
+       if (gtk_dialog_run (GTK_DIALOG(dialog)) != GTK_RESPONSE_ACCEPT) {
+               gtk_widget_destroy(dialog);
+               return;
+       }
+
+       GtkTreeIter iter;
+       GtkTreeModel *model = gtk_tree_view_get_model(GTK_TREE_VIEW(g_theme_view));
+       GSList *l, *list = gtk_file_chooser_get_filenames(chooser);
+       gchar *file, *pt1, *name, *path, *name_first=NULL;
+       for (l = list; l ; l = l->next) {
+               file = (char *)l->data;
+               pt1 = strrchr(file, '/');
+               if (pt1 == NULL)        continue;
+               pt1++;
+               if (*pt1 == 0)  continue;
+
+               name = g_strdup(pt1);
+               path = g_build_filename (g_get_user_config_dir(), "tint2", name, NULL);
+
+               // check existing
+               if (searchTheme(path, model, &iter)) {
+                       gchar *message;
+                       message = g_strdup_printf(_("Couldn't add duplicate theme\n\'%s\'."), pt1);
+
+                       GtkWidget *w = gtk_message_dialog_new(g_window, 0, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, message, NULL);
+                       g_signal_connect_swapped(w, "response", G_CALLBACK(gtk_widget_destroy), w);
+                       gtk_widget_show(w);
+                       g_free(message);
+                       continue;
                }
 
-               g_slist_foreach(list, (GFunc)g_free, NULL);
-               g_slist_free(list);
+               // append theme
+               copy_file(file, path);
+               custom_list_append(path);
+               if (name_first == NULL)
+                       name_first = g_strdup(path);
+               g_free(path);
+               g_free(name);
        }
-       gtk_widget_destroy (dialog);
+       g_slist_foreach(list, (GFunc)g_free, NULL);
+       g_slist_free(list);
+       gtk_widget_destroy(dialog);
+
+       selectTheme(name_first);
+       g_free(name_first);
+       g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL);
 }
 
 
@@ -290,17 +314,19 @@ static void menuDelete()
        GtkTreeSelection *sel;
        GtkTreeIter iter;
        GtkTreeModel *model;
-       gchar *file;
+       gchar *filename;
 
        sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view));
        if (gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) {
-               gtk_tree_model_get(model, &iter, COL_THEME_FILE, &file, -1);
+               gtk_tree_model_get(model, &iter, COL_THEME_FILE, &filename, -1);
                gtk_tree_selection_unselect_all(sel);
 
-               // remove (gui and disk)
+               // remove (gui and file)
                gtk_list_store_remove(GTK_LIST_STORE(model), &iter);
-               g_remove(file);
-               g_free(file);
+               GFile *file = g_file_new_for_path(filename);
+               g_file_trash(file, NULL, NULL);
+               g_object_unref(G_OBJECT(file));
+               g_free(filename);
        }
 }
 
@@ -316,7 +342,8 @@ static void menuProperties()
        if (gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) {
                gtk_tree_model_get(model, &iter, COL_THEME_FILE, &file,  -1);
 
-               cmd = g_strdup_printf("gedit \'%s\' &", file);
+               cmd = g_strdup_printf("%s \'%s\' &", g_cmd_property, file);
+               printf("cmd %s\n", cmd);
                system(cmd);
 
                g_free(cmd);
@@ -335,6 +362,8 @@ static void menuQuit()
                g_free(g_path_dir);
        if (g_default_theme)
                g_free(g_default_theme);
+       if (g_cmd_property)
+               g_free(g_cmd_property);
 
    gtk_main_quit ();
 }
@@ -342,19 +371,33 @@ static void menuQuit()
 
 static void menuRefresh()
 {
-       printf("menuRefresh\n");
+       GtkTreeSelection *sel;
+       GtkTreeIter iter;
+       GtkTreeModel *model;
+
+       sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view));
+       if (gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) {
+               gtk_list_store_set(g_store, &iter, COL_SNAPSHOT, NULL, -1);
+       }
+
+       g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL);
 }
 
 
 static void menuRefreshAll()
 {
-       printf("menuRefreshAll\n");
-}
+       GtkTreeIter iter;
+       GtkTreeModel *model;
+       gboolean have_iter;
 
+       model = gtk_tree_view_get_model(GTK_TREE_VIEW(g_theme_view));
+       have_iter = gtk_tree_model_get_iter_first(model, &iter);
+       while (have_iter) {
+               gtk_list_store_set(g_store, &iter, COL_SNAPSHOT, NULL, -1);
+               have_iter = gtk_tree_model_iter_next(model, &iter);
+       }
 
-static void menuPreferences()
-{
-       printf("menuPreferences\n");
+       g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL);
 }
 
 
@@ -439,10 +482,9 @@ static void windowSizeAllocated()
 static void load_theme(GtkWidget *list)
 {
        GDir *dir;
-       gchar *pt1, *name, *file;
-       gboolean have_iter, found_theme = FALSE;
-       GtkTreeIter iter;
-       GtkTreeModel *model;
+       gchar *pt1, *name;
+       const gchar *file;
+       gboolean found_theme = FALSE;
 
        dir = g_dir_open(g_path_dir, 0, NULL);
        if (dir == NULL) return;
@@ -459,26 +501,31 @@ static void load_theme(GtkWidget *list)
 
        if (!found_theme) {
                // create default theme file
-               name = g_build_filename (g_get_user_config_dir(), "tint2", "default.tint2rc", NULL);
+               name = g_build_filename(g_get_user_config_dir(), "tint2", "default.tint2rc", NULL);
                copy_file(g_path_config, name);
                custom_list_append(name);
+               if (g_default_theme) g_free(g_default_theme);
+               g_default_theme = strdup(name);
                g_free(name);
        }
 
-       // search default theme
-       found_theme = FALSE;
+       selectTheme(g_default_theme);
+
+       g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL);
+}
+
+
+void selectTheme(const gchar *name_theme)
+{
+       gboolean have_iter, found_theme;
+       GtkTreeIter iter;
+       GtkTreeModel *model;
+
+       if (!name_theme) return;
+
        model = gtk_tree_view_get_model(GTK_TREE_VIEW(g_theme_view));
-       have_iter = gtk_tree_model_get_iter_first(model, &iter);
-       while (have_iter) {
-               gtk_tree_model_get(model, &iter, COL_THEME_FILE, &name,  -1);
-               found_theme = (strcmp(name, g_default_theme) == 0);
-               g_free(name);
-               if (found_theme)
-                       break;
-               have_iter = gtk_tree_model_iter_next(model, &iter);
-       }
+       found_theme = searchTheme(name_theme, model, &iter);
 
-       // select theme
        GtkTreePath *path = NULL;
        if (found_theme)
                path = gtk_tree_model_get_path(model, &iter);
@@ -492,22 +539,51 @@ static void load_theme(GtkWidget *list)
                gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(g_theme_view), path, NULL, FALSE, 0, 0);
                gtk_tree_path_free(path);
        }
+}
 
+
+gboolean searchTheme(const gchar *name_theme, GtkTreeModel *model, GtkTreeIter *iter)
+{
+       gchar *name;
+       gboolean have_iter, found = FALSE;
+
+       have_iter = gtk_tree_model_get_iter_first(model, iter);
+       while (have_iter) {
+               gtk_tree_model_get(model, iter, COL_THEME_FILE, &name,  -1);
+               found = (strcmp(name, name_theme) == 0);
+               g_free(name);
+               if (found)
+                       break;
+               have_iter = gtk_tree_model_iter_next(model, iter);
+       }
+       return found;
+}
+
+
+void initTheme()
+{
+       g_path_dir = g_build_filename (g_get_user_config_dir(), "tint2", NULL);
+       if (!g_file_test (g_path_dir, G_FILE_TEST_IS_DIR))
+               g_mkdir(g_path_dir, 0777);
+
+       g_path_config = g_build_filename (g_get_user_config_dir(), "tint2", "tint2rc", NULL);
 }
 
 
-// theme file management
 void read_config()
 {
        char *path;
 
+       // default values
        if (g_default_theme != NULL) {
                g_free(g_default_theme);
                g_default_theme = NULL;
        }
-
        g_width = 500;
        g_height = 350;
+       g_cmd_property = g_strdup("python /usr/bin/tintwizard.py");
+
+       // load config
        path = g_build_filename (g_get_user_config_dir(), "tint2", "tint2confrc", NULL);
        if (g_file_test (path, G_FILE_TEST_EXISTS)) {
                FILE *fp;
@@ -517,7 +593,11 @@ void read_config()
                        while (fgets(line, sizeof(line), fp) != NULL) {
                                if (parse_line(line, &key, &value)) {
                                        if (strcmp (key, "default_theme") == 0)
-                                               g_default_theme = strdup (value);
+                                               g_default_theme = strdup(value);
+                                       else if (strcmp (key, "cmd_property") == 0) {
+                                               g_free(g_cmd_property);
+                                               g_cmd_property = strdup(value);
+                                       }
                                        else if (strcmp (key, "width") == 0)
                                                g_width = atoi(value);
                                        else if (strcmp (key, "height") == 0)
@@ -545,7 +625,9 @@ void write_config()
                fputs("# TINT2CONF CONFIG FILE\n", fp);
                if (g_default_theme != NULL) {
                        fprintf(fp, "default_theme = %s\n", g_default_theme);
-                       printf("default_theme %s\n", g_default_theme);
+               }
+               if (g_cmd_property != NULL) {
+                       fprintf(fp, "cmd_property = %s\n", g_cmd_property);
                }
                fprintf(fp, "width = %d\n", g_width);
                fprintf(fp, "height = %d\n", g_height);
@@ -556,15 +638,4 @@ void write_config()
 }
 
 
-void check_theme()
-{
-       g_path_dir = g_build_filename (g_get_user_config_dir(), "tint2", NULL);
-       if (!g_file_test (g_path_dir, G_FILE_TEST_IS_DIR))
-               g_mkdir(g_path_dir, 0777);
-
-       g_path_config = g_build_filename (g_get_user_config_dir(), "tint2", "tint2rc", NULL);
-
-}
-
-
 
This page took 0.029532 seconds and 4 git commands to generate.