mirror of
https://github.com/tribes2/engine.git
synced 2026-01-20 19:54:46 +00:00
289 lines
8.5 KiB
C++
289 lines
8.5 KiB
C++
//-----------------------------------------------------------------------------
|
|
// V12 Engine
|
|
//
|
|
// Copyright (c) 2001 GarageGames.Com
|
|
// Portions Copyright (c) 2001 by Sierra Online, Inc.
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#include "PlatformWin32/platformWin32.h"
|
|
|
|
#ifdef HAS_VSSCANF
|
|
# undef HAS_VSSCANF
|
|
#endif
|
|
|
|
#if defined(__MWERKS__) && __MWERKS__ >= 0x2400
|
|
# define HAS_VSSCANF
|
|
# define __vsscanf vsscanf
|
|
#endif
|
|
|
|
#ifdef __BORLANDC__
|
|
# define _stricmp stricmp
|
|
# define _strnicmp strnicmp
|
|
# define _strupr strupr
|
|
# define _strlwr strlwr
|
|
# define __vsscanf vsscanf
|
|
#endif
|
|
|
|
|
|
|
|
char *dStrdup_r(const char *src, const char *fileName, U32 lineNumber)
|
|
{
|
|
char *buffer = (char *) dMalloc_r(dStrlen(src) + 1, fileName, lineNumber);
|
|
dStrcpy(buffer, src);
|
|
return buffer;
|
|
}
|
|
|
|
char* dStrcat(char *dst, const char *src)
|
|
{
|
|
return strcat(dst,src);
|
|
}
|
|
|
|
S32 dStrcmp(const char *str1, const char *str2)
|
|
{
|
|
return strcmp(str1, str2);
|
|
}
|
|
|
|
S32 dStricmp(const char *str1, const char *str2)
|
|
{
|
|
return _stricmp(str1, str2);
|
|
}
|
|
|
|
S32 dStrncmp(const char *str1, const char *str2, U32 len)
|
|
{
|
|
return strncmp(str1, str2, len);
|
|
}
|
|
|
|
S32 dStrnicmp(const char *str1, const char *str2, U32 len)
|
|
{
|
|
return _strnicmp(str1, str2, len);
|
|
}
|
|
|
|
char* dStrcpy(char *dst, const char *src)
|
|
{
|
|
return strcpy(dst,src);
|
|
}
|
|
|
|
char* dStrncpy(char *dst, const char *src, U32 len)
|
|
{
|
|
return strncpy(dst,src,len);
|
|
}
|
|
|
|
U32 dStrlen(const char *str)
|
|
{
|
|
return strlen(str);
|
|
}
|
|
|
|
|
|
char* dStrupr(char *str)
|
|
{
|
|
#ifdef __MWERKS__ // metrowerks strupr is broken
|
|
_strupr(str);
|
|
return str;
|
|
#else
|
|
return _strupr(str);
|
|
#endif
|
|
}
|
|
|
|
|
|
char* dStrlwr(char *str)
|
|
{
|
|
return _strlwr(str);
|
|
}
|
|
|
|
|
|
char* dStrchr(char *str, S32 c)
|
|
{
|
|
return strchr(str,c);
|
|
}
|
|
|
|
|
|
const char* dStrchr(const char *str, S32 c)
|
|
{
|
|
return strchr(str,c);
|
|
}
|
|
|
|
|
|
const char* dStrrchr(const char *str, S32 c)
|
|
{
|
|
return strrchr(str,c);
|
|
}
|
|
|
|
char* dStrrchr(char *str, S32 c)
|
|
{
|
|
return strrchr(str,c);
|
|
}
|
|
|
|
U32 dStrspn(const char *str, const char *set)
|
|
{
|
|
return(strspn(str, set));
|
|
}
|
|
|
|
U32 dStrcspn(const char *str, const char *set)
|
|
{
|
|
return strcspn(str, set);
|
|
}
|
|
|
|
|
|
char* dStrstr(char *str1, char *str2)
|
|
{
|
|
return strstr(str1,str2);
|
|
}
|
|
|
|
|
|
const char* dStrstr(const char *str1, const char *str2)
|
|
{
|
|
return strstr(str1,str2);
|
|
}
|
|
|
|
char* dStrtok(char *str, const char *sep)
|
|
{
|
|
return strtok(str, sep);
|
|
}
|
|
|
|
|
|
S32 dAtoi(const char *str)
|
|
{
|
|
return atoi(str);
|
|
}
|
|
|
|
F32 dAtof(const char *str)
|
|
{
|
|
return atof(str);
|
|
}
|
|
|
|
bool dAtob(const char *str)
|
|
{
|
|
return !dStricmp(str, "true") || dAtof(str);
|
|
}
|
|
|
|
|
|
bool dIsalnum(const char c)
|
|
{
|
|
return isalnum(c);
|
|
}
|
|
|
|
bool dIsalpha(const char c)
|
|
{
|
|
return(isalpha(c));
|
|
}
|
|
|
|
bool dIsspace(const char c)
|
|
{
|
|
return(isspace(c));
|
|
}
|
|
|
|
bool dIsdigit(const char c)
|
|
{
|
|
return(isdigit(c));
|
|
}
|
|
|
|
void dPrintf(const char *format, ...)
|
|
{
|
|
va_list args;
|
|
va_start(args, format);
|
|
vprintf(format, args);
|
|
}
|
|
|
|
S32 dVprintf(const char *format, void *arglist)
|
|
{
|
|
S32 len = vprintf(format, (char*)arglist);
|
|
return (len);
|
|
}
|
|
|
|
S32 dSprintf(char *buffer, U32 bufferSize, const char *format, ...)
|
|
{
|
|
va_list args;
|
|
va_start(args, format);
|
|
|
|
#ifdef __MWERKS__
|
|
S32 len = vsnprintf(buffer, bufferSize, format, args);
|
|
#else
|
|
bufferSize;
|
|
S32 len = vsprintf(buffer, format, args);
|
|
#endif
|
|
return (len);
|
|
}
|
|
|
|
|
|
S32 dVsprintf(char *buffer, U32 bufferSize, const char *format, void *arglist)
|
|
{
|
|
#ifdef __MWERKS__
|
|
S32 len = vsnprintf(buffer, bufferSize, format, (char*)arglist);
|
|
#else
|
|
bufferSize;
|
|
S32 len = vsprintf(buffer, format, (char*)arglist);
|
|
#endif
|
|
// S32 len = vsnprintf(buffer, bufferSize, format, (char*)arglist);
|
|
return (len);
|
|
}
|
|
|
|
|
|
S32 dSscanf(const char *buffer, const char *format, ...)
|
|
{
|
|
va_list args;
|
|
#if defined(HAS_VSSCANF)
|
|
va_start(args, format);
|
|
return __vsscanf(buffer, format, args);
|
|
#else
|
|
va_start(args, format);
|
|
|
|
// Boy is this lame. We have to scan through the format string, and find out how many
|
|
// arguments there are. We'll store them off as void*, and pass them to the sscanf
|
|
// function through specialized calls. We're going to have to put a cap on the number of args that
|
|
// can be passed, 8 for the moment. Sigh.
|
|
static void* sVarArgs[20];
|
|
U32 numArgs = 0;
|
|
|
|
for (const char* search = format; *search != '\0'; search++) {
|
|
if (search[0] == '%' && search[1] != '%')
|
|
numArgs++;
|
|
}
|
|
AssertFatal(numArgs <= 20, "Error, too many arguments to lame implementation of dSscanf. Fix implmentation");
|
|
|
|
// Ok, we have the number of arguments...
|
|
for (U32 i = 0; i < numArgs; i++)
|
|
sVarArgs[i] = va_arg(args, void*);
|
|
va_end(args);
|
|
|
|
switch (numArgs) {
|
|
case 0: return 0;
|
|
case 1: return sscanf(buffer, format, sVarArgs[0]);
|
|
case 2: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1]);
|
|
case 3: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2]);
|
|
case 4: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3]);
|
|
case 5: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4]);
|
|
case 6: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5]);
|
|
case 7: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6]);
|
|
case 8: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7]);
|
|
case 9: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8]);
|
|
case 10: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9]);
|
|
case 11: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10]);
|
|
case 12: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11]);
|
|
case 13: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12]);
|
|
case 14: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12], sVarArgs[13]);
|
|
case 15: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12], sVarArgs[13], sVarArgs[14]);
|
|
case 16: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12], sVarArgs[13], sVarArgs[14], sVarArgs[15]);
|
|
case 17: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12], sVarArgs[13], sVarArgs[14], sVarArgs[15], sVarArgs[16]);
|
|
case 18: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12], sVarArgs[13], sVarArgs[14], sVarArgs[15], sVarArgs[16], sVarArgs[17]);
|
|
case 19: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12], sVarArgs[13], sVarArgs[14], sVarArgs[15], sVarArgs[16], sVarArgs[17], sVarArgs[18]);
|
|
case 20: return sscanf(buffer, format, sVarArgs[0], sVarArgs[1], sVarArgs[2], sVarArgs[3], sVarArgs[4], sVarArgs[5], sVarArgs[6], sVarArgs[7], sVarArgs[8], sVarArgs[9], sVarArgs[10], sVarArgs[11], sVarArgs[12], sVarArgs[13], sVarArgs[14], sVarArgs[15], sVarArgs[16], sVarArgs[17], sVarArgs[18], sVarArgs[19]);
|
|
}
|
|
return 0;
|
|
#endif
|
|
}
|
|
|
|
S32 dFflushStdout()
|
|
{
|
|
return fflush(stdout);
|
|
}
|
|
|
|
S32 dFflushStderr()
|
|
{
|
|
return fflush(stderr);
|
|
}
|
|
|
|
void dQsort(void *base, U32 nelem, U32 width, S32 (QSORT_CALLBACK *fcmp)(const void *, const void *))
|
|
{
|
|
qsort(base, nelem, width, fcmp);
|
|
}
|