X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=src%2Fcompat_win32.c;h=23edd9170d5403f0a6f6025d1e934881cf7760ce;hb=7b1f2136183f13cfdc83cc387134688ad07325f5;hp=6802730b0e41b1079d73cddd73d34b9dfa04f7a0;hpb=5888fddccf0882e7738df13a918f296522034a77;p=fdkaac.git diff --git a/src/compat_win32.c b/src/compat_win32.c index 6802730..23edd91 100644 --- a/src/compat_win32.c +++ b/src/compat_win32.c @@ -12,6 +12,7 @@ #include #include #include +#include #include #include #include @@ -74,6 +75,17 @@ FILE *aacenc_fopen(const char *name, const char *mode) return fp; } +static char **__aacenc_argv__; + +static +void aacenc_free_mainargs(void) +{ + char **p = __aacenc_argv__; + for (; *p; ++p) + free(*p); + free(__aacenc_argv__); +} + void aacenc_getmainargs(int *argc, char ***argv) { int i; @@ -85,6 +97,8 @@ void aacenc_getmainargs(int *argc, char ***argv) for (i = 0; i < *argc; ++i) codepage_encode_wchar(CP_UTF8, wargv[i], &(*argv)[i]); (*argv)[*argc] = 0; + __aacenc_argv__ = *argv; + atexit(aacenc_free_mainargs); } char *aacenc_to_utf8(const char *s) @@ -92,6 +106,20 @@ char *aacenc_to_utf8(const char *s) return _strdup(s); } +#if defined(__MINGW32__) && !defined(HAVE__VSCPRINTF) +int _vscprintf(const char *fmt, va_list ap) +{ + static int (*fp_vscprintf)(const char *, va_list) = 0; + if (!fp_vscprintf) { + HANDLE h = GetModuleHandleA("msvcrt.dll"); + FARPROC fp = GetProcAddress(h, "_vscprintf"); + InterlockedCompareExchangePointer(&fp_vscprintf, fp, 0); + } + assert(fp_vscprintf); + return fp_vscprintf(fmt, ap); +} +#endif + int aacenc_fprintf(FILE *fp, const char *fmt, ...) { va_list ap;