aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ChangeLog5
-rw-r--r--src/vasprintf.c14
2 files changed, 19 insertions, 0 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index 2a547bea..2215329a 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,3 +1,8 @@
+2010-11-17 Marcus Brinkmann <[email protected]>
+
+ * 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 <[email protected]>
* w32-ce.h (strcasecmp, strdup) [_MSC_VER]: Define.
diff --git a/src/vasprintf.c b/src/vasprintf.c
index 77113a31..03d38ff2 100644
--- a/src/vasprintf.c
+++ b/src/vasprintf.c
@@ -51,6 +51,19 @@ int_vasprintf (result, format, args)
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 @@ int_vasprintf (result, format, args)
return vsprintf (*result, format, *args);
else
return 0;
+#endif
}
int