From: Fabian Keil Date: Sun, 9 Sep 2007 18:20:20 +0000 (+0000) Subject: Turn privoxy_strlcpy() into a function and try to work with X-Git-Tag: v_3_0_7~153 X-Git-Url: http://www.privoxy.org/gitweb/config.html?a=commitdiff_plain;h=bdc5d2b6118663febc403bdc97ff193bb2e9f135;p=privoxy.git Turn privoxy_strlcpy() into a function and try to work with b0rked snprintf() implementations too. Reported by icmp30. --- diff --git a/miscutil.c b/miscutil.c index 6de15715..22776d8e 100644 --- a/miscutil.c +++ b/miscutil.c @@ -1,4 +1,4 @@ -const char miscutil_rcs[] = "$Id: miscutil.c,v 1.51 2007/06/17 16:12:22 fabiankeil Exp $"; +const char miscutil_rcs[] = "$Id: miscutil.c,v 1.52 2007/08/19 12:32:34 fabiankeil Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/miscutil.c,v $ @@ -44,6 +44,9 @@ const char miscutil_rcs[] = "$Id: miscutil.c,v 1.51 2007/06/17 16:12:22 fabianke * * Revisions : * $Log: miscutil.c,v $ + * Revision 1.52 2007/08/19 12:32:34 fabiankeil + * Fix a conversion warning. + * * Revision 1.51 2007/06/17 16:12:22 fabiankeil * #ifdef _WIN32 the last commit. According to David Shaw, * one of the gnupg developers, the changes are mingw32-specific. @@ -1112,6 +1115,38 @@ long int pick_from_range(long int range) } +#ifdef USE_PRIVOXY_STRLCPY +/********************************************************************* + * + * Function : privoxy_strlcpy + * + * Description : strlcpy(3) look-alike for those without decent libc. + * + * Parameters : + * 1 : destination: buffer to copy into. + * 2 : source: String to copy. + * 3 : size: Size of destination buffer. + * + * Returns : The length of the string that privoxy_strlcpy() tried to create. + * + *********************************************************************/ +size_t privoxy_strlcpy(char *destination, const char *source, const size_t size) +{ + snprintf(destination, size, "%s", source); + /* + * Platforms that lack strlcpy() also tend to have + * a broken snprintf implementation that doesn't + * guarantee nul termination. + * + * XXX: the configure script should detect and reject those. + */ + destination[(size > 1) ? size-1 : 0] = '\0'; + + return strlen(source); +} +#endif /* def USE_PRIVOXY_STRLCPY */ + + #ifndef HAVE_STRLCAT /********************************************************************* * @@ -1124,7 +1159,7 @@ long int pick_from_range(long int range) * 2 : source: String to copy. * 3 : size: Size of destination buffer. * - * Returns : The length of the string that strlcat tried to create. + * Returns : The length of the string that privoxy_strlcat() tried to create. * *********************************************************************/ size_t privoxy_strlcat(char *destination, const char *source, const size_t size) diff --git a/miscutil.h b/miscutil.h index baab1e60..38fb85ba 100644 --- a/miscutil.h +++ b/miscutil.h @@ -1,6 +1,6 @@ #ifndef MISCUTIL_H_INCLUDED #define MISCUTIL_H_INCLUDED -#define MISCUTIL_H_VERSION "$Id: miscutil.h,v 1.27 2007/04/09 17:48:51 fabiankeil Exp $" +#define MISCUTIL_H_VERSION "$Id: miscutil.h,v 1.28 2007/05/11 11:48:16 fabiankeil Exp $" /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/miscutil.h,v $ @@ -37,6 +37,13 @@ * * Revisions : * $Log: miscutil.h,v $ + * Revision 1.28 2007/05/11 11:48:16 fabiankeil + * - Delete strsav() which was replaced + * by string_append() years ago. + * - Add a strlcat() look-alike. + * - Use strlcat() and strlcpy() in those parts + * of the code that are run on unixes. + * * Revision 1.27 2007/04/09 17:48:51 fabiankeil * Check for HAVE_SNPRINTF instead of __OS2__ * before including the portable snprintf() code. @@ -218,7 +225,9 @@ time_t timegm(struct tm *tm); /* Here's looking at you, Ulrich. */ #if !defined(HAVE_STRLCPY) -#define strlcpy(dst, src, size) (size_t)snprintf((dst), (size), "%s", (src)) +size_t privoxy_strlcpy(char *destination, const char *source, size_t size); +#define strlcpy privoxy_strlcpy +#define USE_PRIVOXY_STRLCPY 1 #define HAVE_STRLCPY 1 #endif /* ndef HAVE_STRLCPY*/