* src/prefs_gtk.[ch]
[claws.git] / src / prefs_gtk.c
index e6330a65e9ddf104360bfddd54fa3fad9a2c582e..51ac173266b38194254ead7dde23e2104efaad9e 100644 (file)
 #include "utils.h"
 #include "gtkutils.h"
 
+#define CL(x)  (((gulong) (x) >> (gulong) 8) & 0xFFUL)
+#define RGB_FROM_GDK_COLOR(c) \
+       ((CL(c.red)   << (gulong) 16) | \
+        (CL(c.green) << (gulong)  8) | \
+        (CL(c.blue)))
+
 typedef enum
 {
        DUMMY_PARAM
@@ -95,6 +101,7 @@ void prefs_config_parse_one_line(PrefParam *param, const gchar *buf)
        gint i;
        gint name_len;
        const gchar *value;
+       GdkColor color;
 
        for (i = 0; param[i].name != NULL; i++) {
                name_len = strlen(param[i].name);
@@ -128,6 +135,13 @@ void prefs_config_parse_one_line(PrefParam *param, const gchar *buf)
                        *((gushort *)param[i].data) =
                                (gushort)atoi(value);
                        break;
+               case P_COLOR:
+                       if (gdk_color_parse(value, &color)) 
+                               *((gulong *)param[i].data) = RGB_FROM_GDK_COLOR(color); 
+                       else 
+                               /* be compatible and accept ints */
+                               *((gulong *)param[i].data) = strtoul(value, 0, 10); 
+                       break;
                default:
                        break;
                }
@@ -139,7 +153,7 @@ if (!(func)) \
 { \
        g_warning("failed to write configuration to file\n"); \
        if (orig_fp) fclose(orig_fp); \
-       prefs_write_close_revert(pfile); \
+       prefs_file_close_revert(pfile); \
        g_free(rcpath); \
        g_free(block_label); \
        return; \
@@ -209,7 +223,7 @@ void prefs_save_config(PrefParam *param, const gchar *label,
        }
 
        if (orig_fp) fclose(orig_fp);
-       if (prefs_write_close(pfile) < 0)
+       if (prefs_file_close(pfile) < 0)
                g_warning("failed to write configuration to file\n");
        g_free(rcpath);
 
@@ -244,6 +258,10 @@ gint prefs_write_param(PrefParam *param, FILE *fp)
                        g_snprintf(buf, sizeof(buf), "%s=%d\n", param[i].name,
                                   *((gushort *)param[i].data));
                        break;
+               case P_COLOR:
+                       g_snprintf(buf, sizeof buf,  "%s=#%6.6lx\n", param[i].name,
+                                  *((gulong *) param[i].data));
+                       break;
                default:
                        buf[0] = '\0';
                }
@@ -262,6 +280,7 @@ gint prefs_write_param(PrefParam *param, FILE *fp)
 void prefs_set_default(PrefParam *param)
 {
        gint i;
+       GdkColor color;
 
        g_return_if_fail(param != NULL);
 
@@ -318,6 +337,16 @@ void prefs_set_default(PrefParam *param)
                        else
                                *((gushort *)param[i].data) = 0;
                        break;
+               case P_COLOR:
+                       if (param[i].defval != NULL && gdk_color_parse(param[i].defval, &color))
+                               *((gulong *)param[i].data) =
+                                       RGB_FROM_GDK_COLOR(color);
+                       else if (param[i].defval)
+                               /* be compatible and accept ints */
+                               *((gulong *)param[i].data) = strtoul(param[i].defval, 0, 10); 
+                       else
+                               *((gulong *)param[i].data) = 0; 
+                       break;
                default:
                        break;
                }
@@ -494,6 +523,7 @@ void prefs_set_dialog_to_default(PrefParam *param)
                        tmpparam.data = &enum_data;
                        break;
                case P_OTHER:
+               default:
                        break;
                }
                tmpparam.widget_set_func(&tmpparam);
@@ -505,6 +535,7 @@ void prefs_set_dialog_to_default(PrefParam *param)
 void prefs_set_data_from_entry(PrefParam *pparam)
 {
        gchar **str, *entry_str;
+       GdkColor color;
 
        g_return_if_fail(*pparam->widget != NULL);
 
@@ -691,3 +722,20 @@ void prefs_set_spinbtn(PrefParam *pparam)
                          pparam->type);
        }
 }
+
+static GSList *prefs_pages = NULL;
+
+void prefs_gtk_open()
+{
+       prefswindow_open(prefs_pages, NULL);
+}
+
+void prefs_gtk_register_page(PrefsPage *page)
+{
+       prefs_pages = g_slist_append(prefs_pages, page);
+}
+
+void prefs_gtk_unregister_page(PrefsPage *page)
+{
+       prefs_pages = g_slist_remove(prefs_pages, page);
+}