[gnome-calendar/wip/mcrha/gcal-event-construct: 93/94] event: Rework initialization process
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-calendar/wip/mcrha/gcal-event-construct: 93/94] event: Rework initialization process
- Date: Mon, 7 Mar 2022 17:51:28 +0000 (UTC)
commit 8ccb7be84772881a61d21b80f53bfd661482e92a
Author: Milan Crha <mcrha redhat com>
Date: Wed Feb 2 12:54:31 2022 +0100
event: Rework initialization process
While fixing timezone bugs, it was found that the calendar property needs
to be set before the component property. The component times may require
to have the calendar set, to be able to lookup the custom timezones in the
calendar, thus make sure the calendar is set before the component is set,
during the construction time.
Rework the initialization process so that setting the construct-only
component property merely takes a hold on the references; and the actual
setting up of the event happens during g_initable_init().
Closes https://gitlab.gnome.org/GNOME/gnome-calendar/-/issues/788
src/core/gcal-event.c | 69 ++++++++++++++++++++++++---------------------------
1 file changed, 33 insertions(+), 36 deletions(-)
---
diff --git a/src/core/gcal-event.c b/src/core/gcal-event.c
index 717b4e23..3396912a 100644
--- a/src/core/gcal-event.c
+++ b/src/core/gcal-event.c
@@ -103,9 +103,6 @@ struct _GcalEvent
GcalCalendar *calendar;
GcalRecurrence *recurrence;
-
- gboolean is_valid : 1;
- GError *initialization_error;
};
static void gcal_event_initable_iface_init (GInitableIface *iface);
@@ -117,6 +114,9 @@ G_DEFINE_QUARK (GcalEvent, gcal_event_error);
enum {
PROP_0,
+ /* Have the calendar as the first, to be available before the component
+ is set, when the object is constructing. */
+ PROP_CALENDAR,
PROP_ALL_DAY,
PROP_COLOR,
PROP_COMPONENT,
@@ -124,7 +124,6 @@ enum {
PROP_DATE_END,
PROP_DATE_START,
PROP_LOCATION,
- PROP_CALENDAR,
PROP_RANGE,
PROP_SUMMARY,
PROP_TIMEZONE,
@@ -309,9 +308,9 @@ load_alarms (GcalEvent *self)
g_slist_free_full (alarm_uids, g_free);
}
-static void
-gcal_event_set_component_internal (GcalEvent *self,
- ECalComponent *component)
+static gboolean
+setup_component (GcalEvent *self,
+ GError **error)
{
g_autoptr (GTimeZone) zone_start = NULL;
g_autoptr (GTimeZone) zone_end = NULL;
@@ -324,12 +323,10 @@ gcal_event_set_component_internal (GcalEvent *self,
gboolean start_is_all_day, end_is_all_day;
gchar *description, *location;
- g_assert (self->component == NULL);
-
- self->component = e_cal_component_clone (component);
+ g_assert (self->component != NULL);
/* Setup start date */
- start = e_cal_component_get_dtstart (component);
+ start = e_cal_component_get_dtstart (self->component);
/*
* A NULL start date is invalid. We set something bogus to proceed, and make
@@ -337,14 +334,15 @@ gcal_event_set_component_internal (GcalEvent *self,
*/
if (!start || !e_cal_component_datetime_get_value (start))
{
- self->is_valid = FALSE;
- g_set_error (&self->initialization_error,
+ g_set_error (error,
GCAL_EVENT_ERROR,
GCAL_EVENT_ERROR_INVALID_START_DATE,
"Event '%s' has an invalid start date", gcal_event_get_uid (self));
e_cal_component_datetime_free (start);
start = e_cal_component_datetime_new_take (i_cal_time_new_today (), NULL);
+ g_clear_pointer (&start, e_cal_component_datetime_free);
+ return FALSE;
}
GCAL_TRACE_MSG ("Retrieving start timezone");
@@ -365,7 +363,7 @@ gcal_event_set_component_internal (GcalEvent *self,
g_clear_object (&date);
/* Setup end date */
- end = e_cal_component_get_dtend (component);
+ end = e_cal_component_get_dtend (self->component);
if (!end || !e_cal_component_datetime_get_value (end))
{
@@ -395,35 +393,34 @@ gcal_event_set_component_internal (GcalEvent *self,
}
/* Summary */
- text = e_cal_component_get_summary (component);
+ text = e_cal_component_get_summary (self->component);
if (text && e_cal_component_text_get_value (text))
gcal_event_set_summary (self, e_cal_component_text_get_value (text));
else
gcal_event_set_summary (self, "");
/* Location */
- location = e_cal_component_get_location (component);
+ location = e_cal_component_get_location (self->component);
gcal_event_set_location (self, location ? location : "");
/* Setup description */
- description = get_desc_from_component (component, "\n\n");
+ description = get_desc_from_component (self->component, "\n\n");
gcal_event_set_description (self, description);
/* Setup UID */
gcal_event_update_uid_internal (self);
/* Set has-recurrence to check if the component has recurrence or not */
- self->has_recurrence = e_cal_component_has_recurrences(component);
+ self->has_recurrence = e_cal_component_has_recurrences(self->component);
/* Load the recurrence-rules in GcalRecurrence struct */
- self->recurrence = gcal_recurrence_parse_recurrence_rules (component);
+ self->recurrence = gcal_recurrence_parse_recurrence_rules (self->component);
/* Load and setup the alarms */
load_alarms (self);
g_object_notify_by_pspec (G_OBJECT (self), properties[PROP_HAS_RECURRENCE]);
g_object_notify_by_pspec (G_OBJECT (self), properties[PROP_RECURRENCE]);
- g_object_notify_by_pspec (G_OBJECT (self), properties[PROP_COMPONENT]);
g_clear_pointer (&description, g_free);
g_clear_pointer (&location, g_free);
@@ -431,31 +428,32 @@ gcal_event_set_component_internal (GcalEvent *self,
e_cal_component_text_free (text);
e_cal_component_datetime_free (start);
e_cal_component_datetime_free (end);
+
+ return TRUE;
+}
+
+
+static void
+gcal_event_set_component_internal (GcalEvent *self,
+ ECalComponent *component)
+{
+ g_assert (self->component == NULL);
+ self->component = e_cal_component_clone (component);
+ g_object_notify_by_pspec (G_OBJECT (self), properties[PROP_COMPONENT]);
}
/*
* GInitable iface implementation
*/
-G_LOCK_DEFINE_STATIC (init_lock);
-
static gboolean
gcal_event_initable_init (GInitable *initable,
GCancellable *cancellable,
GError **error)
{
- GcalEvent *self;
-
- self = GCAL_EVENT (initable);
-
- G_LOCK (init_lock);
+ GcalEvent *self = GCAL_EVENT (initable);
- if (!self->is_valid)
- g_propagate_error (error, g_error_copy (self->initialization_error));
-
- G_UNLOCK (init_lock);
-
- return self->is_valid;
+ return setup_component (self, error);
}
static void
@@ -785,8 +783,6 @@ gcal_event_init (GcalEvent *self)
/* Alarms */
self->alarms = g_hash_table_new_full (g_direct_hash, g_direct_equal, NULL, g_free);
-
- self->is_valid = TRUE;
}
/**
@@ -1393,7 +1389,8 @@ gcal_event_set_calendar (GcalEvent *self,
g_object_notify_by_pspec (G_OBJECT (self), properties[PROP_CALENDAR]);
- gcal_event_update_uid_internal (self);
+ if (self->component != NULL)
+ gcal_event_update_uid_internal (self);
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]