diff options
-rw-r--r-- | plugins/itip-formatter/ChangeLog | 7 | ||||
-rw-r--r-- | plugins/itip-formatter/itip-formatter.c | 60 |
2 files changed, 55 insertions, 12 deletions
diff --git a/plugins/itip-formatter/ChangeLog b/plugins/itip-formatter/ChangeLog index 48c18400a1..0587816aee 100644 --- a/plugins/itip-formatter/ChangeLog +++ b/plugins/itip-formatter/ChangeLog @@ -1,3 +1,10 @@ +2007-02-09 Sankar P <psankar@novell.com> + + * itip-formatter.c: (update_item), (view_response_cb): + Deletes all instances of a recurrence appointment as soon as the + invitation is accepted/declined adn applied-to-all. + Fixes #312301 + 2006-09-14 Andre Klapper <a9016009@gmx.de> * itip-view.c: correct display of time. Fixes bug #343686. diff --git a/plugins/itip-formatter/itip-formatter.c b/plugins/itip-formatter/itip-formatter.c index 457b5a7b17..27896c1a54 100644 --- a/plugins/itip-formatter/itip-formatter.c +++ b/plugins/itip-formatter/itip-formatter.c @@ -767,7 +767,7 @@ message_foreach_part (CamelMimePart *part, GSList **part_list) } } -static void +static gboolean update_item (FormatItipPObject *pitip, ItipViewResponse response) { struct icaltimetype stamp; @@ -776,6 +776,7 @@ update_item (FormatItipPObject *pitip, ItipViewResponse response) ECalComponent *clone_comp; ESource *source; GError *error = NULL; + gboolean result = TRUE; /* Set X-MICROSOFT-CDO-REPLYTIME to record the time at which * the user accepted/declined the request. (Outlook ignores @@ -798,6 +799,7 @@ update_item (FormatItipPObject *pitip, ItipViewResponse response) clone_comp = e_cal_component_new (); if (!e_cal_component_set_icalcomponent (clone_comp, clone)) { itip_view_add_lower_info_item (ITIP_VIEW (pitip->view), ITIP_VIEW_INFO_ITEM_TYPE_ERROR, _("Unable to parse item")); + result = FALSE; goto cleanup; } source = e_cal_get_source (pitip->current_ecal); @@ -857,6 +859,7 @@ update_item (FormatItipPObject *pitip, ItipViewResponse response) _("Unable to send item to calendar '%s'. %s"), e_source_peek_name (source), error->message); g_error_free (error); + result = FALSE; } else { itip_view_set_source_list (ITIP_VIEW (pitip->view), NULL); @@ -892,6 +895,7 @@ update_item (FormatItipPObject *pitip, ItipViewResponse response) cleanup: icalcomponent_remove_component (pitip->top_level, clone); g_object_unref (clone_comp); + return result; } /* TODO These operations should be available in e-cal-component.c */ @@ -1429,6 +1433,7 @@ view_response_cb (GtkWidget *widget, ItipViewResponse response, gpointer data) gboolean status = FALSE, delete_invitation_from_cache = FALSE; icalproperty *prop; ECalComponentTransparency trans; + gboolean flag; e_cal_component_get_transparency (pitip->comp, &trans); /* FIXME we should be providing an option to accept as free or busy */ @@ -1456,8 +1461,8 @@ view_response_cb (GtkWidget *widget, ItipViewResponse response, gpointer data) status = TRUE; if (status) { e_cal_component_rescan (pitip->comp); - update_item (pitip, response); - if (e_cal_get_save_schedules (pitip->current_ecal)) + flag = update_item (pitip, response); + if (e_cal_get_save_schedules (pitip->current_ecal) && flag) delete_invitation_from_cache = TRUE; } break; @@ -1466,8 +1471,8 @@ view_response_cb (GtkWidget *widget, ItipViewResponse response, gpointer data) ICAL_PARTSTAT_TENTATIVE); if (status) { e_cal_component_rescan (pitip->comp); - update_item (pitip, response); - if (e_cal_get_save_schedules (pitip->current_ecal)) + flag = update_item (pitip, response); + if (e_cal_get_save_schedules (pitip->current_ecal) && flag) delete_invitation_from_cache = TRUE; } @@ -1485,8 +1490,8 @@ view_response_cb (GtkWidget *widget, ItipViewResponse response, gpointer data) if (status) { e_cal_component_rescan (pitip->comp); - update_item (pitip, response); - if (e_cal_get_save_schedules (pitip->current_ecal)) + flag = update_item (pitip, response); + if (e_cal_get_save_schedules (pitip->current_ecal) && flag) delete_invitation_from_cache = TRUE; } break; @@ -1508,11 +1513,42 @@ view_response_cb (GtkWidget *widget, ItipViewResponse response, gpointer data) if (delete_invitation_from_cache) { CamelFolderChangeInfo *changes = NULL; - camel_folder_summary_remove_uid(((EMFormat *) pitip->pobject.format)->folder->summary, ((EMFormat *) pitip->pobject.format)->uid); - changes = camel_folder_change_info_new (); - camel_folder_change_info_remove_uid (changes, (char *)((EMFormat *) pitip->pobject.format)->uid); - camel_object_trigger_event (((EMFormat *) pitip->pobject.format)->folder, "folder_changed", changes); - camel_folder_change_info_free (changes); + const char *tag = NULL; + CamelMessageInfo *mi; + mi = camel_folder_summary_uid (((EMFormat *) pitip->pobject.format)->folder->summary, ((EMFormat *) pitip->pobject.format)->uid); + if (mi) { + changes = camel_folder_change_info_new (); + + if (itip_view_get_recur_check_state (ITIP_VIEW (pitip->view))) { + /* Recurring appointment and "apply-to-all" is selected */ + camel_message_info_ref (mi); + tag = camel_message_info_user_tag (mi, "recurrence-key"); + camel_message_info_free (mi); + if (tag) { + GPtrArray *summary_array; + int i=0; + + summary_array = camel_folder_summary_array (((EMFormat *) pitip->pobject.format)->folder->summary); + for (i=0; i<summary_array->len; i++) { + mi = (CamelMessageInfo *)g_ptr_array_index (summary_array, i); + camel_message_info_ref (mi); + if ( camel_message_info_user_tag (mi, "recurrence-key") && g_str_equal (camel_message_info_user_tag (mi, "recurrence-key"), tag)) { + + camel_folder_summary_remove_uid(((EMFormat *) pitip->pobject.format)->folder->summary, (char *)(mi->uid)); + camel_folder_change_info_remove_uid (changes, (char *)(mi->uid)); + } + camel_message_info_free (mi); + } + camel_folder_summary_array_free (((EMFormat *) pitip->pobject.format)->folder->summary, summary_array); + } + } else { + /* Either not a recurring appointment or "apply-to-all" is not selected. So just delete this instance alone */ + camel_folder_summary_remove_uid(((EMFormat *) pitip->pobject.format)->folder->summary, ((EMFormat *) pitip->pobject.format)->uid); + camel_folder_change_info_remove_uid (changes, (char *)((EMFormat *) pitip->pobject.format)->uid); + } + camel_object_trigger_event (((EMFormat *) pitip->pobject.format)->folder, "folder_changed", changes); + camel_folder_change_info_free (changes); + } } if (!delete_invitation_from_cache && pitip->delete_message) { |