X-Git-Url: https://git.xonotic.org/?p=xonotic%2Fgmqcc.git;a=blobdiff_plain;f=ansi.c;h=1317e150b0c4afa808283901645a319e83920a6b;hp=52399df78ca538a156e99eeb03dc087899e3bc74;hb=ff37abb0c7c60481e1264914fa5e02e9986c5cd9;hpb=e8955f17eaa5600ce533fb6dd0c3f7b39dc160bd diff --git a/ansi.c b/ansi.c index 52399df..1317e15 100644 --- a/ansi.c +++ b/ansi.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2012, 2013 + * Copyright (C) 2012, 2013, 2014, 2015 * Dale Weiler * * Permission is hereby granted, free of charge, to any person obtaining a copy of @@ -20,9 +20,9 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ +#define GMQCC_PLATFORM_HEADER #include #include -#include #include "platform.h" #include "gmqcc.h" @@ -31,15 +31,8 @@ int platform_vsnprintf(char *buffer, size_t bytes, const char *format, va_list a return vsnprintf(buffer, bytes, format, arg); } -int platform_sscanf(const char *str, const char *format, ...) { - int rt; - va_list va; - - va_start(va, format); - rt = vsscanf(str, format, va); - va_end (va); - - return rt; +int platform_vsscanf(const char *str, const char *format, va_list arg) { + return vsscanf(str, format, arg); } const struct tm *platform_localtime(const time_t *timer) { @@ -54,25 +47,10 @@ char *platform_strncat(char *dest, const char *src, size_t num) { return strncat(dest, src, num); } -const char *platform_tmpnam(char *str) { - return tmpnam(str); -} - -const char *platform_getenv(char *var) { +const char *platform_getenv(const char *var) { return getenv(var); } -int platform_snprintf(char *src, size_t bytes, const char *format, ...) { - int rt; - va_list va; - - va_start(va, format); - rt = vsnprintf(src, bytes, format, va); - va_end(va); - - return rt; -} - int platform_vasprintf(char **dat, const char *fmt, va_list args) { int ret; int len; @@ -84,6 +62,9 @@ int platform_vasprintf(char **dat, const char *fmt, va_list args) { len = vsnprintf(buf, sizeof(buf), fmt, cpy); va_end (cpy); + if (len < 0) + return len; + if (len < (int)sizeof(buf)) { *dat = util_strdup(buf); return len; @@ -157,7 +138,16 @@ long platform_ftell(FILE *stream) { } int platform_mkdir(const char *path, int mode) { + /* + * For some reason mingw32 just doesn't have a correct mkdir impl + * so we handle that here. + */ +# ifdef _WIN32 + (void)mode; + return mkdir(path); +# else return mkdir(path, mode); +# endif /*!_WIN32*/ } DIR *platform_opendir(const char *path) {