X-Git-Url: https://git.xonotic.org/?p=xonotic%2Fgmqcc.git;a=blobdiff_plain;f=ansi.c;h=029508a95ca2e84254412e4a3046a02829910878;hp=adc7907ca1be15bbaaba6bbdfd87f84fb589fd83;hb=68c2baa7c1b9ee1ca7804656d6fb5cf65b435a90;hpb=151606e25558ec8f8f211db5aba4c4fa66948731 diff --git a/ansi.c b/ansi.c index adc7907..029508a 100644 --- a/ansi.c +++ b/ansi.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2012, 2013 + * Copyright (C) 2012, 2013, 2014 * Dale Weiler * * Permission is hereby granted, free of charge, to any person obtaining a copy of @@ -20,24 +20,19 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ +#define GMQCC_PLATFORM_HEADER #include #include +#include "platform.h" #include "gmqcc.h" int platform_vsnprintf(char *buffer, size_t bytes, const char *format, va_list arg) { 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) { @@ -52,23 +47,35 @@ 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; + char *tmp = NULL; + char buf[128]; + va_list cpy; + + va_copy(cpy, args); + len = vsnprintf(buf, sizeof(buf), fmt, cpy); + va_end (cpy); + + if (len < (int)sizeof(buf)) { + *dat = util_strdup(buf); + return len; + } + + tmp = (char*)mem_a(len + 1); + if ((ret = vsnprintf(tmp, len + 1, fmt, args)) != len) { + mem_d(tmp); + *dat = NULL; + return -1; + } + + *dat = tmp; + return len; } char *platform_strcat(char *dest, const char *src) { @@ -82,3 +89,76 @@ char *platform_strncpy(char *dest, const char *src, size_t num) { const char *platform_strerror(int err) { return strerror(err); } + +FILE *platform_fopen(const char *filename, const char *mode) { + return fopen(filename, mode); +} + +size_t platform_fread(void *ptr, size_t size, size_t count, FILE *stream) { + return fread(ptr, size, count, stream); +} + +size_t platform_fwrite(const void *ptr, size_t size, size_t count, FILE *stream) { + return fwrite(ptr, size, count, stream); +} + +int platform_fflush(FILE *stream) { + return fflush(stream); +} + +int platform_vfprintf(FILE *stream, const char *format, va_list arg) { + return vfprintf(stream, format, arg); +} + +int platform_fclose(FILE *stream) { + return fclose(stream); +} + +int platform_ferror(FILE *stream) { + return ferror(stream); +} + +int platform_fgetc(FILE *stream) { + return fgetc(stream); +} + +int platform_fputs(const char *str, FILE *stream) { + return fputs(str, stream); +} + +int platform_fseek(FILE *stream, long offset, int origin) { + return fseek(stream, offset, origin); +} + +long platform_ftell(FILE *stream) { + return ftell(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) { + return opendir(path); +} + +int platform_closedir(DIR *dir) { + return closedir(dir); +} + +struct dirent *platform_readdir(DIR *dir) { + return readdir(dir); +} + +int platform_isatty(int fd) { + return isatty(fd); +}