diff options
| author | 2011-09-14 01:39:02 +0200 | |
|---|---|---|
| committer | 2012-03-19 01:43:00 +0100 | |
| commit | 0df63036c888220ea2d5c122f3c19861b0959167 (patch) | |
| tree | 05febc2ead4e0b426eda479823b2ae1e254c96f4 /src | |
| parent | a87e507134f674f06b3150b1e588a3707c6f4277 (diff) | |
| download | libimobiledevice-0df63036c888220ea2d5c122f3c19861b0959167.tar.gz libimobiledevice-0df63036c888220ea2d5c122f3c19861b0959167.tar.bz2 | |
Refined asprintf/vasprintf detection and inclusion
Diffstat (limited to 'src')
| -rw-r--r-- | src/asprintf.h | 20 | ||||
| -rw-r--r-- | src/debug.c | 2 | ||||
| -rw-r--r-- | src/lockdown.c | 2 | 
3 files changed, 15 insertions, 9 deletions
| diff --git a/src/asprintf.h b/src/asprintf.h index 6f1250d..3b0072e 100644 --- a/src/asprintf.h +++ b/src/asprintf.h @@ -1,15 +1,24 @@  #ifndef ASPRINTF_H  #define ASPRINTF_H -#ifndef vasprintf + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#ifndef HAVE_VASPRINTF  static inline int vasprintf(char **PTR, const char *TEMPLATE, va_list AP)  {  	int res; -	*PTR = (char*)malloc(512); -	res = vsnprintf(*PTR, 512, TEMPLATE, AP); +	res = vsnprintf(NULL, 32768, TEMPLATE, AP); +	if (res > 0) { +		*PTR = (char*)malloc(res+1); +		res = vsnprintf(*PTR, res, TEMPLATE, AP); +	}  	return res;  }  #endif -#ifndef asprintf + +#ifndef HAVE_ASPRINTF  static inline int asprintf(char **PTR, const char *TEMPLATE, ...)  {  	int res; @@ -20,4 +29,5 @@ static inline int asprintf(char **PTR, const char *TEMPLATE, ...)  	return res;  }  #endif -#endif + +#endif /* ASPRINTF_H */ diff --git a/src/debug.c b/src/debug.c index 49ec7c7..b1c528d 100644 --- a/src/debug.c +++ b/src/debug.c @@ -35,10 +35,8 @@  #include "libimobiledevice/libimobiledevice.h"  #ifndef STRIP_DEBUG_CODE -#ifndef HAVE_ASPRINTF  #include "asprintf.h"  #endif -#endif  int debug_level = 0; diff --git a/src/lockdown.c b/src/lockdown.c index e3d557c..0f1e1b2 100644 --- a/src/lockdown.c +++ b/src/lockdown.c @@ -35,9 +35,7 @@  #include "idevice.h"  #include "debug.h"  #include "userpref.h" -#ifndef HAVE_ASPRINTF  #include "asprintf.h" -#endif  #define RESULT_SUCCESS 0  #define RESULT_FAILURE 1 | 
