X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5bedf2dbd161f416298d57e63707cc450d63964b..4de0a434d872a362ac4540728c15bfd966e81b86:/src/portable.h diff --git a/src/portable.h b/src/portable.h index bde3a5e7a8..5e755819d1 100644 --- a/src/portable.h +++ b/src/portable.h @@ -14,13 +14,19 @@ /* * win32 or win64 (__WIN32 is defined for win32 and win64 applications, __TOS_WIN__ is defined by xlC). */ -#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32) || defined(__TOS_WIN__) +#ifdef _WIN32 # include "win32/config.h" -# include +# include #else # include "gras_config.h" #endif +/* Load this asap to make sure that GNU_SOURCE is defined on need when stdio gets loaded by some random system header */ +#ifdef HAVE_GETLINE +# define _GNU_SOURCE +# include +#endif + #include #ifdef HAVE_ERRNO_H @@ -88,22 +94,6 @@ # endif #endif -#ifdef _WIN32 -#define sleep _sleep /* else defined in stdlib.h */ -#endif - -/**** - **** Contexts - ****/ - -#ifdef USE_UCONTEXT -# include -#endif - -#ifdef _WIN32 -# include "xbt/context_win32.h" /* Manual reimplementation for prehistoric platforms */ -#endif - /**** **** Signals ****/ @@ -119,8 +109,17 @@ #ifdef HAVE_SNPRINTF #include #else -extern int snprintf(char *, size_t, const char *, /*args*/ ...); -extern int vsnprintf(char *, size_t, const char *, va_list); +# if (defined(_MSC_VER) && defined(DLL_EXPORT)) + __declspec(dllexport) int snprintf(char *, size_t, const char *, /*args*/ ...); + __declspec(dllexport) int vsnprintf(char *, size_t, const char *, va_list); +# elif (defined(_MSC_VER) && !defined(DLL_EXPORT) && !defined(DLL_STATIC) ) + __declspec(dllimport) int snprintf(char *, size_t, const char *, /*args*/ ...); + __declspec(dllimport) int vsnprintf(char *, size_t, const char *, va_list); +# else + extern int snprintf(char *, size_t, const char *, /*args*/ ...); + extern int vsnprintf(char *, size_t, const char *, va_list); +# endif + #endif /* use internal functions when OS provided ones are borken */ @@ -132,8 +131,10 @@ extern int portable_vsnprintf(char *str, size_t str_m, const char *fmt, va_list #endif /* prototype of GNU functions */ +#ifndef __BORLANDC__ extern int asprintf (char **ptr, const char *fmt, /*args*/ ...); extern int vasprintf (char **ptr, const char *fmt, va_list ap); +#endif extern int asnprintf (char **ptr, size_t str_m, const char *fmt, /*args*/ ...); extern int vasnprintf(char **ptr, size_t str_m, const char *fmt, va_list ap); @@ -161,31 +162,4 @@ extern int vasnprintf(char **ptr, size_t str_m, const char *fmt, va_list ap); void hexa_print(const char*name, unsigned char *data, int size); const char *hexa_str(unsigned char *data, int size, int downside); -/* Windows __declspec(). */ -#if defined (_XBT_USE_DECLSPEC) /* using export/import technique */ - -# ifndef _XBT_EXPORT_DECLSPEC -# define _XBT_EXPORT_DECLSPEC -# endif - -# ifndef _XBT_IMPORT_DECLSPEC -# define _XBT_IMPORT_DECLSPEC -# endif - -# if defined (_XBT_DESIGNATED_DLL) /* this is a lib which will contain xbt exports */ -# define _XBT_DECLSPEC _XBT_EXPORT_DECLSPEC -# else -# define _XBT_DECLSPEC _XBT_IMPORT_DECLSPEC /* other modules, importing xbt exports */ -# endif - -#else /* not using DLL export/import specifications */ - -# define _XBT_DECLSPEC - -#endif /* #if defined (_XBT_USE_DECLSPEC) */ - -#if !defined (_XBT_CALL) -#define _XBT_CALL -#endif - #endif /* GRAS_PORTABLE_H */