X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/db93cd1c0fc7fed756efeb7ffad21d553f41be97..2de2be634908582c082f28ee99ebb337c57aa86e:/src/portable.h diff --git a/src/portable.h b/src/portable.h index 99de0b81ec..c890d8c7e6 100644 --- a/src/portable.h +++ b/src/portable.h @@ -1,34 +1,27 @@ -/* $Id$ */ - /* portable -- header loading to write portable code */ /* loads much more stuff than sysdep.h since the latter is in public interface*/ -/* Copyright (c) 2004 Martin Quinson. All rights reserved. */ +/* Copyright (c) 2004, 2005, 2006, 2007, 2008, 2009, 2010. The SimGrid Team. + * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ -#ifndef GRAS_PORTABLE_H -#define GRAS_PORTABLE_H +#ifndef SIMGRID_PORTABLE_H +#define SIMGRID_PORTABLE_H +#include "internal_config.h" #include "xbt/misc.h" /* - * win32 or win64 (__WIN32 is defined for win32 and win64 applications, __TOS_WIN__ is defined by xlC). -*/ -#ifdef _WIN32 + * win32 or win64 (__XBT_WIN32 is defined for win32 and win64 applications, __TOS_WIN__ is defined by xlC). +*/ +#ifdef _XBT_WIN32 # include "win32/config.h" # 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 +#include #ifdef HAVE_ERRNO_H # include @@ -38,6 +31,13 @@ # include #endif +#ifdef HAVE_SYS_PARAM_H +# include +#endif +#ifdef HAVE_SYS_SYSCTL_H +# include +#endif + /**** **** Networking ****/ @@ -45,11 +45,11 @@ #ifdef HAVE_SYS_SOCKET_H # include -# include /* sometimes required for #include */ -# include /* TCP_NODELAY */ -# include /* getprotobyname() */ -# include /* inet_ntoa() */ -# include /* sometimes required for fd_set */ +# include /* sometimes required for #include */ +# include /* TCP_NODELAY */ +# include /* getprotobyname() */ +# include /* inet_ntoa() */ +# include /* sometimes required for fd_set */ # endif @@ -64,7 +64,7 @@ # else # define tcp_close( s ) close( s ) # endif -#endif /* windows or unix ? */ +#endif /* windows or unix ? */ /**** **** File handling @@ -110,27 +110,31 @@ #if defined(HAVE_SNPRINTF) #include #else - XBT_PUBLIC(int) snprintf(char *, size_t, const char *, /*args*/ ...); - XBT_PUBLIC(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 /* use internal functions when OS provided ones are borken */ #if defined(HAVE_SNPRINTF) && defined(PREFER_PORTABLE_SNPRINTF) -extern int portable_snprintf(char *str, size_t str_m, const char *fmt, /*args*/ ...); -extern int portable_vsnprintf(char *str, size_t str_m, const char *fmt, va_list ap); +extern int portable_snprintf(char *str, size_t str_m, const char *fmt, + /*args */ ...); +extern int portable_vsnprintf(char *str, size_t str_m, const char *fmt, + va_list ap); #define snprintf portable_snprintf #define vsnprintf portable_vsnprintf #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); +#if (defined(__GNUC__) && !defined(__cplusplus)) +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); +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); /* * That's needed to protect solaris's printf from ever seing NULL associated to a %s format @@ -153,23 +157,7 @@ extern int vasnprintf(char **ptr, size_t str_m, const char *fmt, va_list ap); /**** **** Some debugging functions. Can't we find a better place for this?? ****/ -void hexa_print(const char*name, unsigned char *data, int size); +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 - -#define HAVE_SEM_TIMEDWAIT 1 - -/* mac osx doesn't have the sem_timedwait() function */ -#if defined(__GNUC__) && ( defined(__APPLE_CPP__) || defined(__APPLE_CC__) || defined(__MACOS_CLASSIC__) ) -# -# undef HAVE_SEM_TIMEDWAIT -# -#endif - -#endif /* GRAS_PORTABLE_H */ +#endif /* SIMGRID_PORTABLE_H */