aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Meeks <michael.meeks@novell.com>2010-03-14 06:09:37 +0800
committerMichael Meeks <michael.meeks@novell.com>2010-03-14 06:09:37 +0800
commit2184d0a2da58d8ad09dc99ee1479c77276185c9c (patch)
tree96377c3c9af4e6df6242cedb16e5e8a2812ae21f
parentd1c8dd596ce7b0f6a4ce9de605fd67290b5ce42c (diff)
downloadgsoc2013-evolution-2184d0a2da58d8ad09dc99ee1479c77276185c9c.tar
gsoc2013-evolution-2184d0a2da58d8ad09dc99ee1479c77276185c9c.tar.gz
gsoc2013-evolution-2184d0a2da58d8ad09dc99ee1479c77276185c9c.tar.bz2
gsoc2013-evolution-2184d0a2da58d8ad09dc99ee1479c77276185c9c.tar.lz
gsoc2013-evolution-2184d0a2da58d8ad09dc99ee1479c77276185c9c.tar.xz
gsoc2013-evolution-2184d0a2da58d8ad09dc99ee1479c77276185c9c.tar.zst
gsoc2013-evolution-2184d0a2da58d8ad09dc99ee1479c77276185c9c.zip
improve locking for async query update, share code for object disposal,
and don't crash as before: bug#612826#
-rw-r--r--calendar/gui/dialogs/comp-editor.c2
-rw-r--r--calendar/gui/gnome-cal.c137
2 files changed, 78 insertions, 61 deletions
diff --git a/calendar/gui/dialogs/comp-editor.c b/calendar/gui/dialogs/comp-editor.c
index 7e16d8924e..e002f6afd4 100644
--- a/calendar/gui/dialogs/comp-editor.c
+++ b/calendar/gui/dialogs/comp-editor.c
@@ -1580,8 +1580,8 @@ comp_editor_init (CompEditor *editor)
GtkAction *action;
GtkWidget *container;
GtkWidget *widget;
- GtkWidget *scroll;
GtkWindow *window;
+ GtkWidget *scroll = NULL;
EShell *shell;
gint n_targets;
GError *error = NULL;
diff --git a/calendar/gui/gnome-cal.c b/calendar/gui/gnome-cal.c
index a8afeff7fc..7f85442df0 100644
--- a/calendar/gui/gnome-cal.c
+++ b/calendar/gui/gnome-cal.c
@@ -92,6 +92,7 @@ struct _GnomeCalendarPrivate {
ECalendar *date_navigator;
/* Calendar query for the date navigator */
+ GMutex *dn_query_lock;
GList *dn_queries; /* list of CalQueries */
gchar *sexp;
gchar *todo_sexp;
@@ -152,6 +153,7 @@ enum {
static guint signals[LAST_SIGNAL];
static void gnome_calendar_do_dispose (GObject *object);
+static void gnome_calendar_finalize (GObject *object);
static void gnome_calendar_goto_date (GnomeCalendar *gcal,
GnomeCalendarGotoDateType goto_date);
@@ -489,6 +491,7 @@ gnome_calendar_class_init (GnomeCalendarClass *class)
object_class->get_property = gnome_calendar_get_property;
object_class->constructed = gnome_calendar_constructed;
object_class->dispose = gnome_calendar_do_dispose;
+ object_class->finalize = gnome_calendar_finalize;
class->dates_shown_changed = NULL;
class->calendar_selection_changed = NULL;
@@ -987,6 +990,31 @@ struct _date_query_msg {
GnomeCalendar *gcal;
};
+
+static void
+free_dn_queries (GnomeCalendar *gcal)
+{
+ GList *l;
+ GnomeCalendarPrivate *priv;
+
+ priv = gcal->priv;
+
+ g_mutex_lock (priv->dn_query_lock);
+
+ for (l = priv->dn_queries; l != NULL; l = l->next) {
+ if (!l->data)
+ continue;
+ g_signal_handlers_disconnect_matched ((ECalView *) l->data, G_SIGNAL_MATCH_DATA,
+ 0, 0, NULL, NULL, gcal);
+ g_object_unref (l->data);
+ }
+
+ g_list_free (priv->dn_queries);
+ priv->dn_queries = NULL;
+
+ g_mutex_unlock (priv->dn_query_lock);
+}
+
static void
update_query_async (struct _date_query_msg *msg)
{
@@ -999,18 +1027,7 @@ update_query_async (struct _date_query_msg *msg)
priv = gcal->priv;
/* free the previous queries */
- for (iter = priv->dn_queries; iter != NULL; iter = iter->next) {
- old_query = iter->data;
-
- if (old_query) {
- g_signal_handlers_disconnect_matched (old_query, G_SIGNAL_MATCH_DATA,
- 0, 0, NULL, NULL, gcal);
- g_object_unref (old_query);
- }
- }
-
- g_list_free (priv->dn_queries);
- priv->dn_queries = NULL;
+ free_dn_queries (gcal);
g_return_if_fail (priv->sexp != NULL);
@@ -1363,6 +1380,7 @@ gnome_calendar_init (GnomeCalendar *gcal)
non_intrusive_error_table = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_object_unref);
priv->todo_update_lock = g_mutex_new ();
+ priv->dn_query_lock = g_mutex_new ();
priv->current_view_type = GNOME_CAL_DAY_VIEW;
priv->range_selected = FALSE;
@@ -1383,6 +1401,7 @@ gnome_calendar_init (GnomeCalendar *gcal)
static void
gnome_calendar_do_dispose (GObject *object)
{
+ GList *l;
GnomeCalendar *gcal;
GnomeCalendarPrivate *priv;
@@ -1392,66 +1411,64 @@ gnome_calendar_do_dispose (GObject *object)
gcal = GNOME_CALENDAR (object);
priv = gcal->priv;
- if (priv) {
- GList *l;
+
+ if (priv->shell_settings != NULL) {
+ g_object_unref (priv->shell_settings);
+ priv->shell_settings = NULL;
+ }
- if (priv->shell_settings != NULL) {
- g_object_unref (priv->shell_settings);
- priv->shell_settings = NULL;
- }
+ if (priv->model != NULL) {
+ g_signal_handlers_disconnect_by_func (
+ priv->model, view_progress_cb, gcal);
+ g_signal_handlers_disconnect_by_func (
+ priv->model, view_done_cb, gcal);
+ g_object_unref (priv->model);
+ priv->model = NULL;
+ }
- if (priv->model != NULL) {
- g_signal_handlers_disconnect_by_func (
- priv->model, view_progress_cb, gcal);
- g_signal_handlers_disconnect_by_func (
- priv->model, view_done_cb, gcal);
- g_object_unref (priv->model);
- priv->model = NULL;
- }
+ for (l = priv->notifications; l; l = l->next)
+ calendar_config_remove_notification (GPOINTER_TO_UINT (l->data));
+ g_list_free (priv->notifications);
+ priv->notifications = NULL;
- for (l = priv->notifications; l; l = l->next)
- calendar_config_remove_notification (GPOINTER_TO_UINT (l->data));
- g_list_free (priv->notifications);
- priv->notifications = NULL;
+ free_dn_queries (gcal);
- if (priv->dn_queries) {
- for (l = priv->dn_queries; l != NULL; l = l->next) {
- g_signal_handlers_disconnect_matched ((ECalView *) l->data, G_SIGNAL_MATCH_DATA,
- 0, 0, NULL, NULL, gcal);
- g_object_unref (l->data);
- }
+ if (non_intrusive_error_table) {
+ g_hash_table_destroy (non_intrusive_error_table);
+ non_intrusive_error_table = NULL;
+ }
- g_list_free (priv->dn_queries);
- priv->dn_queries = NULL;
- }
+ if (priv->sexp) {
+ g_free (priv->sexp);
+ priv->sexp = NULL;
+ }
- if (non_intrusive_error_table) {
- g_hash_table_destroy (non_intrusive_error_table);
- non_intrusive_error_table = NULL;
- }
+ if (priv->update_timeout) {
+ g_source_remove (priv->update_timeout);
+ priv->update_timeout = 0;
+ }
- if (priv->sexp) {
- g_free (priv->sexp);
- priv->sexp = NULL;
- }
+ if (priv->update_marcus_bains_line_timeout) {
+ g_source_remove (priv->update_marcus_bains_line_timeout);
+ priv->update_marcus_bains_line_timeout = 0;
+ }
- if (priv->update_timeout) {
- g_source_remove (priv->update_timeout);
- priv->update_timeout = 0;
- }
+ G_OBJECT_CLASS (gnome_calendar_parent_class)->dispose (object);
+}
- if (priv->update_marcus_bains_line_timeout) {
- g_source_remove (priv->update_marcus_bains_line_timeout);
- priv->update_marcus_bains_line_timeout = 0;
- }
+static void
+gnome_calendar_finalize (GObject *object)
+{
+ GnomeCalendar *gcal = GNOME_CALENDAR (object);
+ GnomeCalendarPrivate *priv = gcal->priv;
- g_mutex_free (priv->todo_update_lock);
+ g_mutex_free (priv->todo_update_lock);
+ g_mutex_free (priv->dn_query_lock);
- g_free (priv);
- gcal->priv = NULL;
- }
+ g_free (priv);
+ gcal->priv = NULL;
- G_OBJECT_CLASS (gnome_calendar_parent_class)->dispose (object);
+ G_OBJECT_CLASS (gnome_calendar_parent_class)->finalize (object);
}
void