Blame vasprintf_compat.h

Packit ea8578
#ifndef __vasprintf_compat_h
Packit ea8578
#define __vasprintf_compat_h
Packit ea8578
Packit ea8578
/**
Packit ea8578
 * @file
Packit ea8578
 * @brief Do not use, json-c internal, may be changed or removed at any time.
Packit ea8578
 */
Packit ea8578
Packit ea8578
#include "snprintf_compat.h"
Packit ea8578
Packit ea8578
#if !defined(HAVE_VASPRINTF)
Packit ea8578
/* CAW: compliant version of vasprintf */
Packit ea8578
static int vasprintf(char **buf, const char *fmt, va_list ap)
Packit ea8578
{
Packit ea8578
#ifndef WIN32
Packit ea8578
	static char _T_emptybuffer = '\0';
Packit ea8578
#endif /* !defined(WIN32) */
Packit ea8578
	int chars;
Packit ea8578
	char *b;
Packit ea8578
Packit ea8578
	if(!buf) { return -1; }
Packit ea8578
Packit ea8578
#ifdef WIN32
Packit ea8578
	chars = _vscprintf(fmt, ap)+1;
Packit ea8578
#else /* !defined(WIN32) */
Packit ea8578
	/* CAW: RAWR! We have to hope to god here that vsnprintf doesn't overwrite
Packit ea8578
	   our buffer like on some 64bit sun systems.... but hey, its time to move on */
Packit ea8578
	chars = vsnprintf(&_T_emptybuffer, 0, fmt, ap)+1;
Packit ea8578
	if(chars < 0) { chars *= -1; } /* CAW: old glibc versions have this problem */
Packit ea8578
#endif /* defined(WIN32) */
Packit ea8578
Packit ea8578
	b = (char*)malloc(sizeof(char)*chars);
Packit ea8578
	if(!b) { return -1; }
Packit ea8578
Packit ea8578
	if((chars = vsprintf(b, fmt, ap)) < 0)
Packit ea8578
	{
Packit ea8578
		free(b);
Packit ea8578
	} else {
Packit ea8578
		*buf = b;
Packit ea8578
	}
Packit ea8578
Packit ea8578
	return chars;
Packit ea8578
}
Packit ea8578
#endif /* !HAVE_VASPRINTF */
Packit ea8578
Packit ea8578
#endif /* __vasprintf_compat_h */