summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/config.c237
1 files changed, 184 insertions, 53 deletions
diff --git a/src/config.c b/src/config.c
index f91b643..5ced483 100644
--- a/src/config.c
+++ b/src/config.c
@@ -228,6 +228,190 @@ config_set_conf (const char *key, const char *value)
return -1;
}
+static int
+config_serialize_bool (char *dest, unsigned *val)
+{
+ if (*val)
+ {
+ dest[0] = 'y';
+ dest[1] = 'e';
+ dest[2] = 's';
+ dest[3] = '\0';
+ }
+ else
+ {
+ dest[0] = 'n';
+ dest[1] = 'o';
+ dest[2] = '\0';
+ }
+
+ return 1;
+}
+
+static int
+config_serialize_unsigned (char *dest, unsigned *val)
+{
+ snprintf (dest, BUFSIZ, "%u", *val);
+ return 1;
+}
+
+static int
+config_serialize_int (char *dest, int *val)
+{
+ snprintf (dest, BUFSIZ, "%d", *val);
+ return 1;
+}
+
+static int
+config_serialize_str (char *dest, const char *val)
+{
+ strncpy (dest, val, BUFSIZ);
+ return 1;
+}
+
+/*
+ * Return a string defining the color theme in the form:
+ * foreground color 'on' background color
+ * in order to dump this data in the configuration file.
+ * Color numbers follow the ncurses library definitions.
+ * If ncurses library was compiled with --enable-ext-funcs,
+ * then default color is -1.
+ */
+void
+config_color_theme_name (char *theme_name)
+{
+#define MAXCOLORS 8
+#define NBCOLORS 2
+#define DEFAULTCOLOR 255
+#define DEFAULTCOLOR_EXT -1
+
+ int i;
+ short color[NBCOLORS];
+ char *color_name[NBCOLORS];
+ char *default_color = "default";
+ char *name[MAXCOLORS] = {
+ "black",
+ "red",
+ "green",
+ "yellow",
+ "blue",
+ "magenta",
+ "cyan",
+ "white"
+ };
+
+ if (!colorize)
+ strncpy (theme_name, "0", BUFSIZ);
+ else
+ {
+ pair_content (COLR_CUSTOM, &color[0], &color[1]);
+ for (i = 0; i < NBCOLORS; i++)
+ {
+ if ((color[i] == DEFAULTCOLOR) || (color[i] == DEFAULTCOLOR_EXT))
+ color_name[i] = default_color;
+ else if (color[i] >= 0 && color[i] <= MAXCOLORS)
+ color_name[i] = name[color[i]];
+ else
+ {
+ EXIT (_("unknown color"));
+ /* NOTREACHED */
+ }
+ }
+ snprintf (theme_name, BUFSIZ, "%s on %s", color_name[0], color_name[1]);
+ }
+}
+
+/* Serialize the value of a configuration variable. */
+static int
+config_serialize_conf (char *buf, const char *key)
+{
+ if (!key)
+ return -1;
+
+ if (!strcmp(key, "auto_save"))
+ return config_serialize_bool (buf, &conf.auto_save);
+
+ if (!strcmp(key, "auto_gc"))
+ return config_serialize_bool (buf, &conf.auto_gc);
+
+ if (!strcmp(key, "periodic_save"))
+ return config_serialize_unsigned (buf, &conf.periodic_save);
+
+ if (!strcmp(key, "confirm_quit"))
+ return config_serialize_bool (buf, &conf.confirm_quit);
+
+ if (!strcmp(key, "confirm_delete"))
+ return config_serialize_bool (buf, &conf.confirm_delete);
+
+ if (!strcmp(key, "skip_system_dialogs"))
+ return config_serialize_bool (buf, &conf.skip_system_dialogs);
+
+ if (!strcmp(key, "skip_progress_bar"))
+ return config_serialize_bool (buf, &conf.skip_progress_bar);
+
+ if (!strcmp(key, "calendar_default_view"))
+ {
+ int tmp = calendar_get_view ();
+ return config_serialize_int (buf, &tmp);
+ }
+
+ if (!strcmp(key, "week_begins_on_monday"))
+ {
+ unsigned tmp = calendar_week_begins_on_monday ();
+ return config_serialize_bool (buf, &tmp);
+ }
+
+ if (!strcmp(key, "color-theme"))
+ {
+ config_color_theme_name (buf);
+ return 1;
+ }
+
+ if (!strcmp(key, "layout"))
+ {
+ int tmp = wins_layout ();
+ return config_serialize_int (buf, &tmp);
+ }
+
+ if (!strcmp(key, "side-bar_width"))
+ {
+ int tmp = wins_sbar_wperc ();
+ return config_serialize_int (buf, &tmp);
+ }
+
+ if (!strcmp(key, "notify-bar_show"))
+ return config_serialize_bool (buf, &nbar.show);
+
+ if (!strcmp(key, "notify-bar_date"))
+ return config_serialize_str (buf, nbar.datefmt);
+
+ if (!strcmp(key, "notify-bar_clock"))
+ return config_serialize_str (buf, nbar.timefmt);
+
+ if (!strcmp(key, "notify-bar_warning"))
+ return config_serialize_int (buf, &nbar.cntdwn);
+
+ if (!strcmp(key, "notify-bar_command"))
+ return config_serialize_str (buf, nbar.cmd);
+
+ if (!strcmp(key, "notify-all"))
+ return config_serialize_bool (buf, &nbar.notify_all);
+
+ if (!strcmp(key, "output_datefmt"))
+ return config_serialize_str (buf, conf.output_datefmt);
+
+ if (!strcmp(key, "input_datefmt"))
+ return config_serialize_int (buf, &conf.input_datefmt);
+
+ if (!strcmp(key, "notify-daemon_enable"))
+ return config_serialize_bool (buf, &dmon.enable);
+
+ if (!strcmp(key, "notify-daemon_log"))
+ return config_serialize_bool (buf, &dmon.log);
+
+ return -1;
+}
+
static void
config_file_walk (config_fn_walk_cb_t fn_cb,
config_fn_walk_junk_cb_t fn_junk_cb, void *data)
@@ -306,59 +490,6 @@ config_load (void)
config_file_walk (config_load_cb, NULL, NULL);
}
-/*
- * Return a string defining the color theme in the form:
- * foreground color 'on' background color
- * in order to dump this data in the configuration file.
- * Color numbers follow the ncurses library definitions.
- * If ncurses library was compiled with --enable-ext-funcs,
- * then default color is -1.
- */
-void
-config_color_theme_name (char *theme_name)
-{
-#define MAXCOLORS 8
-#define NBCOLORS 2
-#define DEFAULTCOLOR 255
-#define DEFAULTCOLOR_EXT -1
-
- int i;
- short color[NBCOLORS];
- char *color_name[NBCOLORS];
- char *default_color = "default";
- char *name[MAXCOLORS] = {
- "black",
- "red",
- "green",
- "yellow",
- "blue",
- "magenta",
- "cyan",
- "white"
- };
-
- if (!colorize)
- strncpy (theme_name, "0", BUFSIZ);
- else
- {
- pair_content (COLR_CUSTOM, &color[0], &color[1]);
- for (i = 0; i < NBCOLORS; i++)
- {
- if ((color[i] == DEFAULTCOLOR) || (color[i] == DEFAULTCOLOR_EXT))
- color_name[i] = default_color;
- else if (color[i] >= 0 && color[i] <= MAXCOLORS)
- color_name[i] = name[color[i]];
- else
- {
- EXIT (_("unknown color"));
- /* NOTREACHED */
- }
- }
- snprintf (theme_name, BUFSIZ, "%s on %s", color_name[0], color_name[1]);
- }
-}
-
-
/* Save the user configuration. */
unsigned
config_save (void)