[gnome-calendar] calendar: Make it a derivable class
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-calendar] calendar: Make it a derivable class
- Date: Sat, 4 May 2019 15:08:07 +0000 (UTC)
commit 02cbfdadf26784b80f41af4467fc5fdef9795690
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date: Sat May 4 11:05:32 2019 -0300
calendar: Make it a derivable class
src/core/gcal-calendar.c | 116 ++++++++++++++++++++++++++++-------------------
src/core/gcal-calendar.h | 7 ++-
2 files changed, 76 insertions(+), 47 deletions(-)
---
diff --git a/src/core/gcal-calendar.c b/src/core/gcal-calendar.c
index 7b0d8e36..2cb40d4c 100644
--- a/src/core/gcal-calendar.c
+++ b/src/core/gcal-calendar.c
@@ -23,10 +23,8 @@
#include "gcal-debug.h"
#include "gcal-calendar.h"
-struct _GcalCalendar
+typedef struct
{
- GObject parent;
-
GdkRGBA color;
ESource *source;
ECalClient *client;
@@ -38,11 +36,12 @@ struct _GcalCalendar
guint readonly_changed_handler_id;
guint visible_changed_handler_id;
gboolean initialized;
-};
+} GcalCalendarPrivate;
static void g_initable_iface_init (GInitableIface *iface);
G_DEFINE_TYPE_WITH_CODE (GcalCalendar, gcal_calendar, G_TYPE_OBJECT,
+ G_ADD_PRIVATE (GcalCalendar)
G_IMPLEMENT_INTERFACE (G_TYPE_INITABLE, g_initable_iface_init)
G_IMPLEMENT_INTERFACE (G_TYPE_ASYNC_INITABLE, NULL))
@@ -71,27 +70,30 @@ static GParamSpec *properties [N_PROPS];
static void
save_calendar (GcalCalendar *self)
{
- if (!e_source_get_writable (self->source))
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
+ if (!e_source_get_writable (priv->source))
{
g_warning ("Calendar %s is read-only and cannot be modified. Aborting.",
- e_source_get_uid (self->source));
+ e_source_get_uid (priv->source));
return;
}
- e_source_write (self->source, NULL, NULL, NULL);
+ e_source_write (priv->source, NULL, NULL, NULL);
}
static void
update_color (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
ESourceSelectable *selectable_extension;
const gchar *color;
- selectable_extension = e_source_get_extension (self->source, E_SOURCE_EXTENSION_CALENDAR);
+ selectable_extension = e_source_get_extension (priv->source, E_SOURCE_EXTENSION_CALENDAR);
color = e_source_selectable_get_color (selectable_extension);
- if (!gdk_rgba_parse (&self->color, color))
- gdk_rgba_parse (&self->color, "#ffffff");
+ if (!gdk_rgba_parse (&priv->color, color))
+ gdk_rgba_parse (&priv->color, "#ffffff");
}
@@ -142,6 +144,7 @@ gcal_calendar_initable_init (GInitable *initable,
GCancellable *cancellable,
GError **error)
{
+ GcalCalendarPrivate *priv;
g_autoptr (EClient) client = NULL;
g_autoptr (GError) local_error = NULL;
ESourceSelectable *selectable_extension;
@@ -150,11 +153,12 @@ gcal_calendar_initable_init (GInitable *initable,
GCAL_ENTRY;
self = GCAL_CALENDAR (initable);
+ priv = gcal_calendar_get_instance_private (self);
- g_assert (!self->initialized);
- self->initialized = TRUE;
+ g_assert (!priv->initialized);
+ priv->initialized = TRUE;
- if (!e_source_has_extension (self->source, E_SOURCE_EXTENSION_CALENDAR))
+ if (!e_source_has_extension (priv->source, E_SOURCE_EXTENSION_CALENDAR))
{
g_set_error (error,
GCAL_CALENDAR_ERROR,
@@ -163,26 +167,26 @@ gcal_calendar_initable_init (GInitable *initable,
GCAL_RETURN (FALSE);
}
- selectable_extension = e_source_get_extension (self->source, E_SOURCE_EXTENSION_CALENDAR);
+ selectable_extension = e_source_get_extension (priv->source, E_SOURCE_EXTENSION_CALENDAR);
update_color (self);
- self->color_changed_handler_id = g_signal_connect (selectable_extension,
+ priv->color_changed_handler_id = g_signal_connect (selectable_extension,
"notify::color",
G_CALLBACK (on_source_color_changed_cb),
self);
- self->visible_changed_handler_id = g_signal_connect (selectable_extension,
+ priv->visible_changed_handler_id = g_signal_connect (selectable_extension,
"notify::selected",
G_CALLBACK (on_source_visible_changed_cb),
self);
- self->name_changed_handler_id = g_signal_connect (self->source,
+ priv->name_changed_handler_id = g_signal_connect (priv->source,
"notify::display-name",
G_CALLBACK (on_source_name_changed_cb),
self);
/* 15s is arbitrary, but very rarely this will be reached */
- client = e_cal_client_connect_sync (self->source,
+ client = e_cal_client_connect_sync (priv->source,
E_CAL_CLIENT_SOURCE_TYPE_EVENTS,
15,
cancellable,
@@ -194,13 +198,13 @@ gcal_calendar_initable_init (GInitable *initable,
GCAL_RETURN (FALSE);
}
- self->readonly_changed_handler_id = g_signal_connect (client,
+ priv->readonly_changed_handler_id = g_signal_connect (client,
"notify::readonly",
G_CALLBACK (on_client_readonly_changed_cb),
self);
g_assert (E_IS_CAL_CLIENT (client));
- self->client = (ECalClient*) g_steal_pointer (&client);
+ priv->client = (ECalClient*) g_steal_pointer (&client);
GCAL_RETURN (TRUE);
}
@@ -220,18 +224,19 @@ static void
gcal_calendar_finalize (GObject *object)
{
GcalCalendar *self = (GcalCalendar *)object;
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
- g_signal_handler_disconnect (self->source, self->color_changed_handler_id);
- self->color_changed_handler_id = 0;
+ g_signal_handler_disconnect (priv->source, priv->color_changed_handler_id);
+ priv->color_changed_handler_id = 0;
- g_signal_handler_disconnect (self->source, self->name_changed_handler_id);
- self->name_changed_handler_id = 0;
+ g_signal_handler_disconnect (priv->source, priv->name_changed_handler_id);
+ priv->name_changed_handler_id = 0;
- g_signal_handler_disconnect (self->client, self->readonly_changed_handler_id);
- self->readonly_changed_handler_id = 0;
+ g_signal_handler_disconnect (priv->client, priv->readonly_changed_handler_id);
+ priv->readonly_changed_handler_id = 0;
- g_clear_object (&self->client);
- g_clear_object (&self->source);
+ g_clear_object (&priv->client);
+ g_clear_object (&priv->source);
G_OBJECT_CLASS (gcal_calendar_parent_class)->finalize (object);
}
@@ -243,15 +248,16 @@ gcal_calendar_get_property (GObject *object,
GParamSpec *pspec)
{
GcalCalendar *self = GCAL_CALENDAR (object);
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
switch (prop_id)
{
case PROP_CLIENT:
- g_value_set_object (value, self->client);
+ g_value_set_object (value, priv->client);
break;
case PROP_COLOR:
- g_value_set_boxed (value, &self->color);
+ g_value_set_boxed (value, &priv->color);
break;
case PROP_ID:
@@ -259,7 +265,7 @@ gcal_calendar_get_property (GObject *object,
break;
case PROP_NAME:
- g_value_set_string (value, e_source_get_display_name (self->source));
+ g_value_set_string (value, e_source_get_display_name (priv->source));
break;
case PROP_READ_ONLY:
@@ -267,7 +273,7 @@ gcal_calendar_get_property (GObject *object,
break;
case PROP_SOURCE:
- g_value_set_object (value, self->source);
+ g_value_set_object (value, priv->source);
break;
case PROP_VISIBLE:
@@ -286,6 +292,7 @@ gcal_calendar_set_property (GObject *object,
GParamSpec *pspec)
{
GcalCalendar *self = GCAL_CALENDAR (object);
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
switch (prop_id)
{
@@ -310,8 +317,8 @@ gcal_calendar_set_property (GObject *object,
break;
case PROP_SOURCE:
- g_assert (self->source == NULL);
- self->source = g_value_dup_object (value);
+ g_assert (priv->source == NULL);
+ priv->source = g_value_dup_object (value);
break;
case PROP_VISIBLE:
@@ -446,9 +453,11 @@ gcal_calendar_new_finish (GAsyncResult *result,
const GdkRGBA*
gcal_calendar_get_color (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
g_return_val_if_fail (GCAL_IS_CALENDAR (self), NULL);
- return &self->color;
+ return &priv->color;
}
/**
@@ -462,19 +471,20 @@ void
gcal_calendar_set_color (GcalCalendar *self,
const GdkRGBA *color)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
g_autofree gchar *color_string = NULL;
ESourceSelectable *selectable_extension;
g_return_if_fail (GCAL_IS_CALENDAR (self));
g_return_if_fail (color != NULL);
- if (gdk_rgba_equal (&self->color, color))
+ if (gdk_rgba_equal (&priv->color, color))
return;
- self->color = *color;
+ priv->color = *color;
color_string = gdk_rgba_to_string (color);
- selectable_extension = e_source_get_extension (self->source, E_SOURCE_EXTENSION_CALENDAR);
+ selectable_extension = e_source_get_extension (priv->source, E_SOURCE_EXTENSION_CALENDAR);
e_source_selectable_set_color (selectable_extension, color_string);
save_calendar (self);
@@ -493,9 +503,11 @@ gcal_calendar_set_color (GcalCalendar *self,
const gchar*
gcal_calendar_get_id (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
g_return_val_if_fail (GCAL_IS_CALENDAR (self), NULL);
- return e_source_get_uid (self->source);
+ return e_source_get_uid (priv->source);
}
/**
@@ -509,9 +521,11 @@ gcal_calendar_get_id (GcalCalendar *self)
const gchar*
gcal_calendar_get_name (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
g_return_val_if_fail (GCAL_IS_CALENDAR (self), NULL);
- return e_source_get_display_name (self->source);
+ return e_source_get_display_name (priv->source);
}
/**
@@ -525,9 +539,11 @@ void
gcal_calendar_set_name (GcalCalendar *self,
const gchar *name)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
g_return_if_fail (GCAL_IS_CALENDAR (self));
- e_source_set_display_name (self->source, name);
+ e_source_set_display_name (priv->source, name);
save_calendar (self);
g_object_notify_by_pspec (G_OBJECT (self), properties[PROP_NAME]);
@@ -544,9 +560,11 @@ gcal_calendar_set_name (GcalCalendar *self,
gboolean
gcal_calendar_is_read_only (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
g_return_val_if_fail (GCAL_IS_CALENDAR (self), FALSE);
- return e_client_is_readonly (E_CLIENT (self->client));
+ return e_client_is_readonly (E_CLIENT (priv->client));
}
/**
@@ -560,9 +578,11 @@ gcal_calendar_is_read_only (GcalCalendar *self)
ESource*
gcal_calendar_get_source (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
g_return_val_if_fail (GCAL_IS_CALENDAR (self), NULL);
- return self->source;
+ return priv->source;
}
/**
@@ -576,9 +596,11 @@ gcal_calendar_get_source (GcalCalendar *self)
ECalClient*
gcal_calendar_get_client (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
+
g_return_val_if_fail (GCAL_IS_CALENDAR (self), NULL);
- return self->client;
+ return priv->client;
}
/**
@@ -592,11 +614,12 @@ gcal_calendar_get_client (GcalCalendar *self)
gboolean
gcal_calendar_get_visible (GcalCalendar *self)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
ESourceSelectable *selectable_extension;
g_return_val_if_fail (GCAL_IS_CALENDAR (self), FALSE);
- selectable_extension = e_source_get_extension (self->source, E_SOURCE_EXTENSION_CALENDAR);
+ selectable_extension = e_source_get_extension (priv->source, E_SOURCE_EXTENSION_CALENDAR);
return e_source_selectable_get_selected (selectable_extension);
}
@@ -611,11 +634,12 @@ void
gcal_calendar_set_visible (GcalCalendar *self,
gboolean visible)
{
+ GcalCalendarPrivate *priv = gcal_calendar_get_instance_private (self);
ESourceSelectable *selectable_extension;
g_return_if_fail (GCAL_IS_CALENDAR (self));
- selectable_extension = e_source_get_extension (self->source, E_SOURCE_EXTENSION_CALENDAR);
+ selectable_extension = e_source_get_extension (priv->source, E_SOURCE_EXTENSION_CALENDAR);
e_source_selectable_set_selected (selectable_extension, visible);
save_calendar (self);
diff --git a/src/core/gcal-calendar.h b/src/core/gcal-calendar.h
index 30ce125c..069d66f4 100644
--- a/src/core/gcal-calendar.h
+++ b/src/core/gcal-calendar.h
@@ -40,7 +40,12 @@ typedef enum
#define GCAL_TYPE_CALENDAR (gcal_calendar_get_type())
-G_DECLARE_FINAL_TYPE (GcalCalendar, gcal_calendar, GCAL, CALENDAR, GObject)
+G_DECLARE_DERIVABLE_TYPE (GcalCalendar, gcal_calendar, GCAL, CALENDAR, GObject)
+
+struct _GcalCalendarClass
+{
+ GObjectClass parent_class;
+};
GQuark gcal_calendar_error_quark (void);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]