aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/conduits/todo/todo-conduit.c
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/conduits/todo/todo-conduit.c')
-rw-r--r--calendar/conduits/todo/todo-conduit.c256
1 files changed, 256 insertions, 0 deletions
diff --git a/calendar/conduits/todo/todo-conduit.c b/calendar/conduits/todo/todo-conduit.c
new file mode 100644
index 0000000000..3a543816af
--- /dev/null
+++ b/calendar/conduits/todo/todo-conduit.c
@@ -0,0 +1,256 @@
+/* $Id$ */
+
+#include <glib.h>
+#include <gnome.h>
+
+#include <pi-source.h>
+#include <pi-socket.h>
+#include <pi-file.h>
+#include <pi-dlp.h>
+#include <pi-version.h>
+
+#include <sys/stat.h>
+#include <sys/types.h>
+#include <utime.h>
+#include <unistd.h>
+#include <pwd.h>
+#include <signal.h>
+#include <errno.h>
+#include <gpilotd/gnome-pilot-conduit.h>
+#include <gpilotd/gnome-pilot-conduit-standard-abs.h>
+
+#include "todo-conduit.h"
+
+static gint
+load_records(GnomePilotConduit *c)
+{
+ return 0;
+}
+
+static gint
+pre_sync(GnomePilotConduit *c, GnomePilotDBInfo *dbi) {
+ int l;
+ unsigned char *buf;
+
+ gtk_object_set_data(GTK_OBJECT(c),"dbinfo",dbi);
+
+ load_records(c);
+
+ buf = (unsigned char*)g_malloc(0xffff);
+ if((l=dlp_ReadAppBlock(dbi->pilot_socket,dbi->db_handle,0,(unsigned char *)buf,0xffff))<0) {
+ return -1;
+ }
+ unpack_ToDoAppInfo(&(GET_DATA(c)->ai),buf,l);
+ g_free(buf);
+
+ return 0;
+}
+
+static gint
+post_sync(GnomePilotConduit *c) {
+ return 0;
+}
+
+static gint
+match_record (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord **local,
+ PilotRecord *remote,
+ gpointer data)
+{
+ g_print ("in match_record\n");
+ return 0;
+}
+static gint
+free_match (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord **local,
+ gpointer data)
+{
+ g_print ("entering free_match\n");
+ *local = NULL;
+
+ return 0;
+}
+static gint
+archive_local (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ gpointer data)
+{
+ g_print ("entering archive_local\n");
+ return 1;
+
+}
+static gint
+archive_remote (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ PilotRecord *remote,
+ gpointer data)
+{
+ g_print ("entering archive_remote\n");
+ return 1;
+}
+static gint
+store_remote (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ PilotRecord *remote,
+ gpointer data)
+{
+ g_print ("entering store_remote\n");
+ g_print ("Rec:%s:\nLength:%d\n", remote->record, remote->length);
+ return 1;
+}
+static gint
+clear_status_archive_local (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ gpointer data)
+{
+ g_print ("entering clear_status_archive_local\n");
+ return 1;
+}
+static gint
+iterate (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord **local,
+ gpointer data)
+{
+ g_print ("entering iterate\n");
+ return 1;
+}
+static gint
+iterate_specific (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord **local,
+ gint flag,
+ gint archived,
+ gpointer data)
+{
+ g_print ("entering iterate_specific\n");
+ return 1;
+}
+static gint
+purge (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ gpointer data)
+{
+ g_print ("entering purge\n");
+ return 1;
+}
+static gint
+set_status (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ gint status,
+ gpointer data)
+{
+ g_print ("entering set_status\n");
+ return 1;
+}
+static gint
+set_archived (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *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,
+ guint32 ID,
+ gpointer data)
+{
+ g_print ("entering set_pilot_id\n");
+ return 1;
+}
+static gint
+compare (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ PilotRecord *remote,
+ gpointer data)
+{
+ g_print ("entering compare\n");
+ return 1;
+}
+static gint
+compare_backup (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ PilotRecord *remote,
+ gpointer data)
+{
+ g_print ("entering compare_backup\n");
+ return 1;
+}
+static gint
+free_transmit (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ PilotRecord *remote,
+ gpointer data)
+{
+ g_print ("entering free_transmit\n");
+ return 1;
+}
+static gint
+delete_all (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ gpointer data)
+{
+ g_print ("entering delete_all\n");
+ return 1;
+}
+static PilotRecord *
+transmit (GnomePilotConduitStandardAbs *pilot_conduit_standard_abs,
+ LocalRecord *local,
+ gpointer data)
+{
+ g_print ("entering transmit\n");
+ return NULL;
+}
+
+static GnomePilotConduit *
+conduit_get_gpilot_conduit (guint32 pilotId)
+{
+ GtkObject *retval;
+ ConduitCfg *cfg;
+ ConduitData *cdata;
+
+ g_print ("creating our new conduit\n");
+ retval = gnome_pilot_conduit_standard_abs_new ("TodoDB", 0x0);
+ g_assert (retval != NULL);
+ gnome_pilot_conduit_construct(GNOME_PILOT_CONDUIT(retval),"todo");
+
+ cfg = g_new0(ConduitCfg,1);
+ g_assert(cfg != NULL);
+ gtk_object_set_data(retval,"conduit_cfg",cfg);
+
+ cdata = g_new0(ConduitData,1);
+ g_assert(cdata != NULL);
+ gtk_object_set_data(retval,"conduit_data",cdata);
+
+ gtk_signal_connect (retval, "match_record", (GtkSignalFunc) match_record, NULL);
+ gtk_signal_connect (retval, "free_match", (GtkSignalFunc) free_match, NULL);
+ gtk_signal_connect (retval, "archive_local", (GtkSignalFunc) archive_local, NULL);
+ gtk_signal_connect (retval, "archive_remote", (GtkSignalFunc) archive_remote, NULL);
+ gtk_signal_connect (retval, "store_remote", (GtkSignalFunc) store_remote, NULL);
+ gtk_signal_connect (retval, "clear_status_archive_local", (GtkSignalFunc) clear_status_archive_local, NULL);
+ gtk_signal_connect (retval, "iterate", (GtkSignalFunc) iterate, NULL);
+ gtk_signal_connect (retval, "iterate_specific", (GtkSignalFunc) iterate_specific, NULL);
+ gtk_signal_connect (retval, "purge", (GtkSignalFunc) purge, NULL);
+ gtk_signal_connect (retval, "set_status", (GtkSignalFunc) set_status, NULL);
+ gtk_signal_connect (retval, "set_archived", (GtkSignalFunc) set_archived, NULL);
+ gtk_signal_connect (retval, "set_pilot_id", (GtkSignalFunc) set_pilot_id, NULL);
+ gtk_signal_connect (retval, "compare", (GtkSignalFunc) compare, NULL);
+ gtk_signal_connect (retval, "compare_backup", (GtkSignalFunc) compare_backup, NULL);
+ gtk_signal_connect (retval, "free_transmit", (GtkSignalFunc) free_transmit, NULL);
+ gtk_signal_connect (retval, "delete_all", (GtkSignalFunc) delete_all, NULL);
+ gtk_signal_connect (retval, "transmit", (GtkSignalFunc) transmit, NULL);
+ gtk_signal_connect (retval, "pre_sync", (GtkSignalFunc) pre_sync, NULL);
+ gtk_signal_connect (retval, "post_sync", (GtkSignalFunc) post_sync, NULL);
+
+ load_configuration(&cfg,pilotId);
+
+ return GNOME_PILOT_CONDUIT (retval);
+}
+static void
+conduit_destroy_gpilot_conduit (GnomePilotConduit *conduit)
+{
+ ConduitCfg *cc;
+ cc = GET_CONFIG(conduit);
+ destroy_configuration(&cc);
+ gtk_object_destroy (GTK_OBJECT (conduit));
+}
+
+