X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=Source%2FWinDefs.h;h=32c7945f8068104280683648ec8324f55ef1fba3;hb=599983e84cffd250055557d78b4d8b4af84cb092;hp=478c74435e234ca288b7c88ffe50187aed6f4246;hpb=0cca0c495c7dc29d134a10d7eed5de1f377c99bf;p=lugaru.git diff --git a/Source/WinDefs.h b/Source/WinDefs.h index 478c744..32c7945 100644 --- a/Source/WinDefs.h +++ b/Source/WinDefs.h @@ -1,10 +1,30 @@ +/* +Copyright (C) 2003, 2010 - Wolfire Games +Copyright (C) 2010-2016 - Lugaru contributors (see AUTHORS file) + +This file is part of Lugaru. + +Lugaru is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2 of the License, or +(at your option) any later version. + +Lugaru is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with Lugaru. If not, see . +*/ + #ifndef _WINDEFS_H_ #define _WINDEFS_H_ #ifdef WIN32 #include -#include +#include // stuff to make Mac code compatable with Windows @@ -19,13 +39,9 @@ // disable warning about unreferenced local variables #pragma warning(disable:4101) -typedef bool Boolean; - - -struct Point -{ - short v; - short h; +struct Point { + short v; + short h; }; typedef signed char SInt8; @@ -35,68 +51,44 @@ typedef unsigned int UInt32; #include "Random.h" -void CopyCStringToPascal( const char* src, unsigned char dst[256]); -void CopyPascalStringToC( const unsigned char* src, char* dst); +typedef struct AbsoluteTime { + unsigned long hi; + unsigned long lo; +} AbsoluteTime; +AbsoluteTime UpTime(); // NOTE: returns time since app started, not system start -typedef struct AbsoluteTime -{ - unsigned long hi; - unsigned long lo; -} AbsoluteTime; +typedef long Duration; -AbsoluteTime UpTime(); // NOTE: returns time since app started, not system start - -typedef long Duration; - -enum -{ - durationMicrosecond = -1, - durationMillisecond = 1, - durationSecond = 1000, - durationMinute = 1000 * 60, - durationHour = 1000 * 60 * 60, - durationDay = 1000 * 60 * 60 * 24, - durationForever = 0x7FFFFFFF, - durationImmediate = 0, -}; +enum { + durationMicrosecond = -1, + durationMillisecond = 1, + durationSecond = 1000, + durationMinute = 1000 * 60, + durationHour = 1000 * 60 * 60, + durationDay = 1000 * 60 * 60 * 24, + durationForever = 0x7FFFFFFF, + durationImmediate = 0, +}; Duration AbsoluteDeltaToDuration( AbsoluteTime& a, AbsoluteTime& b); - -inline bool isnormal( double x) +#ifndef __MINGW32__ +inline float abs(float f) { - int ret = _fpclass( x); - return (ret == _FPCLASS_NN || ret == _FPCLASS_PN); + if (f < 0) + return -f; + return f; } -typedef unsigned int uintptr_t; - - -// fix file names to use '/' instead of ':' -char* ConvertFileName( const char* orgfilename); - -#define fopen( a, b) fopen( ConvertFileName( a), b); -/* -inline float abs( float f) +inline double abs(double f) { -if (f < 0) -return -f; -return f; + if (f < 0) + return -f; + return f; } +#endif // __MINGW32__ -inline double abs( double f) -{ -if (f < 0) -return -f; -return f; -} -*/ -inline long long abs( long long f) -{ - if (f < 0) - return -f; - return f; -} + +#endif #endif -#endif \ No newline at end of file