X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=simgear%2Fcompiler.h;h=adcc51f429659e3af1e6f935eb2e55f4359bf7f6;hb=3b6af2f0c2dfc6ee2dee057da426ed9465dc89fa;hp=41b43c48b21d0d38547ea3d215dbadd9a2de0c55;hpb=d5f38a558e3afafc9b79784cf2c22b9de5857ad6;p=simgear.git diff --git a/simgear/compiler.h b/simgear/compiler.h index 41b43c48..adcc51f4 100644 --- a/simgear/compiler.h +++ b/simgear/compiler.h @@ -121,7 +121,7 @@ # define STL_STRSTREAM # endif -# elif __GNUC__ == 3 +# elif __GNUC__ >= 3 // g++-3.0.x # define SG_EXPLICIT_FUNCTION_TMPL_ARGS # define SG_NEED_AUTO_PTR @@ -141,7 +141,6 @@ # define STL_STDEXCEPT # define STL_STRING # define STL_STRSTREAM - # else # error Time to upgrade. GNU compilers < 2.7 not supported # endif @@ -150,11 +149,6 @@ #endif // __GNUC__ -#if defined( __MINGW32__ ) -# define bcopy(from, to, n) memcpy(to, from, n) -# define FG_MEM_COPY(to,from,n) memcpy(to, from, n) -#endif - /* KAI C++ */ #if defined(__KCC) @@ -219,7 +213,7 @@ # define bcopy(from, to, n) memcpy(to, from, n) # define FG_MEM_COPY(to,from,n) memcpy(to, from, n) -# if _MSC_VER == 1200 // msvc++ 6.0 +# if _MSC_VER >= 1200 // msvc++ 6.0 or greater # define SG_NAMESPACES # define SG_HAVE_STD # define SG_HAVE_STD_INCLUDES @@ -235,18 +229,8 @@ # define STL_STRING # define STL_STRSTREAM -# define SG_NO_INCLASS_MEMBER_INITIALIZATION - -// disable min/max macros if defined: -// # ifdef min -// # undef min -// # endif -// # ifdef max -// # undef max -// # endif -// # ifndef NOMINMAX -// # define NOMINMAX -// # endif +# define isnan _isnan +# define snprintf _snprintf # pragma warning(disable: 4786) // identifier was truncated to '255' characters # pragma warning(disable: 4244) // conversion from double to float @@ -302,37 +286,40 @@ # define SG_HAVE_NATIVE_SGI_COMPILERS # define SG_EXPLICIT_FUNCTION_TMPL_ARGS +# define SG_CLASS_PARTIAL_SPECIALIZATION # define SG_NEED_AUTO_PTR # define SG_MEMBER_TEMPLATES # define SG_NAMESPACES # define SG_HAVE_STD -# define SG_CLASS_PARTIAL_SPECIALIZATION +# define SG_HAVE_STREAMBUF # define SG_HAVE_TRAITS +# define SG_HAVE_STD_INCLUDES # define STL_ALGORITHM # define STL_FUNCTIONAL -# define STL_IOMANIP -# define STL_IOSTREAM -# define STL_ITERATOR -# define STL_FSTREAM +# define STL_IOMANIP +# define STL_IOSTREAM +# define STL_ITERATOR +# define STL_FSTREAM # define STL_STDEXCEPT +#if (_COMPILER_VERSION < 740) +# define STL_STRING +#else # define STL_STRING -# define STL_STRSTREAM - -// # define __STL_FUNCTION_TMPL_PARTIAL_ORDER -// typedef void PFNGLPOINTPARAMETERFEXTPROC - -#define glPointParameterfEXT glPointParameterfSGIS -#define glPointParameterfvEXT glPointParameterfvSGIS +#endif +# define STL_STRSTREAM #pragma set woff 1001,1012,1014,1116,1155,1172,1174 #pragma set woff 1401,1460,1551,1552,1681 #ifdef __cplusplus #pragma set woff 1682,3303 +#if (_COMPILER_VERSION >= 740) +# pragma set woff 3624 +#endif #endif -# define SG_COMPILER_STR "SGI Irix compiler version " SG_STRINGIZE(_COMPILER_VERSION) +# define SG_COMPILER_STR "SGI MipsPro compiler version " SG_STRINGIZE(_COMPILER_VERSION) #endif // Native SGI compilers @@ -349,14 +336,16 @@ extern void *memmove(void *, const void *, size_t); # endif // __cplusplus -# define SG_COMPILER_STR "Sun compiler version " SG_STRINGIZE(__SUNPRO_CC) +# if !defined( __GNUC__ ) +# define SG_COMPILER_STR "Sun compiler version " SG_STRINGIZE(__SUNPRO_CC) +# endif #endif // sun // // Intel C++ Compiler // -#if defined(__ICC) +#if defined(__ICC) || defined (__ECC) # define SG_NAMESPACES # define SG_HAVE_STD # define SG_HAVE_STREAMBUF @@ -377,6 +366,23 @@ #endif // __ICC +// +// Platform dependent gl.h and glut.h definitions +// + +#ifdef __APPLE__ +# define SG_GL_H +# define SG_GLU_H +# define SG_GLEXT_H +# define SG_GLUT_H +#else +# define SG_GL_H +# define SG_GLU_H +# define SG_GLEXT_H +# define SG_GLUT_H +#endif + + // // No user modifiable definitions beyond here. // @@ -457,17 +463,4 @@ inline const_mem_fun_ref_t<_Ret,_Tp> mem_fun_ref(_Ret (_Tp::*__f)() const) #endif // SG_INCOMPLETE_FUNCTIONAL -/** - * SG_STATIC_CONSTANT workaround. - * On compilers which don't allow in-class initialization of static integral - * constant members, we must use enums as a workaround if we want the constants - * to be available at compile-time. This macro gives us a convenient way to - * declare such constants. - */ -#ifdef SG_NO_INCLASS_MEMBER_INITIALIZATION -# define SG_STATIC_CONST(type,assignment) enum { assignment } -#else -# define SG_STATIC_CONST(type,assignment) static const type assignment -#endif - #endif // _SG_COMPILER_H