Mercurial > pidgin
view libpurple/protocols/gg/gg-utils.c @ 17011:e44a272b27a8
merge of '41f3a410baa40935d56c676abbf69c92987f86b7'
and 'b8101f7594a660d5b9f9a0a1ad0e740ed9a78364'
author | Nathan Walp <nwalp@pidgin.im> |
---|---|
date | Fri, 11 May 2007 00:16:58 +0000 |
parents | 32c366eeeb99 |
children | 44b4e8bd759b |
line wrap: on
line source
/** * @file gg-utils.c * * purple * * Copyright (C) 2005 Bartosz Oler <bartosz@bzimage.us> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * 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 "gg-utils.h" /* uin_t ggp_str_to_uin(const char *str) {{{ */ uin_t ggp_str_to_uin(const char *str) { char *tmp; long num; if (!str) return 0; errno = 0; num = strtol(str, &tmp, 10); if (*str == '\0' || *tmp != '\0') return 0; if ((errno == ERANGE || (num == LONG_MAX || num == LONG_MIN)) #if (LONG_MAX > UINT_MAX) || num > (long)UINT_MAX #endif || num < 0) return 0; return (uin_t) num; } /* }}} */ /* unsigned int ggp_array_size(char **array) {{{ */ unsigned int ggp_array_size(char **array) { unsigned int i; for (i = 0; array[i] != NULL && i < UINT_MAX; i++) {} return i; } /* }}} */ /* char *charset_convert(const gchar *locstr, const char *encsrc, const char *encdst) {{{ */ char *charset_convert(const gchar *locstr, const char *encsrc, const char *encdst) { gchar *msg; GError *err = NULL; if (locstr == NULL) return NULL; msg = g_convert_with_fallback(locstr, strlen(locstr), encdst, encsrc, "?", NULL, NULL, &err); if (err != NULL) { purple_debug_error("gg", "Error converting from %s to %s: %s\n", encsrc, encdst, err->message); g_error_free(err); } /* Just in case? */ if (msg == NULL) msg = g_strdup(locstr); return msg; } /* }}} */ /* ggp_get_uin(PurpleAccount *account) {{{ */ uin_t ggp_get_uin(PurpleAccount *account) { return ggp_str_to_uin(purple_account_get_username(account)); } /* }}} */ /* char *ggp_buddy_get_name(PurpleConnection *gc, const uin_t uin) {{{ */ char *ggp_buddy_get_name(PurpleConnection *gc, const uin_t uin) { PurpleBuddy *buddy; gchar *str_uin; str_uin = g_strdup_printf("%lu", (unsigned long int)uin); buddy = purple_find_buddy(purple_connection_get_account(gc), str_uin); if (buddy != NULL) { g_free(str_uin); return g_strdup(purple_buddy_get_alias(buddy)); } else { return str_uin; } } /* }}} */ /* vim: set ts=8 sts=0 sw=8 noet: */