[svn] gpgme - r1507 - trunk/src
svn author marcus
cvs at cvs.gnupg.org
Wed Nov 17 03:11:06 CET 2010
Author: marcus
Date: 2010-11-17 03:11:05 +0100 (Wed, 17 Nov 2010)
New Revision: 1507
Modified:
trunk/src/ChangeLog
trunk/src/vasprintf.c
Log:
2010-11-17 Marcus Brinkmann <mb at g10code.com>
* vasprintf.c (int_vasprintf) [HAVE_W32CE_SYSTEM]: Just use a
fixed size buffer, as va_copy is not easy to fake.
Modified: trunk/src/ChangeLog
===================================================================
--- trunk/src/ChangeLog 2010-11-15 15:30:04 UTC (rev 1506)
+++ trunk/src/ChangeLog 2010-11-17 02:11:05 UTC (rev 1507)
@@ -1,3 +1,8 @@
+2010-11-17 Marcus Brinkmann <mb at g10code.com>
+
+ * vasprintf.c (int_vasprintf) [HAVE_W32CE_SYSTEM]: Just use a
+ fixed size buffer, as va_copy is not easy to fake.
+
2010-11-15 Marcus Brinkmann <mb at g10code.com>
* w32-ce.h (strcasecmp, strdup) [_MSC_VER]: Define.
Modified: trunk/src/vasprintf.c
===================================================================
--- trunk/src/vasprintf.c 2010-11-15 15:30:04 UTC (rev 1506)
+++ trunk/src/vasprintf.c 2010-11-17 02:11:05 UTC (rev 1507)
@@ -51,6 +51,19 @@
const char *format;
va_list *args;
{
+#ifdef HAVE_W32CE_SYSTEM
+ /* No va_copy and the replacement above doesn't work. */
+#define MAX_STRLEN 256
+ *result = malloc (MAX_STRLEN);
+ if (*result != NULL)
+ {
+ int res = _vsnprintf (*result, MAX_STRLEN, format, *args);
+ (*result)[MAX_STRLEN - 1] = '\0';
+ return res;
+ }
+ else
+ return 0;
+#else
const char *p = format;
/* Add one to make sure that it is never zero, which might cause malloc
to return NULL. */
@@ -133,6 +146,7 @@
return vsprintf (*result, format, *args);
else
return 0;
+#endif
}
int
More information about the Gnupg-commits
mailing list