diff options
author | Charles Kerr <charles.kerr@canonical.com> | 2013-09-05 11:57:05 -0500 |
---|---|---|
committer | Charles Kerr <charles.kerr@canonical.com> | 2013-09-05 11:57:05 -0500 |
commit | 039722a99003890732e6a06de7005fbd1ea2b4d3 (patch) | |
tree | a95196a61f728c5ae5a37885bc801b71cd8d0c83 /src/planner.c | |
parent | f47b93edd44b7eb7525f704e7801985e895716c6 (diff) | |
download | ayatana-indicator-datetime-039722a99003890732e6a06de7005fbd1ea2b4d3.tar.gz ayatana-indicator-datetime-039722a99003890732e6a06de7005fbd1ea2b4d3.tar.bz2 ayatana-indicator-datetime-039722a99003890732e6a06de7005fbd1ea2b4d3.zip |
change the Planner API s.t. get_appoinments() is an async function. Breaks everything
Diffstat (limited to 'src/planner.c')
-rw-r--r-- | src/planner.c | 31 |
1 files changed, 29 insertions, 2 deletions
diff --git a/src/planner.c b/src/planner.c index 1643651..124aeae 100644 --- a/src/planner.c +++ b/src/planner.c @@ -178,17 +178,44 @@ compare_appointments_by_start_time (gconstpointer ga, gconstpointer gb) return g_date_time_compare (a->begin, b->begin); } +void +indicator_datetime_planner_get_appointments (IndicatorDatetimePlanner * self, + GDateTime * begin, + GDateTime * end, + GAsyncReadyCallback callback, + gpointer user_data) +{ + IndicatorDatetimePlannerClass * klass; + + g_return_if_fail (INDICATOR_IS_DATETIME_PLANNER (self)); + + klass = INDICATOR_DATETIME_PLANNER_GET_CLASS (self); + g_return_if_fail (klass->get_appointments != NULL); + klass->get_appointments (self, begin, end, callback, user_data); +} + GSList * -indicator_datetime_planner_get_appointments (IndicatorDatetimePlanner * self, GDateTime * begin, GDateTime * end) +indicator_datetime_planner_get_appointments_finish (IndicatorDatetimePlanner * self, + GAsyncResult * res, + GError ** error) { + IndicatorDatetimePlannerClass * klass; GSList * appointments; g_return_val_if_fail (INDICATOR_IS_DATETIME_PLANNER (self), NULL); - appointments = INDICATOR_DATETIME_PLANNER_GET_CLASS (self)->get_appointments (self, begin, end); + klass = INDICATOR_DATETIME_PLANNER_GET_CLASS (self); + g_return_val_if_fail (klass->get_appointments_finish != NULL, NULL); + appointments = klass->get_appointments_finish (self, res, error); return g_slist_sort (appointments, compare_appointments_by_start_time); } +void +indicator_datetime_planner_free_appointments (GSList * l) +{ + g_slist_free_full (l, (GDestroyNotify)indicator_datetime_appt_free); +} + gboolean indicator_datetime_planner_is_configured (IndicatorDatetimePlanner * self) { |