[gnome-calendar] shell-search-provider: Rework property initialization
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-calendar] shell-search-provider: Rework property initialization
- Date: Sun, 28 Jan 2018 02:28:35 +0000 (UTC)
commit 0bfc6fe2914340f77d555082d97353f8efe279a6
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date: Sun Jan 28 00:13:15 2018 -0200
shell-search-provider: Rework property initialization
src/gcal-application.c | 4 +-
src/gcal-shell-search-provider.c | 102 ++++++++++++++++++++++++++++++++-------
src/gcal-shell-search-provider.h | 5 +-
3 files changed, 87 insertions(+), 24 deletions(-)
---
diff --git a/src/gcal-application.c b/src/gcal-application.c
index 772864a2..eef7b4aa 100644
--- a/src/gcal-application.c
+++ b/src/gcal-application.c
@@ -476,9 +476,7 @@ gcal_application_init (GcalApplication *self)
g_signal_connect_swapped (self->manager, "source-changed", G_CALLBACK (process_sources), self);
self->weather_service = gcal_weather_service_new ();
-
- self->search_provider = gcal_shell_search_provider_new ();
- gcal_shell_search_provider_connect (self->search_provider, self->manager);
+ self->search_provider = gcal_shell_search_provider_new (self->manager);
}
static void
diff --git a/src/gcal-shell-search-provider.c b/src/gcal-shell-search-provider.c
index 5523cbac..8aa85934 100644
--- a/src/gcal-shell-search-provider.c
+++ b/src/gcal-shell-search-provider.c
@@ -50,6 +50,15 @@ static void gcal_subscriber_interface_init (ECalDataModelSubscriberInterface *
G_DEFINE_TYPE_WITH_CODE (GcalShellSearchProvider, gcal_shell_search_provider, G_TYPE_OBJECT,
G_IMPLEMENT_INTERFACE (E_TYPE_CAL_DATA_MODEL_SUBSCRIBER,
gcal_subscriber_interface_init));
+enum
+{
+ PROP_0,
+ PROP_MANAGER,
+ N_PROPS
+};
+
+static GParamSpec* properties[N_PROPS] = { NULL, };
+
static gint
sort_event_data (GcalEvent *a,
GcalEvent *b,
@@ -324,6 +333,11 @@ out:
return FALSE;
}
+
+/*
+ * ECalDataModelSubscriber iface
+ */
+
static void
gcal_shell_search_provider_component_changed (ECalDataModelSubscriber *subscriber,
ECalClient *client,
@@ -353,6 +367,21 @@ gcal_shell_search_provider_thaw (ECalDataModelSubscriber *subscriber)
;
}
+static void
+gcal_subscriber_interface_init (ECalDataModelSubscriberInterface *iface)
+{
+ iface->component_added = gcal_shell_search_provider_component_changed;
+ iface->component_modified = gcal_shell_search_provider_component_changed;
+ iface->component_removed = gcal_shell_search_provider_component_removed;
+ iface->freeze = gcal_shell_search_provider_freeze;
+ iface->thaw = gcal_shell_search_provider_thaw;
+}
+
+
+/*
+ * GObject overrides
+ */
+
static void
gcal_shell_search_provider_finalize (GObject *object)
{
@@ -360,19 +389,54 @@ gcal_shell_search_provider_finalize (GObject *object)
g_hash_table_destroy (self->events);
+ g_clear_object (&self->manager);
g_clear_object (&self->skel);
G_OBJECT_CLASS (gcal_shell_search_provider_parent_class)->finalize (object);
}
static void
-gcal_subscriber_interface_init (ECalDataModelSubscriberInterface *iface)
+gcal_shell_search_provider_get_property (GObject *object,
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
{
- iface->component_added = gcal_shell_search_provider_component_changed;
- iface->component_modified = gcal_shell_search_provider_component_changed;
- iface->component_removed = gcal_shell_search_provider_component_removed;
- iface->freeze = gcal_shell_search_provider_freeze;
- iface->thaw = gcal_shell_search_provider_thaw;
+ GcalShellSearchProvider *self = GCAL_SHELL_SEARCH_PROVIDER (object);
+
+ switch (property_id)
+ {
+ case PROP_MANAGER:
+ g_value_set_object (value, self->manager);
+ break;
+
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ }
+}
+
+static void
+gcal_shell_search_provider_set_property (GObject *object,
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ GcalShellSearchProvider *self = GCAL_SHELL_SEARCH_PROVIDER (object);
+
+ switch (property_id)
+ {
+ case PROP_MANAGER:
+ if (g_set_object (&self->manager, g_value_get_object (value)))
+ {
+ gcal_manager_setup_shell_search (self->manager, E_CAL_DATA_MODEL_SUBSCRIBER (self));
+ g_signal_connect_swapped (self->manager, "query-completed", G_CALLBACK (query_completed_cb), self);
+
+ g_object_notify_by_pspec (object, properties[PROP_MANAGER]);
+ }
+ break;
+
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ }
}
static void
@@ -381,6 +445,16 @@ gcal_shell_search_provider_class_init (GcalShellSearchProviderClass *klass)
GObjectClass *object_class = G_OBJECT_CLASS (klass);
object_class->finalize = gcal_shell_search_provider_finalize;
+ object_class->get_property = gcal_shell_search_provider_get_property;
+ object_class->set_property = gcal_shell_search_provider_set_property;
+
+ properties[PROP_MANAGER] = g_param_spec_object ("manager",
+ "The manager object",
+ "The manager object",
+ GCAL_TYPE_MANAGER,
+ G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS);
+
+ g_object_class_install_properties (object_class, N_PROPS, properties);
}
static void
@@ -397,9 +471,11 @@ gcal_shell_search_provider_init (GcalShellSearchProvider *self)
}
GcalShellSearchProvider*
-gcal_shell_search_provider_new (void)
+gcal_shell_search_provider_new (GcalManager *manager)
{
- return g_object_new (GCAL_TYPE_SHELL_SEARCH_PROVIDER, NULL);
+ return g_object_new (GCAL_TYPE_SHELL_SEARCH_PROVIDER,
+ "manager", manager,
+ NULL);
}
gboolean
@@ -419,13 +495,3 @@ gcal_shell_search_provider_dbus_unexport (GcalShellSearchProvider *self,
if (g_dbus_interface_skeleton_has_connection (G_DBUS_INTERFACE_SKELETON (self->skel), connection))
g_dbus_interface_skeleton_unexport_from_connection (G_DBUS_INTERFACE_SKELETON (self->skel), connection);
}
-
-void
-gcal_shell_search_provider_connect (GcalShellSearchProvider *self,
- GcalManager *manager)
-{
- self->manager = manager;
-
- gcal_manager_setup_shell_search (manager, E_CAL_DATA_MODEL_SUBSCRIBER (self));
- g_signal_connect_swapped (manager, "query-completed", G_CALLBACK (query_completed_cb), self);
-}
diff --git a/src/gcal-shell-search-provider.h b/src/gcal-shell-search-provider.h
index a7dcb34a..47078408 100644
--- a/src/gcal-shell-search-provider.h
+++ b/src/gcal-shell-search-provider.h
@@ -30,17 +30,16 @@ G_BEGIN_DECLS
G_DECLARE_FINAL_TYPE (GcalShellSearchProvider, gcal_shell_search_provider, GCAL, SHELL_SEARCH_PROVIDER,
GObject)
-GcalShellSearchProvider *gcal_shell_search_provider_new (void);
+GcalShellSearchProvider* gcal_shell_search_provider_new (GcalManager *manager);
gboolean gcal_shell_search_provider_dbus_export (GcalShellSearchProvider *search_provider,
GDBusConnection *connection,
const gchar *object_path,
GError **error);
+
void gcal_shell_search_provider_dbus_unexport (GcalShellSearchProvider *search_provider,
GDBusConnection *connection,
const gchar *object_path);
-void gcal_shell_search_provider_connect (GcalShellSearchProvider *search_provider,
- GcalManager *manager);
G_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]