Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Cleanup of the portability between win and lin at header level
authormquinson <mquinson@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Mon, 24 Sep 2007 14:23:36 +0000 (14:23 +0000)
committermquinson <mquinson@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Mon, 24 Sep 2007 14:23:36 +0000 (14:23 +0000)
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/simgrid/simgrid/trunk@4698 48e7efb5-ca39-0410-a469-dd3cf9ba447f

src/portable.h
src/win32/compiler/visualc.h

index a6a0220..f56b81d 100644 (file)
@@ -11,6 +11,7 @@
 #ifndef GRAS_PORTABLE_H
 #define GRAS_PORTABLE_H
 
 #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).        
 */ 
 /* 
  * win32 or win64 (__WIN32 is defined for win32 and win64 applications, __TOS_WIN__ is defined by xlC).        
 */ 
  ****/
 
 /* prototype of C99 functions */
  ****/
 
 /* prototype of C99 functions */
-#if defined(HAVE_SNPRINTF) && defined(_MSC_VER)
+#if defined(HAVE_SNPRINTF)
 #include <stdio.h>
 #else
 #include <stdio.h>
 #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);
-#  endif
-
+   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)
 extern int portable_snprintf(char *str, size_t str_m, const char *fmt, /*args*/ ...);
 /* 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*/ ...);
@@ -131,7 +124,7 @@ extern int portable_vsnprintf(char *str, size_t str_m, const char *fmt, va_list
 #endif
 
 /* prototype of GNU functions  */
 #endif
 
 /* prototype of GNU functions  */
-#if !defined(__BORLANDC__) && !defined(_MSC_VER)
+#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 asprintf  (char **ptr, const char *fmt, /*args*/ ...);
 extern int vasprintf (char **ptr, const char *fmt, va_list ap);
 #endif
index adb8905..3833296 100644 (file)
 #endif
 
 /* The compiler has `snprintf' function. */
 #endif
 
 /* The compiler has `snprintf' function. */
-#ifndef HAVE_SNPRINTF
+#if _MSC_VER >= 7 /* FIXME: check version number */
+#  ifndef HAVE_SNPRINTF
        #define HAVE_SNPRINTF   1
        #define HAVE_SNPRINTF   1
+#  endif
+#else 
+#  ifdef HAVE_SNPRINTF
+       #undef HAVE_SNPRINTF
+#  endif
 #endif
 
 /* No `swapcontext' function. */
 #endif
 
 /* No `swapcontext' function. */