From be13fec34348b896b22543dd6f4693ec19d1ac02 Mon Sep 17 00:00:00 2001 From: Jeffrey Stedfast Date: Thu, 30 Nov 2000 22:23:44 +0000 Subject: Bump the version to 0.2.99.4 2000-11-30 Jeffrey Stedfast * configure.in: Bump the version to 0.2.99.4 * gal/util/e-util.c (e_strstrcase): This should return a const gchar *. (e_str_make_safe): New convenience function to replace risky chars with an underscore. svn path=/trunk/; revision=6744 --- e-util/e-util.c | 19 ++++++++++++++++--- e-util/e-util.h | 6 ++++-- 2 files changed, 20 insertions(+), 5 deletions(-) (limited to 'e-util') diff --git a/e-util/e-util.c b/e-util/e-util.c index 9a0929c865..6965bff9ee 100644 --- a/e-util/e-util.c +++ b/e-util/e-util.c @@ -500,7 +500,7 @@ e_strsplit (const gchar *string, return str_array; } -gchar * +const gchar * e_strstrcase (const gchar *haystack, const gchar *needle) { /* find the needle in the haystack neglecting case */ @@ -515,11 +515,24 @@ e_strstrcase (const gchar *haystack, const gchar *needle) return NULL; if (len == 0) - return (char *)haystack; + return haystack; - for (ptr = (char *)haystack; *(ptr + len - 1) != '\0'; ptr++) + for (ptr = haystack; *(ptr + len - 1) != '\0'; ptr++) if (!g_strncasecmp(ptr, needle, len)) return ptr; return NULL; } + +void +e_str_make_safe (gchar *string) +{ + gchar *p; + + g_return_if_fail (string != NULL); + + for (p = string; *p; p++) { + if (!isprint ((unsigned char)*p) || strchr (" /'\"`&();|<>${}!", *p)) + *p = '_'; + } +} diff --git a/e-util/e-util.h b/e-util/e-util.h index 7f61295d9a..37dcf3daec 100644 --- a/e-util/e-util.h +++ b/e-util/e-util.h @@ -48,8 +48,10 @@ gchar **e_strsplit (const gchar *string, const gchar *delimiter, gint max_tokens); -gchar *e_strstrcase (const gchar *haystack, - const gchar *needle); +const gchar *e_strstrcase (const gchar *haystack, + const gchar *needle); + +void e_str_make_safe (gchar *string); void e_marshal_INT__INT_INT_POINTER (GtkObject * object, GtkSignalFunc func, -- cgit v1.2.3