diff options
author | Seth Alves <alves@src.gnome.org> | 2000-04-21 10:35:18 +0800 |
---|---|---|
committer | Seth Alves <alves@src.gnome.org> | 2000-04-21 10:35:18 +0800 |
commit | 115bdd59278dbbc2111c88b80be065db72e08528 (patch) | |
tree | 25e84e4daab30639c65a30af8be5902779bef2f5 /calendar/gui/gnome-cal.c | |
parent | 0ebe18356658bb57a0c69f872a38ceb58259bfe1 (diff) | |
download | gsoc2013-evolution-115bdd59278dbbc2111c88b80be065db72e08528.tar.gz gsoc2013-evolution-115bdd59278dbbc2111c88b80be065db72e08528.tar.zst gsoc2013-evolution-115bdd59278dbbc2111c88b80be065db72e08528.zip |
new function: callback for listener's object updated signal.
* 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
svn path=/trunk/; revision=2539
Diffstat (limited to 'calendar/gui/gnome-cal.c')
-rw-r--r-- | calendar/gui/gnome-cal.c | 28 |
1 files changed, 18 insertions, 10 deletions
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 |