From 8a71509ee441e48215df9a9c3018214fe9a592ce Mon Sep 17 00:00:00 2001 From: Matthew Barnes Date: Sun, 20 Jan 2013 18:31:11 -0500 Subject: Add a "settings" module. Collect all the "config" extensions from the "addressbook", "calendar", and "mail" modules into one place. These extensions typically just bind GObject properties of extensible classes to app-specific GSettings keys. --- modules/settings/e-settings-name-selector-entry.c | 122 ++++++++++++++++++++++ 1 file changed, 122 insertions(+) create mode 100644 modules/settings/e-settings-name-selector-entry.c (limited to 'modules/settings/e-settings-name-selector-entry.c') diff --git a/modules/settings/e-settings-name-selector-entry.c b/modules/settings/e-settings-name-selector-entry.c new file mode 100644 index 0000000000..799a796671 --- /dev/null +++ b/modules/settings/e-settings-name-selector-entry.c @@ -0,0 +1,122 @@ +/* + * e-settings-name-selector-entry.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 + * + */ + +#ifdef HAVE_CONFIG_H +#include +#endif + +#include "e-settings-name-selector-entry.h" + +#include + +#define E_SETTINGS_NAME_SELECTOR_ENTRY_GET_PRIVATE(obj) \ + (G_TYPE_INSTANCE_GET_PRIVATE \ + ((obj), E_TYPE_SETTINGS_NAME_SELECTOR_ENTRY, ESettingsNameSelectorEntryPrivate)) + +struct _ESettingsNameSelectorEntryPrivate { + GSettings *settings; +}; + +G_DEFINE_DYNAMIC_TYPE ( + ESettingsNameSelectorEntry, + e_settings_name_selector_entry, + E_TYPE_EXTENSION) + +static void +settings_name_selector_entry_dispose (GObject *object) +{ + ESettingsNameSelectorEntryPrivate *priv; + + priv = E_SETTINGS_NAME_SELECTOR_ENTRY_GET_PRIVATE (object); + + if (priv->settings != NULL) { + g_object_unref (priv->settings); + priv->settings = NULL; + } + + /* Chain up to parent's dispose() method. */ + G_OBJECT_CLASS (e_settings_name_selector_entry_parent_class)-> + dispose (object); +} + +static void +settings_name_selector_entry_constructed (GObject *object) +{ + ESettingsNameSelectorEntry *extension; + EExtensible *extensible; + + extension = E_SETTINGS_NAME_SELECTOR_ENTRY (object); + extensible = e_extension_get_extensible (E_EXTENSION (extension)); + + /* Chain up to parent's consturcted() method. */ + G_OBJECT_CLASS (e_settings_name_selector_entry_parent_class)-> + constructed (object); + + g_settings_bind ( + extension->priv->settings, "completion-minimum-query-length", + extensible, "minimum-query-length", + G_SETTINGS_BIND_DEFAULT | + G_SETTINGS_BIND_NO_SENSITIVITY); + + g_settings_bind ( + extension->priv->settings, "completion-show-address", + extensible, "show-address", + G_SETTINGS_BIND_DEFAULT | + G_SETTINGS_BIND_NO_SENSITIVITY); +} + +static void +e_settings_name_selector_entry_class_init (ESettingsNameSelectorEntryClass *class) +{ + GObjectClass *object_class; + EExtensionClass *extension_class; + + g_type_class_add_private ( + class, sizeof (ESettingsNameSelectorEntryPrivate)); + + object_class = G_OBJECT_CLASS (class); + object_class->dispose = settings_name_selector_entry_dispose; + object_class->constructed = settings_name_selector_entry_constructed; + + extension_class = E_EXTENSION_CLASS (class); + extension_class->extensible_type = E_TYPE_NAME_SELECTOR_ENTRY; +} + +static void +e_settings_name_selector_entry_class_finalize (ESettingsNameSelectorEntryClass *class) +{ +} + +static void +e_settings_name_selector_entry_init (ESettingsNameSelectorEntry *extension) +{ + extension->priv = + E_SETTINGS_NAME_SELECTOR_ENTRY_GET_PRIVATE (extension); + extension->priv->settings = + g_settings_new ("org.gnome.evolution.addressbook"); +} + +void +e_settings_name_selector_entry_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_name_selector_entry_register_type (type_module); +} + -- cgit