diff options
-rw-r--r-- | calendar/ChangeLog | 15 | ||||
-rw-r--r-- | calendar/gui/gnome-cal.c | 28 |
2 files changed, 29 insertions, 14 deletions
diff --git a/calendar/ChangeLog b/calendar/ChangeLog index b128d4e0a7..4a746a513d 100644 --- a/calendar/ChangeLog +++ b/calendar/ChangeLog @@ -1,9 +1,16 @@ 2000-04-20 Seth Alves <alves@hungry.com> - * gui/gnome-cal.c (gnome_calendar_changed_cb): callback for - obj_updated or obj_removed. - (gnome_calendar_new): hook up gnome_calendar_changed_cb so if - evolution is running twice, they will both see changes right away. + * gui/gnome-cal.c (gnome_calendar_changed_cb): new function: callback + for listener's object updated signal. + (gnome_calendar_object_removed_cb): new function: callback for + listener's object removed signal. + (gnome_calendar_new): hook up listener's "obj_updated" and + "obj_removed" signals so if evolution is running twice, + they will both see changes right away. + (gnome_calendar_object_changed): don't call update_all, since + it will be called by the listener. + (gnome_calendar_remove_object): don't call update_all + (gnome_calendar_add_object): don't call update_all * gui/gncal-full-day.c (child_realize): create fullday's gcs even if pixmap_bell has already been created. this was diff --git a/calendar/gui/gnome-cal.c b/calendar/gui/gnome-cal.c index ad4c95168d..6229dbf30b 100644 --- a/calendar/gui/gnome-cal.c +++ b/calendar/gui/gnome-cal.c @@ -238,11 +238,23 @@ gnome_calendar_update_all (GnomeCalendar *cal, iCalObject *object, int flags) static void -gnome_calendar_changed_cb (GtkWidget *cal_client, - const char *uid, - GnomeCalendar *gcal) +gnome_calendar_object_updated_cb (GtkWidget *cal_client, + const char *uid, + GnomeCalendar *gcal) { - printf ("gnome-cal: got changed_cb, uid='%s'\n", uid?uid:"<NULL>"); + printf ("gnome-cal: got object changed_cb, uid='%s'\n", + uid?uid:"<NULL>"); + gnome_calendar_update_all (gcal, NULL, CHANGE_NEW); +} + + +static void +gnome_calendar_object_removed_cb (GtkWidget *cal_client, + const char *uid, + GnomeCalendar *gcal) +{ + printf ("gnome-cal: got object removed _cb, uid='%s'\n", + uid?uid:"<NULL>"); gnome_calendar_update_all (gcal, NULL, CHANGE_ALL); } @@ -262,9 +274,9 @@ gnome_calendar_new (char *title) setup_widgets (gcal); gtk_signal_connect (GTK_OBJECT (gcal->client), "obj_updated", - gnome_calendar_changed_cb, gcal); + gnome_calendar_object_updated_cb, gcal); gtk_signal_connect (GTK_OBJECT (gcal->client), "obj_removed", - gnome_calendar_changed_cb, gcal); + gnome_calendar_object_removed_cb, gcal); return retval; } @@ -361,7 +373,6 @@ gnome_calendar_add_object (GnomeCalendar *gcal, iCalObject *obj) obj_string = ical_object_to_string (obj); cal_client_update_object (gcal->client, obj->uid, obj_string); g_free (obj_string); - gnome_calendar_update_all (gcal, obj, CHANGE_NEW); } void @@ -373,9 +384,7 @@ gnome_calendar_remove_object (GnomeCalendar *gcal, iCalObject *obj) g_return_if_fail (GNOME_IS_CALENDAR (gcal)); g_return_if_fail (obj != NULL); - /* calendar_remove_object (gcal->cal, obj); DELETE */ r = cal_client_remove_object (gcal->client, obj->uid); - gnome_calendar_update_all (gcal, obj, CHANGE_ALL); } void @@ -389,7 +398,6 @@ gnome_calendar_object_changed (GnomeCalendar *gcal, iCalObject *obj, int flags) obj_string = ical_object_to_string (obj); cal_client_update_object (gcal->client, obj->uid, obj_string); g_free (obj_string); - gnome_calendar_update_all (gcal, obj, CHANGE_NEW); } static int |