aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--modules/settings/Makefile.am2
-rw-r--r--modules/settings/e-settings-deprecated.c367
-rw-r--r--modules/settings/e-settings-deprecated.h65
-rw-r--r--modules/settings/evolution-module-settings.c2
4 files changed, 436 insertions, 0 deletions
diff --git a/modules/settings/Makefile.am b/modules/settings/Makefile.am
index 9ecf1c1e33..61cf5688d4 100644
--- a/modules/settings/Makefile.am
+++ b/modules/settings/Makefile.am
@@ -25,6 +25,8 @@ module_settings_la_SOURCES = \
e-settings-comp-editor.h \
e-settings-date-edit.c \
e-settings-date-edit.h \
+ e-settings-deprecated.c \
+ e-settings-deprecated.h \
e-settings-mail-formatter.c \
e-settings-mail-formatter.h \
e-settings-mail-reader.c \
diff --git a/modules/settings/e-settings-deprecated.c b/modules/settings/e-settings-deprecated.c
new file mode 100644
index 0000000000..abcf152800
--- /dev/null
+++ b/modules/settings/e-settings-deprecated.c
@@ -0,0 +1,367 @@
+/*
+ * e-settings-deprecated.c
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) version 3.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+/* This class is different from the others in this module. Its purpose
+ * is to transfer values from deprecated GSettings keys to the preferred
+ * keys on startup, and keep them synchronized at all times for backward
+ * compatibility. */
+
+#include "e-settings-deprecated.h"
+
+#include <shell/e-shell.h>
+
+#define E_SETTINGS_DEPRECATED_GET_PRIVATE(obj) \
+ (G_TYPE_INSTANCE_GET_PRIVATE \
+ ((obj), E_TYPE_SETTINGS_DEPRECATED, ESettingsDeprecatedPrivate))
+
+struct _ESettingsDeprecatedPrivate {
+ GSettings *calendar_settings;
+ gulong week_start_day_name_handler_id;
+ gulong work_day_monday_handler_id;
+ gulong work_day_tuesday_handler_id;
+ gulong work_day_wednesday_handler_id;
+ gulong work_day_thursday_handler_id;
+ gulong work_day_friday_handler_id;
+ gulong work_day_saturday_handler_id;
+ gulong work_day_sunday_handler_id;
+};
+
+/* Flag values used in the "working-days" key. */
+enum {
+ DEPRECATED_WORKING_DAYS_SUNDAY = 1 << 0,
+ DEPRECATED_WORKING_DAYS_MONDAY = 1 << 1,
+ DEPRECATED_WORKING_DAYS_TUESDAY = 1 << 2,
+ DEPRECATED_WORKING_DAYS_WEDNESDAY = 1 << 3,
+ DEPRECATED_WORKING_DAYS_THURSDAY = 1 << 4,
+ DEPRECATED_WORKING_DAYS_FRIDAY = 1 << 5,
+ DEPRECATED_WORKING_DAYS_SATURDAY = 1 << 6
+};
+
+G_DEFINE_DYNAMIC_TYPE (
+ ESettingsDeprecated,
+ e_settings_deprecated,
+ E_TYPE_EXTENSION)
+
+static void
+settings_deprecated_week_start_day_name_cb (GSettings *settings,
+ const gchar *key)
+{
+ GDateWeekday weekday;
+ gint tm_wday;
+
+ weekday = g_settings_get_enum (settings, "week-start-day-name");
+ tm_wday = e_weekday_to_tm_wday (weekday);
+ g_settings_set_int (settings, "week-start-day", tm_wday);
+}
+
+static void
+settings_deprecated_work_day_monday_cb (GSettings *settings,
+ const gchar *key)
+{
+ gint flags;
+
+ flags = g_settings_get_int (settings, "working-days");
+ if (g_settings_get_boolean (settings, "work-day-monday"))
+ flags |= DEPRECATED_WORKING_DAYS_MONDAY;
+ else
+ flags &= ~DEPRECATED_WORKING_DAYS_MONDAY;
+ g_settings_set_int (settings, "working-days", flags);
+}
+
+static void
+settings_deprecated_work_day_tuesday_cb (GSettings *settings,
+ const gchar *key)
+{
+ gint flags;
+
+ flags = g_settings_get_int (settings, "working-days");
+ if (g_settings_get_boolean (settings, "work-day-tuesday"))
+ flags |= DEPRECATED_WORKING_DAYS_TUESDAY;
+ else
+ flags &= ~DEPRECATED_WORKING_DAYS_TUESDAY;
+ g_settings_set_int (settings, "working-days", flags);
+}
+
+static void
+settings_deprecated_work_day_wednesday_cb (GSettings *settings,
+ const gchar *key)
+{
+ gint flags;
+
+ flags = g_settings_get_int (settings, "working-days");
+ if (g_settings_get_boolean (settings, "work-day-wednesday"))
+ flags |= DEPRECATED_WORKING_DAYS_WEDNESDAY;
+ else
+ flags &= ~DEPRECATED_WORKING_DAYS_WEDNESDAY;
+ g_settings_set_int (settings, "working-days", flags);
+}
+
+static void
+settings_deprecated_work_day_thursday_cb (GSettings *settings,
+ const gchar *key)
+{
+ gint flags;
+
+ flags = g_settings_get_int (settings, "working-days");
+ if (g_settings_get_boolean (settings, "work-day-thursday"))
+ flags |= DEPRECATED_WORKING_DAYS_THURSDAY;
+ else
+ flags &= ~DEPRECATED_WORKING_DAYS_THURSDAY;
+ g_settings_set_int (settings, "working-days", flags);
+}
+
+static void
+settings_deprecated_work_day_friday_cb (GSettings *settings,
+ const gchar *key)
+{
+ gint flags;
+
+ flags = g_settings_get_int (settings, "working-days");
+ if (g_settings_get_boolean (settings, "work-day-friday"))
+ flags |= DEPRECATED_WORKING_DAYS_FRIDAY;
+ else
+ flags &= ~DEPRECATED_WORKING_DAYS_FRIDAY;
+ g_settings_set_int (settings, "working-days", flags);
+}
+
+static void
+settings_deprecated_work_day_saturday_cb (GSettings *settings,
+ const gchar *key)
+{
+ gint flags;
+
+ flags = g_settings_get_int (settings, "working-days");
+ if (g_settings_get_boolean (settings, "work-day-saturday"))
+ flags |= DEPRECATED_WORKING_DAYS_SATURDAY;
+ else
+ flags &= ~DEPRECATED_WORKING_DAYS_SATURDAY;
+ g_settings_set_int (settings, "working-days", flags);
+}
+
+static void
+settings_deprecated_work_day_sunday_cb (GSettings *settings,
+ const gchar *key)
+{
+ gint flags;
+
+ flags = g_settings_get_int (settings, "working-days");
+ if (g_settings_get_boolean (settings, "work-day-sunday"))
+ flags |= DEPRECATED_WORKING_DAYS_SUNDAY;
+ else
+ flags &= ~DEPRECATED_WORKING_DAYS_SUNDAY;
+ g_settings_set_int (settings, "working-days", flags);
+}
+
+static void
+settings_deprecated_dispose (GObject *object)
+{
+ ESettingsDeprecatedPrivate *priv;
+
+ priv = E_SETTINGS_DEPRECATED_GET_PRIVATE (object);
+
+ if (priv->week_start_day_name_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->week_start_day_name_handler_id);
+ priv->week_start_day_name_handler_id = 0;
+ }
+
+ if (priv->work_day_monday_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->work_day_monday_handler_id);
+ priv->work_day_monday_handler_id = 0;
+ }
+
+ if (priv->work_day_tuesday_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->work_day_tuesday_handler_id);
+ priv->work_day_tuesday_handler_id = 0;
+ }
+
+ if (priv->work_day_wednesday_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->work_day_wednesday_handler_id);
+ priv->work_day_wednesday_handler_id = 0;
+ }
+
+ if (priv->work_day_thursday_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->work_day_thursday_handler_id);
+ priv->work_day_thursday_handler_id = 0;
+ }
+
+ if (priv->work_day_friday_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->work_day_friday_handler_id);
+ priv->work_day_friday_handler_id = 0;
+ }
+
+ if (priv->work_day_saturday_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->work_day_saturday_handler_id);
+ priv->work_day_saturday_handler_id = 0;
+ }
+
+ if (priv->work_day_sunday_handler_id > 0) {
+ g_signal_handler_disconnect (
+ priv->calendar_settings,
+ priv->work_day_sunday_handler_id);
+ priv->work_day_sunday_handler_id = 0;
+ }
+
+ g_clear_object (&priv->calendar_settings);
+
+ /* Chain up to parent's dispose() method. */
+ G_OBJECT_CLASS (e_settings_deprecated_parent_class)->dispose (object);
+}
+
+static void
+settings_deprecated_constructed (GObject *object)
+{
+ ESettingsDeprecatedPrivate *priv;
+ gulong handler_id;
+ gint int_value;
+
+ priv = E_SETTINGS_DEPRECATED_GET_PRIVATE (object);
+
+ /* Chain up to parent's constructed() method. */
+ G_OBJECT_CLASS (e_settings_deprecated_parent_class)->
+ constructed (object);
+
+ /* Migrate values from deprecated to preferred keys. */
+
+ int_value = g_settings_get_int (
+ priv->calendar_settings, "week-start-day");
+ g_settings_set_enum (
+ priv->calendar_settings, "week-start-day-name",
+ e_weekday_from_tm_wday (int_value));
+
+ int_value = g_settings_get_int (
+ priv->calendar_settings, "working-days");
+ g_settings_set_boolean (
+ priv->calendar_settings, "work-day-monday",
+ (int_value & DEPRECATED_WORKING_DAYS_MONDAY) != 0);
+ g_settings_set_boolean (
+ priv->calendar_settings, "work-day-tuesday",
+ (int_value & DEPRECATED_WORKING_DAYS_TUESDAY) != 0);
+ g_settings_set_boolean (
+ priv->calendar_settings, "work-day-wednesday",
+ (int_value & DEPRECATED_WORKING_DAYS_WEDNESDAY) != 0);
+ g_settings_set_boolean (
+ priv->calendar_settings, "work-day-thursday",
+ (int_value & DEPRECATED_WORKING_DAYS_THURSDAY) != 0);
+ g_settings_set_boolean (
+ priv->calendar_settings, "work-day-friday",
+ (int_value & DEPRECATED_WORKING_DAYS_FRIDAY) != 0);
+ g_settings_set_boolean (
+ priv->calendar_settings, "work-day-saturday",
+ (int_value & DEPRECATED_WORKING_DAYS_SATURDAY) != 0);
+ g_settings_set_boolean (
+ priv->calendar_settings, "work-day-sunday",
+ (int_value & DEPRECATED_WORKING_DAYS_SUNDAY) != 0);
+
+ /* Write changes back to the deprecated keys. */
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::week-start-day-name",
+ G_CALLBACK (settings_deprecated_week_start_day_name_cb), NULL);
+ priv->week_start_day_name_handler_id = handler_id;
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::work-day-monday",
+ G_CALLBACK (settings_deprecated_work_day_monday_cb), NULL);
+ priv->work_day_monday_handler_id = handler_id;
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::work-day-tuesday",
+ G_CALLBACK (settings_deprecated_work_day_tuesday_cb), NULL);
+ priv->work_day_tuesday_handler_id = handler_id;
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::work-day-wednesday",
+ G_CALLBACK (settings_deprecated_work_day_wednesday_cb), NULL);
+ priv->work_day_wednesday_handler_id = handler_id;
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::work-day-thursday",
+ G_CALLBACK (settings_deprecated_work_day_thursday_cb), NULL);
+ priv->work_day_thursday_handler_id = handler_id;
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::work-day-friday",
+ G_CALLBACK (settings_deprecated_work_day_friday_cb), NULL);
+ priv->work_day_friday_handler_id = handler_id;
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::work-day-saturday",
+ G_CALLBACK (settings_deprecated_work_day_saturday_cb), NULL);
+ priv->work_day_saturday_handler_id = handler_id;
+
+ handler_id = g_signal_connect (
+ priv->calendar_settings, "changed::work-day-sunday",
+ G_CALLBACK (settings_deprecated_work_day_sunday_cb), NULL);
+ priv->work_day_sunday_handler_id = handler_id;
+}
+
+static void
+e_settings_deprecated_class_init (ESettingsDeprecatedClass *class)
+{
+ GObjectClass *object_class;
+ EExtensionClass *extension_class;
+
+ g_type_class_add_private (class, sizeof (ESettingsDeprecatedPrivate));
+
+ object_class = G_OBJECT_CLASS (class);
+ object_class->dispose = settings_deprecated_dispose;
+ object_class->constructed = settings_deprecated_constructed;
+
+ extension_class = E_EXTENSION_CLASS (class);
+ extension_class->extensible_type = E_TYPE_SHELL;
+}
+
+static void
+e_settings_deprecated_class_finalize (ESettingsDeprecatedClass *class)
+{
+}
+
+static void
+e_settings_deprecated_init (ESettingsDeprecated *extension)
+{
+ GSettings *settings;
+
+ extension->priv = E_SETTINGS_DEPRECATED_GET_PRIVATE (extension);
+
+ settings = g_settings_new ("org.gnome.evolution.calendar");
+ extension->priv->calendar_settings = settings;
+}
+
+void
+e_settings_deprecated_type_register (GTypeModule *type_module)
+{
+ /* XXX G_DEFINE_DYNAMIC_TYPE declares a static type registration
+ * function, so we have to wrap it with a public function in
+ * order to register types from a separate compilation unit. */
+ e_settings_deprecated_register_type (type_module);
+}
+
diff --git a/modules/settings/e-settings-deprecated.h b/modules/settings/e-settings-deprecated.h
new file mode 100644
index 0000000000..1307254f7c
--- /dev/null
+++ b/modules/settings/e-settings-deprecated.h
@@ -0,0 +1,65 @@
+/*
+ * e-settings-deprecated.h
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) version 3.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+#ifndef E_SETTINGS_DEPRECATED_H
+#define E_SETTINGS_DEPRECATED_H
+
+#include <libebackend/libebackend.h>
+
+/* Standard GObject macros */
+#define E_TYPE_SETTINGS_DEPRECATED \
+ (e_settings_deprecated_get_type ())
+#define E_SETTINGS_DEPRECATED(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST \
+ ((obj), E_TYPE_SETTINGS_DEPRECATED, ESettingsDeprecated))
+#define E_SETTINGS_DEPRECATED_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_CAST \
+ ((cls), E_TYPE_SETTINGS_DEPRECATED, ESettingsDeprecatedClass))
+#define E_IS_SETTINGS_DEPRECATED(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE \
+ ((obj), E_TYPE_SETTINGS_DEPRECATED))
+#define E_IS_SETTINGS_DEPRECATED_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_TYPE \
+ ((cls), E_TYPE_SETTINGS_DEPRECATED))
+#define E_SETTINGS_DEPRECATED_GET_CLASS(obj) \
+ (G_TYPE_INSTANCE_GET_CLASS \
+ ((obj), E_TYPE_SETTINGS_DEPRECATED, ESettingsDeprecatedClass))
+
+G_BEGIN_DECLS
+
+typedef struct _ESettingsDeprecated ESettingsDeprecated;
+typedef struct _ESettingsDeprecatedClass ESettingsDeprecatedClass;
+typedef struct _ESettingsDeprecatedPrivate ESettingsDeprecatedPrivate;
+
+struct _ESettingsDeprecated {
+ EExtension parent;
+ ESettingsDeprecatedPrivate *priv;
+};
+
+struct _ESettingsDeprecatedClass {
+ EExtensionClass parent_class;
+};
+
+GType e_settings_deprecated_get_type (void) G_GNUC_CONST;
+void e_settings_deprecated_type_register
+ (GTypeModule *type_module);
+
+G_END_DECLS
+
+#endif /* E_SETTINGS_DEPRECATED_H */
+
diff --git a/modules/settings/evolution-module-settings.c b/modules/settings/evolution-module-settings.c
index a67d192067..94caf05a6e 100644
--- a/modules/settings/evolution-module-settings.c
+++ b/modules/settings/evolution-module-settings.c
@@ -22,6 +22,7 @@
#include "e-settings-client-cache.h"
#include "e-settings-comp-editor.h"
#include "e-settings-date-edit.h"
+#include "e-settings-deprecated.h"
#include "e-settings-mail-formatter.h"
#include "e-settings-mail-reader.h"
#include "e-settings-meeting-store.h"
@@ -46,6 +47,7 @@ e_module_load (GTypeModule *type_module)
e_settings_client_cache_type_register (type_module);
e_settings_comp_editor_type_register (type_module);
e_settings_date_edit_type_register (type_module);
+ e_settings_deprecated_type_register (type_module);
e_settings_mail_formatter_type_register (type_module);
e_settings_mail_reader_type_register (type_module);
e_settings_meeting_store_type_register (type_module);