/* Evolution calendar client - test program * * Copyright (C) 2000 Ximian, Inc. * Copyright (C) 2000 Ximian, Inc. * * Author: Federico Mena-Quintero <federico@ximian.com> * * This program is free software; you can redistribute it and/or * modify it under the terms of version 2 of the GNU General Public * License as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. */ #include <config.h> #include <stdlib.h> #include <bonobo-activation/bonobo-activation.h> #include <bonobo/bonobo-i18n.h> #include <bonobo/bonobo-main.h> #include "cal-client.h" #include "cal-util/cal-component.h" static CalClient *client1; static CalClient *client2; /* Prints a message with a client identifier */ static void cl_printf (CalClient *client, const char *format, ...) { va_list args; va_start (args, format); printf ("Client %s: ", client == client1 ? "1" : client == client2 ? "2" : "UNKNOWN"); vprintf (format, args); va_end (args); } /* Dumps some interesting data from a component */ static void dump_component (CalComponent *comp) { const char *uid; CalComponentText summary; cal_component_get_uid (comp, &uid); printf ("UID %s\n", uid); cal_component_get_summary (comp, &summary); if (summary.value) printf ("\tSummary: `%s', altrep `%s'\n", summary.value, summary.altrep ? summary.altrep : "NONE"); else printf ("\tNo summary\n"); } /* Lists the UIDs of objects in a calendar, called as an idle handler */ static gboolean list_uids (gpointer data) { CalClient *client; GList *uids; GList *l; client = CAL_CLIENT (data); uids = cal_client_get_uids (client, CALOBJ_TYPE_ANY); cl_printf (client, "UIDs: "); if (!uids) printf ("none\n"); else { for (l = uids; l; l = l->next) { char *uid; uid = l->data; printf ("`%s' ", uid); } printf ("\n"); for (l = uids; l; l = l->next) { char *uid; CalComponent *comp; CalClientGetStatus status; uid = l->data; status = cal_client_get_object (client, uid, &comp); if (status == CAL_CLIENT_GET_SUCCESS) { printf ("------------------------------\n"); dump_component (comp); printf ("------------------------------\n"); g_object_unref (comp); } else { printf ("FAILED: %d\n", status); } } } cal_obj_uid_list_free (uids); g_object_unref (client); return FALSE; } /* Callback used when a calendar is opened */ static void cal_opened_cb (CalClient *client, CalClientOpenStatus status, gpointer data) { cl_printf (client, "Load/create %s\n", ((status == CAL_CLIENT_OPEN_SUCCESS) ? "success" : (status == CAL_CLIENT_OPEN_ERROR) ? "error" : (status == CAL_CLIENT_OPEN_NOT_FOUND) ? "not found" : (status == CAL_CLIENT_OPEN_METHOD_NOT_SUPPORTED) ? "method not supported" : "unknown status value")); if (status == CAL_CLIENT_OPEN_SUCCESS) { GList *comp_list; /* get free/busy information */ comp_list = cal_client_get_free_busy (client, NULL, 0, time (NULL)); if (comp_list) { GList *l; for (l = comp_list; l; l = l->next) { char *comp_str; comp_str = cal_component_get_as_string (CAL_COMPONENT (l->data)); g_object_unref (l->data); cl_printf (client, "Free/Busy -> %s\n", comp_str); g_free (comp_str); } g_list_free (comp_list); } g_idle_add (list_uids, client); } else g_object_unref (client); } /* Callback used when an object is updated */ static void obj_updated_cb (CalClient *client, const char *uid, gpointer data) { cl_printf (client, "Object updated: %s\n", uid); } /* Callback used when a client is destroyed */ static void client_destroy_cb (GObject *object, gpointer data) { if (CAL_CLIENT (object) == client1) client1 = NULL; else if (CAL_CLIENT (object) == client2) client2 = NULL; else g_assert_not_reached (); if (!client1 && !client2) bonobo_main_quit (); } /* Creates a calendar client and tries to load the specified URI into it */ static void create_client (CalClient **client, const char *uri, gboolean only_if_exists) { gboolean result; *client = cal_client_new (); if (!*client) { g_message ("create_client(): could not create the client"); exit (1); } g_signal_connect (*client, "destroy", G_CALLBACK (client_destroy_cb), NULL); g_signal_connect (*client, "cal_opened", G_CALLBACK (cal_opened_cb), NULL); g_signal_connect (*client, "obj_updated", G_CALLBACK (obj_updated_cb), NULL); printf ("Calendar loading `%s'...\n", uri); result = cal_client_open_calendar (*client, uri, only_if_exists); if (!result) { g_message ("create_client(): failure when issuing calendar open request `%s'", uri); exit (1); } } int main (int argc, char **argv) { char *dir; bindtextdomain (GETTEXT_PACKAGE, EVOLUTION_LOCALEDIR); textdomain (GETTEXT_PACKAGE); g_type_init (); bonobo_activation_init (argc, argv); if (!bonobo_init (&argc, argv)) { g_message ("main(): could not initialize Bonobo"); exit (1); } dir = g_strdup_printf ("%s/evolution/local/Calendar/calendar.ics", g_get_home_dir ()); create_client (&client1, dir, FALSE); g_free (dir); create_client (&client2, "/cvs/evolution/calendar/cal-client/test.ics", TRUE); bonobo_main (); return 0; }