diff options
Diffstat (limited to 'calendar/conduits/common/libecalendar-common-conduit.c')
-rw-r--r-- | calendar/conduits/common/libecalendar-common-conduit.c | 372 |
1 files changed, 0 insertions, 372 deletions
diff --git a/calendar/conduits/common/libecalendar-common-conduit.c b/calendar/conduits/common/libecalendar-common-conduit.c deleted file mode 100644 index 5a082461c6..0000000000 --- a/calendar/conduits/common/libecalendar-common-conduit.c +++ /dev/null @@ -1,372 +0,0 @@ -/* - * Evolution calendar - ToDo Conduit - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) version 3. - * - * 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with the program; if not, see <http://www.gnu.org/licenses/> - * - * - * Authors: - * Tom Billet <mouse256@ulyssis.org> - * Nathan Owens <pianocomp81@yahoo.com> - * - * Copyright (C) 1999-2008 Novell, Inc. (www.novell.com) - * - */ - -#include <string.h> - -#include <libedataserver/e-categories.h> -#include <e-pilot-util.h> -#include <pi-appinfo.h> -#include <glib.h> -#include <gconf/gconf-client.h> - -#include "libecalendar-common-conduit.h" - -/*make debugging possible if it's required for a conduit */ -#define LOG(x) -#ifdef DEBUG_CALCONDUIT -#define LOG(x) x -#endif -#ifdef DEBUG_MEMOCONDUIT -#define LOG(x) x -#endif -#ifdef DEBUG_TODOCONDUIT -#define LOG(x) x -#endif -#ifdef DEBUG_CONDUIT -#define LOG(x) x -#endif - -/* - * Adds a category to the category app info structure (name and ID), - * sets category->renamed[i] to true if possible to rename. - * - * This will be packed and written to the app info block during post_sync. - * - * NOTE: cat_to_add MUST be in PCHAR format. Evolution stores categories - * in UTF-8 format. A conversion must take place before calling - * this function (see e_pilot_utf8_to_pchar() in e-pilot-util.c) - */ -gint -e_pilot_add_category_if_possible(gchar *cat_to_add, struct CategoryAppInfo *category) -{ - gint i, j; - gint retval = 0; /* 0 is the Unfiled category */ - LOG(g_message("e_pilot_add_category_if_possible\n")); - - for (i=0; i<PILOT_MAX_CATEGORIES; i++) { - /* if strlen is 0, then the category is empty - the PalmOS doesn't let 0-length strings for - categories */ - if (strlen(category->name[i]) == 0) { - gint cat_to_add_len; - gint desktopUniqueID; - - cat_to_add_len = strlen(cat_to_add); - retval = i; - - if (cat_to_add_len > 15) { - /* Have to truncate the category name */ - cat_to_add_len = 15; - } - - /* only 15 characters for category, 16th is - * '\0' can't do direct mem transfer due to - * declaration type - */ - for (j=0; j<cat_to_add_len; j++) { - category->name[i][j] = cat_to_add[j]; - } - - for (j=cat_to_add_len; j<16; j++) { - category->name[i][j] = '\0'; - } - - /* find a desktop id that is not in use between 128 and 255 */ - for (desktopUniqueID = 128; desktopUniqueID <= 255; desktopUniqueID++) { - gint found = 0; - for (j=0; j<PILOT_MAX_CATEGORIES; j++) { - if (category->ID[i] == desktopUniqueID) { - found = 1; - } - } - if (found == 0) { - break; - } - if (desktopUniqueID == 255) { - LOG (g_warning ("*** no more categories available on PC ***")); - } - } - category->ID[i] = desktopUniqueID; - - category->renamed[i] = TRUE; - - break; - } - } - - if (retval == 0) { - LOG (g_warning ("*** not adding category - category list already full ***")); - } - - return retval; -} - -/* - *conversion from an evolution category to a palm category - */ -void e_pilot_local_category_to_remote(gint * pilotCategory, ECalComponent *comp, struct CategoryAppInfo *category, const gchar *pilot_charset) -{ - GSList *c_list = NULL; - gchar * category_string; - gint i; - e_cal_component_get_categories_list (comp, &c_list); - if (c_list) { - /* list != 0, so at least 1 category is assigned */ - category_string = e_pilot_utf8_to_pchar((const gchar *)c_list->data, pilot_charset); - if (c_list->next != 0) { - LOG (g_message ("Note: item has more categories in evolution, first chosen")); - } - i=1; - while (1) { - if (strcmp(category_string,category->name[i]) == 0) { - *pilotCategory = i; - break; - } - i++; - if (i == PILOT_MAX_CATEGORIES) { - /* category not available on palm, try to create it */ - *pilotCategory = e_pilot_add_category_if_possible(category_string,category); - break; - } - } - e_cal_component_free_categories_list(c_list); - c_list = NULL; - } else { - *pilotCategory = 0; - } - /*end category*/ -} - -/* - *conversion from a palm category to an evolution category - */ -void e_pilot_remote_category_to_local(gint pilotCategory, ECalComponent *comp, struct CategoryAppInfo *category, const gchar *pilot_charset) -{ - gchar *category_string = NULL; - - if (pilotCategory != 0) { - /* pda has category assigned */ - category_string = e_pilot_utf8_from_pchar(category->name[pilotCategory], pilot_charset); - - LOG(g_message("Category: %s\n", category_string)); - - /* TODO The calendar editor page and search bar are not updated until a restart of the evolution client */ - if (e_categories_exist(category_string) == FALSE) { - /* add if it doesn't exist */ - LOG(g_message("Category created on pc\n")); - e_categories_add(category_string, NULL, NULL, TRUE); - } - } - - /* store the data on in evolution */ - if (category_string == NULL) { - /* note: this space is needed to make sure evolution clears the category */ - e_cal_component_set_categories (comp, " "); - } - else { - - /* Since only the first category is synced with the PDA, add the PDA's - * category to the beginning of the category list */ - GSList *c_list = NULL; - GSList *newcat_in_list; - e_cal_component_get_categories_list (comp, &c_list); - - /* remove old item from list so we don't have duplicate entries */ - newcat_in_list = g_slist_find_custom(c_list, category_string, (GCompareFunc)strcmp); - if (newcat_in_list != NULL) - { - c_list = g_slist_remove(c_list, newcat_in_list->data); - } - - c_list = g_slist_prepend(c_list, category_string); - e_cal_component_set_categories_list (comp, c_list); - e_cal_component_free_categories_list(c_list); - } -} - -static gchar * -build_setup_path (const gchar *path, const gchar *key) -{ - return g_strconcat ("/apps/evolution/conduit", "/", path, "/", key, NULL); -} - -gboolean -e_pilot_setup_get_bool (const gchar *path, const gchar *key, gboolean def) -{ - gboolean res = def; - gchar *full_path; - GConfValue *value; - GConfClient *gconf; - - g_return_val_if_fail (path != NULL, res); - g_return_val_if_fail (key != NULL, res); - - gconf = gconf_client_get_default (); - full_path = build_setup_path (path, key); - - value = gconf_client_get (gconf, full_path, NULL); - if (value) { - if (value->type == GCONF_VALUE_BOOL) - res = gconf_value_get_bool (value); - - gconf_value_free (value); - } - - g_free (full_path); - g_object_unref (gconf); - - return res; -} - -void -e_pilot_setup_set_bool (const gchar *path, const gchar *key, gboolean value) -{ - GError *error = NULL; - gchar *full_path; - GConfClient *gconf; - - g_return_if_fail (path != NULL); - g_return_if_fail (key != NULL); - - gconf = gconf_client_get_default (); - full_path = build_setup_path (path, key); - - gconf_client_set_bool (gconf, full_path, value, &error); - - g_free (full_path); - g_object_unref (gconf); - - if (error) { - g_message ("%s: Failed to write: %s", G_STRFUNC, error->message); - g_error_free (error); - } -} - -gint -e_pilot_setup_get_int (const gchar *path, const gchar *key, gint def) -{ - gint res = def; - gchar *full_path; - GConfValue *value; - GConfClient *gconf; - - g_return_val_if_fail (path != NULL, res); - g_return_val_if_fail (key != NULL, res); - - gconf = gconf_client_get_default (); - full_path = build_setup_path (path, key); - - value = gconf_client_get (gconf, full_path, NULL); - if (value) { - if (value->type == GCONF_VALUE_INT) - res = gconf_value_get_int (value); - - gconf_value_free (value); - } - - g_free (full_path); - g_object_unref (gconf); - - return res; -} - -void -e_pilot_setup_set_int (const gchar *path, const gchar *key, gint value) -{ - GError *error = NULL; - gchar *full_path; - GConfClient *gconf; - - g_return_if_fail (path != NULL); - g_return_if_fail (key != NULL); - - gconf = gconf_client_get_default (); - full_path = build_setup_path (path, key); - - gconf_client_set_int (gconf, full_path, value, &error); - - g_free (full_path); - g_object_unref (gconf); - - if (error) { - g_message ("%s: Failed to write: %s", G_STRFUNC, error->message); - g_error_free (error); - } -} - -gchar * -e_pilot_setup_get_string (const gchar *path, const gchar *key, const gchar *def) -{ - gchar *res = g_strdup (def); - gchar *full_path; - GConfValue *value; - GConfClient *gconf; - - g_return_val_if_fail (path != NULL, res); - g_return_val_if_fail (key != NULL, res); - - gconf = gconf_client_get_default (); - full_path = build_setup_path (path, key); - - value = gconf_client_get (gconf, full_path, NULL); - if (value) { - if (value->type == GCONF_VALUE_STRING) { - g_free (res); - res = g_strdup (gconf_value_get_string (value)); - } - - gconf_value_free (value); - } - - g_free (full_path); - g_object_unref (gconf); - - return res; -} - -void -e_pilot_setup_set_string (const gchar *path, const gchar *key, const gchar *value) -{ - GError *error = NULL; - gchar *full_path; - GConfClient *gconf; - - g_return_if_fail (path != NULL); - g_return_if_fail (key != NULL); - g_return_if_fail (value != NULL); - - gconf = gconf_client_get_default (); - full_path = build_setup_path (path, key); - - gconf_client_set_string (gconf, full_path, value, &error); - - g_free (full_path); - g_object_unref (gconf); - - if (error) { - g_message ("%s: Failed to write: %s", G_STRFUNC, error->message); - g_error_free (error); - } -} |