diff options
author | Federico Mena Quintero <federico@ximian.com> | 2001-03-30 00:51:38 +0800 |
---|---|---|
committer | Federico Mena Quintero <federico@src.gnome.org> | 2001-03-30 00:51:38 +0800 |
commit | feaa9ddc81a8d4f0c3c037fd2822a56107bbab6b (patch) | |
tree | 3cfa33b74e4fac905b9aac2f5f346ab71555cdfe /calendar/pcs/cal-backend.c | |
parent | 1548cfd25910747414952bde0fd479222e7abdf5 (diff) | |
download | gsoc2013-evolution-feaa9ddc81a8d4f0c3c037fd2822a56107bbab6b.tar.gz gsoc2013-evolution-feaa9ddc81a8d4f0c3c037fd2822a56107bbab6b.tar.zst gsoc2013-evolution-feaa9ddc81a8d4f0c3c037fd2822a56107bbab6b.zip |
Engine for live queries to calendars. A query object watches a CalBackend
2001-03-29 Federico Mena Quintero <federico@ximian.com>
Engine for live queries to calendars. A query object watches a
CalBackend in the PCS and is otherwise completely separate from
it; backends need to do nothing to support live queries. Right
now we have the following functions:
(get-vtype)
Returns a string indicating the type of component
(VEVENT, VTODO, VJOURNAL, VFREEBUSY, VTIMEZONE,
UNKNOWN).
(occur-in-time-range? START END)
START - int, time_t start of the time range
END - int, time_t end of the time range
Returns a boolean indicating whether the component
has any occurrences in the specified time range.
* idl/evolution-calendar.idl (Cal::getQuery): New method that
initiates a live query.
(Query): New interface for a handle to a live query.
(QueryListener): New interface for a listener to changes in a live
query.
* pcs/query.[ch]: New files with the live query engine.
* pcs/cal-backend.h (CalBackendClass): Added notification signals
so that the query system can catch them.
(CalBackendClass): New virtual method ::get_load_state().
* pcs/cal-backend.c (cal_backend_opened):
(cal_backend_obj_updated):
(cal_backend_obj_updated): New functions to emit the notification
signals; to be used only by backend implementations.
(cal_backend_get_load_state): New function.
* pcs/cal-backend-file.c (notify_update): Call
cal_backend_obj_updated().
(notify_remove): Call call_backend_obj_removed().
(open_cal): Free the icalcomp if it is not of the correct type.
(cal_backend_file_get_load_state): Implemented new method.
* pcs/cal-backend-db.c (cal_backend_db_update_object): Call
cal_backend_obj_updated().
(cal_backend_db_remove_object): Call cal_backend_obj_removed().
(cal_backend_db_get_load_state): Implemented new method.
* pcs/cal.c (Cal_get_query): Implementation of the ::getQuery()
method.
svn path=/trunk/; revision=9013
Diffstat (limited to 'calendar/pcs/cal-backend.c')
-rw-r--r-- | calendar/pcs/cal-backend.c | 125 |
1 files changed, 124 insertions, 1 deletions
diff --git a/calendar/pcs/cal-backend.c b/calendar/pcs/cal-backend.c index ce53cda78a..350e6468e4 100644 --- a/calendar/pcs/cal-backend.c +++ b/calendar/pcs/cal-backend.c @@ -37,6 +37,9 @@ /* Signal IDs */ enum { LAST_CLIENT_GONE, + OPENED, + OBJ_UPDATED, + OBJ_REMOVED, LAST_SIGNAL }; @@ -96,8 +99,51 @@ cal_backend_class_init (CalBackendClass *class) GTK_SIGNAL_OFFSET (CalBackendClass, last_client_gone), gtk_marshal_NONE__NONE, GTK_TYPE_NONE, 0); + cal_backend_signals[OPENED] = + gtk_signal_new ("opened", + GTK_RUN_FIRST, + object_class->type, + GTK_SIGNAL_OFFSET (CalBackendClass, opened), + gtk_marshal_NONE__ENUM, + GTK_TYPE_NONE, 1, + GTK_TYPE_ENUM); + cal_backend_signals[OBJ_UPDATED] = + gtk_signal_new ("obj_updated", + GTK_RUN_FIRST, + object_class->type, + GTK_SIGNAL_OFFSET (CalBackendClass, obj_updated), + gtk_marshal_NONE__STRING, + GTK_TYPE_NONE, 1, + GTK_TYPE_STRING); + cal_backend_signals[OBJ_REMOVED] = + gtk_signal_new ("obj_removed", + GTK_RUN_FIRST, + object_class->type, + GTK_SIGNAL_OFFSET (CalBackendClass, obj_removed), + gtk_marshal_NONE__STRING, + GTK_TYPE_NONE, 1, + GTK_TYPE_STRING); gtk_object_class_add_signals (object_class, cal_backend_signals, LAST_SIGNAL); + + class->last_client_gone = NULL; + class->opened = NULL; + class->obj_updated = NULL; + class->obj_removed = NULL; + + class->get_uri = NULL; + class->add_cal = NULL; + class->open = NULL; + class->get_n_objects = NULL; + class->get_object = NULL; + class->get_type_by_uid = NULL; + class->get_uids = NULL; + class->get_objects_in_range = NULL; + class->get_changes = NULL; + class->get_alarms_in_range = NULL; + class->get_alarms_for_object = NULL; + class->update_object = NULL; + class->remove_object = NULL; } @@ -162,7 +208,29 @@ cal_backend_open (CalBackend *backend, GnomeVFSURI *uri, gboolean only_if_exists g_return_val_if_fail (uri != NULL, CAL_BACKEND_OPEN_ERROR); g_assert (CLASS (backend)->open != NULL); - result = (* CLASS (backend)->open) (backend, uri, only_if_exists); + result = (* CLASS (backend)->open) (backend, uri, only_if_exists); + + return result; +} + +/** + * cal_backend_is_loaded: + * @backend: A calendar backend. + * + * Queries whether a calendar backend has been loaded yet. + * + * Return value: TRUE if the backend has been loaded with data, FALSE otherwise. + **/ +gboolean +cal_backend_is_loaded (CalBackend *backend) +{ + gboolean result; + + g_return_val_if_fail (backend != NULL, FALSE); + g_return_val_if_fail (IS_CAL_BACKEND (backend), FALSE); + + g_assert (CLASS (backend)->is_loaded != NULL); + result = (* CLASS (backend)->is_loaded) (backend); return result; } @@ -417,3 +485,58 @@ cal_backend_last_client_gone (CalBackend *backend) gtk_signal_emit (GTK_OBJECT (backend), cal_backend_signals[LAST_CLIENT_GONE]); } +/** + * cal_backend_opened: + * @backend: A calendar backend. + * @status: Open status code. + * + * Emits the "opened" signal of a calendar backend. This function is to be used + * only by backend implementations. + **/ +void +cal_backend_opened (CalBackend *backend, CalBackendOpenStatus status) +{ + g_return_if_fail (backend != NULL); + g_return_if_fail (IS_CAL_BACKEND (backend)); + + gtk_signal_emit (GTK_OBJECT (backend), cal_backend_signals[OPENED], + status); +} + +/** + * cal_backend_obj_updated: + * @backend: A calendar backend. + * @uid: Unique identifier of the component that was updated. + * + * Emits the "obj_updated" signal of a calendar backend. This function is to be + * used only by backend implementations. + **/ +void +cal_backend_obj_updated (CalBackend *backend, const char *uid) +{ + g_return_if_fail (backend != NULL); + g_return_if_fail (IS_CAL_BACKEND (backend)); + g_return_if_fail (uid != NULL); + + gtk_signal_emit (GTK_OBJECT (backend), cal_backend_signals[OBJ_UPDATED], + uid); +} + +/** + * cal_backend_obj_removed: + * @backend: A calendar backend. + * @uid: Unique identifier of the component that was removed. + * + * Emits the "obj_removed" signal of a calendar backend. This function is to be + * used only by backend implementations. + **/ +void +cal_backend_obj_removed (CalBackend *backend, const char *uid) +{ + g_return_if_fail (backend != NULL); + g_return_if_fail (IS_CAL_BACKEND (backend)); + g_return_if_fail (uid != NULL); + + gtk_signal_emit (GTK_OBJECT (backend), cal_backend_signals[OBJ_REMOVED], + uid); +} |