/* * $Id$ * * (c) 2004 by Kalle Wallin * * 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 "support.h" #include "charset.h" #include "config.h" #include #include #include #ifndef HAVE_STRCASESTR const char * strcasestr(const char *haystack, const char *needle) { char *haystack2 = g_utf8_strdown(haystack, -1); char *needle2 = g_utf8_strdown(needle, -1); char *result; assert(haystack != NULL); assert(needle != NULL); result = strstr(haystack2, needle2); g_free(haystack2); g_free(needle2); return haystack + (result - haystack2); } #endif /* HAVE_STRCASESTR */ // FIXME: utf-8 length char * strscroll(char *str, char *separator, int width, scroll_state_t *st) { gchar *tmp, *buf; gsize len, size; assert(str != NULL); assert(separator != NULL); assert(st != NULL); if( st->offset==0 ) { st->offset++; return g_strdup(str); } /* create a buffer containing the string and the separator */ size = strlen(str)+strlen(separator)+1; tmp = g_malloc(size); g_strlcpy(tmp, str, size); g_strlcat(tmp, separator, size); len = utf8_width(tmp); if (st->offset >= len) st->offset = 0; /* create the new scrolled string */ size = width+1; if (g_utf8_validate(tmp, -1, NULL) ) { int ulen; buf = g_malloc(size*6);// max length of utf8 char is 6 g_utf8_strncpy(buf, g_utf8_offset_to_pointer(tmp,st->offset), size); if( (ulen = g_utf8_strlen(buf, -1)) < width ) g_utf8_strncpy(buf+strlen(buf), tmp, size - ulen - 1); } else { buf = g_malloc(size); g_strlcpy(buf, tmp+st->offset, size); if (strlen(buf) < (size_t)width) g_strlcat(buf, tmp, size); } if( time(NULL)-st->t >= 1 ) { st->t = time(NULL); st->offset++; } g_free(tmp); return buf; }