X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5c5685dc7dbf80037da524d5787a8265bf36a552..dfe761f4bc8d35a74c3da5fabe99630c0788001f:/src/portable.h diff --git a/src/portable.h b/src/portable.h index 61a3ea0f43..537d24cff6 100644 --- a/src/portable.h +++ b/src/portable.h @@ -11,6 +11,7 @@ #ifndef GRAS_PORTABLE_H #define GRAS_PORTABLE_H +#include "xbt/misc.h" /* * win32 or win64 (__WIN32 is defined for win32 and win64 applications, __TOS_WIN__ is defined by xlC). */ @@ -21,6 +22,12 @@ # 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 @@ -73,11 +80,6 @@ # define O_BINARY 0 #endif -#ifdef HAVE_GETLINE -# define _GNU_SOURCE -# include -#endif - /**** **** Time handling ****/ @@ -93,19 +95,6 @@ # endif #endif - -/**** - **** Contexts - ****/ - -#ifdef USE_UCONTEXT -# include -#endif - -#ifdef _WIN32 -# include "xbt/context_win32.h" /* Manual reimplementation for prehistoric platforms */ -#endif - /**** **** Signals ****/ @@ -118,21 +107,13 @@ ****/ /* prototype of C99 functions */ -#ifdef HAVE_SNPRINTF +#if defined(HAVE_SNPRINTF) #include #else -# 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); + XBT_PUBLIC(int) snprintf(char *, size_t, const char *, /*args*/ ...); + XBT_PUBLIC(int) vsnprintf(char *, size_t, const char *, va_list); #endif -#endif /* use internal functions when OS provided ones are borken */ #if defined(HAVE_SNPRINTF) && defined(PREFER_PORTABLE_SNPRINTF) @@ -143,8 +124,11 @@ extern int portable_vsnprintf(char *str, size_t str_m, const char *fmt, va_list #endif /* prototype of GNU functions */ +#if defined(__GNUC__) 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); @@ -172,4 +156,11 @@ 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); + +#if defined(WIN32) +/* Visual C++ does not implements the gettimeofday() function */ +XBT_PUBLIC(int) +gettimeofday(struct timeval *tv, struct timezone *tz); +#endif + #endif /* GRAS_PORTABLE_H */