aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/conduits
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/conduits')
-rw-r--r--calendar/conduits/calendar/calendar-conduit.c210
-rw-r--r--calendar/conduits/calendar/calendar-conduit.h13
2 files changed, 180 insertions, 43 deletions
diff --git a/calendar/conduits/calendar/calendar-conduit.c b/calendar/conduits/calendar/calendar-conduit.c
index 8f5835e4ef..c931b15174 100644
--- a/calendar/conduits/calendar/calendar-conduit.c
+++ b/calendar/conduits/calendar/calendar-conduit.c
@@ -49,8 +49,6 @@ CORBA_ORB orb;
static GNOME_Calendar_Repository
calendar_server (void)
{
- int n =0;
-
calendar = goad_server_activate_with_id (NULL, "IDL:GNOME:Calendar:Repository:1.0",
0, NULL);
if (calendar == CORBA_OBJECT_NIL)
@@ -71,6 +69,64 @@ calendar_notify (time_t time, CalendarAlarm *which, void *data)
{
}
+static void
+local_from_ical(CalLocalRecord **local,iCalObject *obj) {
+ g_return_if_fail(local!=NULL);
+ g_return_if_fail(*local!=NULL);
+ g_return_if_fail(obj!=NULL);
+
+ (*local)->ical = obj;
+ (*local)->ID = (*local)->ical->pilot_id;
+
+ g_message("(*local)->Id = %ld",(*local)->ID);
+ switch((*local)->ical->pilot_status) {
+ case ICAL_PILOT_SYNC_NONE: (*local)->local.attr = RecordNothing; break;
+ case ICAL_PILOT_SYNC_MOD: (*local)->local.attr = RecordNew; break;
+ case ICAL_PILOT_SYNC_DEL: (*local)->local.attr = RecordDeleted; break;
+ }
+
+ (*local)->local.secret = 0;
+ if(obj->class!=NULL)
+ if(strcmp(obj->class,"PRIVATE")==0)
+ (*local)->local.secret = 1;
+
+ (*local)->local.archived = 0;
+
+ /* used by iterations */
+ (*local)->list_ptr = NULL;
+}
+
+static CalLocalRecord *
+match_record_from_repository(PilotRecord *remote) {
+ char *vcal_string;
+ CalLocalRecord *loc;
+
+ g_return_val_if_fail(remote!=NULL,NULL);
+
+ printf ("requesting %ld []\n", remote->ID);
+
+ /* FIXME: ehm, who frees this string ? */
+ vcal_string =
+ GNOME_Calendar_Repository_get_object_by_pilot_id (calendar, remote->ID, &ev);
+
+ if (ev._major == CORBA_USER_EXCEPTION){
+ printf (_("\tObject did not exist\n"));
+ return NULL;
+ } else if(ev._major != CORBA_NO_EXCEPTION) {
+ printf(_("\tError while communicating with calendar server\n"));
+ CORBA_exception_free(&ev);
+ return NULL;
+ } else {
+ printf ("\tFound\n");
+ loc = g_new0(CalLocalRecord,1);
+ /* memory allocated in new_from_string is freed in free_match */
+ local_from_ical(&loc,ical_object_new_from_string (vcal_string));
+ return loc;
+ }
+
+ return NULL;
+}
+
/* Code blatantly stolen from
* calendar-pilot-sync.c:
*
@@ -97,7 +153,8 @@ update_record (PilotRecord *remote)
g_get_user_name (),
a.description ? a.description : "");
- printf ("requesting %d [%s]\n", remote->ID, a.description);
+ printf ("requesting %ld [%s]\n", remote->ID, a.description);
+ /* FIXME: ehm, who frees this string ? */
vcal_string = GNOME_Calendar_Repository_get_object_by_pilot_id (calendar, remote->ID, &ev);
if (ev._major == CORBA_USER_EXCEPTION){
@@ -277,7 +334,7 @@ load_records(GnomePilotConduit *c)
ConduitData *cd;
vcalendar_string =
- GNOME_Calendar_Repository_get_updated_objects (calendar, &ev);
+ GNOME_Calendar_Repository_get_objects (calendar, &ev);
cd = GET_DATA(c);
g_assert(cd!=NULL);
@@ -314,46 +371,69 @@ pre_sync(GnomePilotConduit *c, GnomePilotDBInfo *dbi)
return 1;
}
+/**
+ * Find (if possible) the local record which matches
+ * the given PilotRecord.
+ * if successfull, return non-zero and set *local to
+ * a non-null value (the located local record),
+ * otherwise return 0 and set *local = NULL;
+ */
+
static gint
-match_record (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord **local,
+match_record (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord **local,
PilotRecord *remote,
gpointer data)
{
g_return_val_if_fail(remote!=NULL,0);
- g_print ("in match_record\n");
- *local = NULL;
- return 1;
+ g_print ("in match_record\n");
+
+ *local = match_record_from_repository(remote);
+
+ return 1;
}
+
+/**
+ * Free the data allocated by a previous match_record call.
+ * If successfull, return non-zero and ser *local=NULL, otherwise
+ * return 0.
+ */
static gint
-free_match (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord **local,
+free_match (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord **local,
gpointer data)
{
g_print ("entering free_match\n");
+ ical_object_destroy (CALLOCALRECORD(*local)->ical);
+ g_free(*local);
+
*local = NULL;
- return 0;
+ return 1;
}
+
+
static gint
-archive_local (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+archive_local (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
gpointer data)
{
g_print ("entering archive_local\n");
return 1;
}
+
static gint
-archive_remote (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+archive_remote (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
PilotRecord *remote,
gpointer data)
{
g_print ("entering archive_remote\n");
return 1;
}
+
static gint
-store_remote (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+store_remote (GnomePilotConduitStandardAbs *conduit,
PilotRecord *remote,
gpointer data)
{
@@ -364,103 +444,147 @@ store_remote (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
return 1;
}
+
static gint
-clear_status_archive_local (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+clear_status_archive_local (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
gpointer data)
{
g_print ("entering clear_status_archive_local\n");
return 1;
}
+
static gint
-iterate (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord **local,
+iterate (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord **local,
gpointer data)
{
- g_print ("entering iterate\n");
- return 1;
+ g_return_val_if_fail(local!=NULL,0);
+
+ if(*local==NULL) {
+ g_message("calconduit: beginning iteration");
+ if(GET_DATA(conduit)->cal->events!=NULL) {
+ *local = g_new0(CalLocalRecord,1);
+
+ local_from_ical(local,(iCalObject*)GET_DATA(conduit)->cal->events->data);
+ (*local)->list_ptr = GET_DATA(conduit)->cal->events;
+ } else {
+ g_message("calconduit: no events");
+ (*local) = NULL;
+ }
+ } else {
+ g_message("calconduit: continuing iteration");
+ if(g_list_next((*local)->list_ptr)==NULL) {
+ g_message("calconduit: ending");
+ g_free((*local));
+ (*local) = NULL; /* ends iteration */
+ } else {
+ local_from_ical(local,(iCalObject*)(g_list_next((*local)->list_ptr)->data));
+ (*local)->list_ptr = g_list_next((*local)->list_ptr);
+ }
+ }
+ return 1;
}
+
static gint
-iterate_specific (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord **local,
+iterate_specific (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord **local,
gint flag,
gint archived,
gpointer data)
{
- g_print ("entering iterate_specific\n");
- return 1;
+ g_return_val_if_fail(local!=NULL,0);
+
+ g_print ("entering iterate_specific\n");
+ do {
+ gnome_pilot_conduit_standard_abs_iterate(conduit,(LocalRecord**)local);
+ if((*local)==NULL) break;
+ if(archived && ((*local)->local.archived==archived)) break;
+ if((*local)->local.attr == flag) break;
+ } while((*local)!=NULL);
+
+ return 1;
}
+
static gint
-purge (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+purge (GnomePilotConduitStandardAbs *conduit,
gpointer data)
{
g_print ("entering purge\n");
return 1;
}
+
static gint
-set_status (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+set_status (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
gint status,
gpointer data)
{
g_print ("entering set_status\n");
return 0;
}
+
static gint
-set_archived (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+set_archived (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
gint archived,
gpointer data)
{
g_print ("entering set_archived\n");
return 1;
}
+
static gint
-set_pilot_id (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+set_pilot_id (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
guint32 ID,
gpointer data)
{
g_print ("entering set_pilot_id\n");
return 1;
}
+
static gint
-compare (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+compare (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
PilotRecord *remote,
gpointer data)
{
g_print ("entering compare\n");
return 1;
}
+
static gint
-compare_backup (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+compare_backup (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
PilotRecord *remote,
gpointer data)
{
g_print ("entering compare_backup\n");
return 1;
}
+
static gint
-free_transmit (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+free_transmit (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
PilotRecord *remote,
gpointer data)
{
g_print ("entering free_transmit\n");
return 1;
}
+
static gint
-delete_all (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+delete_all (GnomePilotConduitStandardAbs *conduit,
gpointer data)
{
g_print ("entering delete_all\n");
return 1;
}
+
static PilotRecord *
-transmit (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
- LocalRecord *local,
+transmit (GnomePilotConduitStandardAbs *conduit,
+ CalLocalRecord *local,
gpointer data)
{
g_print ("entering transmit\n");
diff --git a/calendar/conduits/calendar/calendar-conduit.h b/calendar/conduits/calendar/calendar-conduit.h
index 5b7be2367d..2f5cc0c7da 100644
--- a/calendar/conduits/calendar/calendar-conduit.h
+++ b/calendar/conduits/calendar/calendar-conduit.h
@@ -9,6 +9,19 @@
#include <pi-datebook.h>
#include <gnome.h>
+#define CALLOCALRECORD(s) ((CalLocalRecord*)(s))
+typedef struct _CalLocalRecord CalLocalRecord;
+
+struct _CalLocalRecord {
+ /* The stuff from gnome-pilot-conduit-standard-abs.h */
+ LocalRecord local;
+ /* The Pilot ID of the record */
+ recordid_t ID;
+ /* The corresponding iCal object */
+ iCalObject *ical;
+ /* used by iterations, points to a GList element */
+ GList *list_ptr;
+};
typedef struct _ConduitCfg ConduitCfg;