X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/108245d608bf821c8b0b748195d75b4b83f2376d..4c04b128260c38d0d28a1fc70cd8cf02f06c15c1:/include/simgrid_config.h.in diff --git a/include/simgrid_config.h.in b/include/simgrid_config.h.in index ca6c5502e8..c9952306f8 100644 --- a/include/simgrid_config.h.in +++ b/include/simgrid_config.h.in @@ -1,8 +1,6 @@ -/* $Id$ */ - /* simgrid_config.h - Results of the configure made visible to user code */ -/* Copyright (c) 2009, Da SimGrid team. All rights reserved. */ +/* Copyright (c) 2009, 2010, 2011. Da 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. */ @@ -11,25 +9,80 @@ #ifndef SIMGRID_PUBLIC_CONFIG_H #define SIMGRID_PUBLIC_CONFIG_H +SG_BEGIN_DECL() + + +/** Define the version numbers of the used header files. + sg_version() can be used to retrieve the version of the dynamic library. + But actually, if these numbers don't match, SimGrid refuses to start (so you shouldn't have to care about sg_version() yourself) */ + +#define SIMGRID_VERSION_MAJOR @SIMGRID_VERSION_MAJOR@ +#define SIMGRID_VERSION_MINOR @SIMGRID_VERSION_MINOR@ +#define SIMGRID_VERSION_PATCH @SIMGRID_VERSION_PATCH@ + +/* Version X.Y.Z will get version number XYZ: all digits concatenated without dots + * (with Y and Z must be on two positions)*/ + +#define MAKE_SIMGRID_VERSION(major, minor, patch) \ + (100UL * (100UL * (major) + (minor)) + (patch)) +#define SIMGRID_VERSION MAKE_SIMGRID_VERSION(SIMGRID_VERSION_MAJOR, \ + SIMGRID_VERSION_MINOR, \ + SIMGRID_VERSION_PATCH) + +/** Retrieves the version numbers of the used dynamic library (so, DLL or dynlib) , while + SIMGRID_VERSION_MAJOR and friends give the version numbers of the used header files */ +XBT_PUBLIC(void) sg_version(int *major,int *minor,int *patch); + +/* take care of DLL usage madness */ + +#ifdef _XBT_DLL_EXPORT + #ifndef DLL_EXPORT + #define DLL_EXPORT + #endif +#else + #ifdef _XBT_DLL_STATIC + #ifndef DLL_STATIC + #define DLL_STATIC + #endif + #else + #ifndef DLL_EXPORT + #define DLL_IMPORT + #endif + #endif +#endif + +#cmakedefine _XBT_WIN32 @_XBT_WIN32@ /*this variable is set if it is a windows platform*/ +#cmakedefine _WIN32 @_WIN32@ /*this variable is set if it is a 32 bits windows platform*/ +#cmakedefine _WIN64 @_WIN64@ /*this variable is set if it is a 64 bits windows platform*/ +#cmakedefine __VISUALC__ @__VISUALC__@ +#cmakedefine __BORLANDC__ @__BORLANDC__@ +#ifdef _XBT_WIN32 + #ifndef __GNUC__ + #cmakedefine __GNUC__ @__GNUC__@ + #endif +#endif + + +/* Define to 1 if you have the `mmap' function. */ +#cmakedefine HAVE_MMAP @HAVE_MMAP@ /* Get the config */ #undef SIMGRID_NEED_GETLINE #undef SIMGRID_NEED_ASPRINTF #undef SIMGRID_NEED_VASPRINTF @need_getline@ -@need_asprintf@ -@need_vasprintf@ +@simgrid_need_asprintf@ +@simgrid_need_vasprintf@ + +#include /* FILE, getline if it exists */ /* Use that config to declare missing elements */ #ifdef SIMGRID_NEED_GETLINE #include /* size_t */ -#include /* FILE* */ XBT_PUBLIC(long) getline(char **lineptr, size_t * n, FILE * stream); -#else -#define _GNU_SOURCE -#include #endif +#include /* snprintf related functions */ /** @addtogroup XBT_str @@ -56,9 +109,35 @@ XBT_PUBLIC(int) vasprintf(char **ptr, const char *fmt, va_list ap); #endif /** @brief print to allocated string * - * Works just like asprintf(), but returns a pointer to the newly created string + * Works just like vasprintf(), but returns a pointer to the newly + * created string, or aborts on error. + */ +XBT_PUBLIC(char *) bvprintf(const char *fmt, va_list ap); +/** @brief print to allocated string + * + * Works just like asprintf(), but returns a pointer to the newly + * created string, or aborts on error. */ XBT_PUBLIC(char *) bprintf(const char *fmt, ...) _XBT_GNUC_PRINTF(1, 2); /** @} */ +/* Define if xbt contexts are based on our threads implementation or not */ +#cmakedefine CONTEXT_THREADS @CONTEXT_THREADS@ + +/* Tracing SimGrid */ +#cmakedefine HAVE_TRACING @HAVE_TRACING@ + +/* Jedule output */ +#cmakedefine HAVE_JEDULE @HAVE_JEDULE@ + +/* Tracking of latency bound */ +#cmakedefine HAVE_LATENCY_BOUND_TRACKING @HAVE_LATENCY_BOUND_TRACKING@ + +/* If __thread is available */ +#cmakedefine HAVE_THREAD_LOCAL_STORAGE @HAVE_THREAD_LOCAL_STORAGE@ + +/* If Model-Checking support was requested */ +#cmakedefine HAVE_MC @HAVE_MC@ + +SG_END_DECL() #endif /* SIMGRID_PUBLIC_CONFIG_H */