Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
new dll export an dll import mechanism for Windows.
authorcherierm <cherierm@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Wed, 7 Feb 2007 14:36:46 +0000 (14:36 +0000)
committercherierm <cherierm@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Wed, 7 Feb 2007 14:36:46 +0000 (14:36 +0000)
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/simgrid/simgrid/trunk@3091 48e7efb5-ca39-0410-a469-dd3cf9ba447f

include/xbt/misc.h

index 7e339d6..f2db436 100644 (file)
 #    define XBT_INLINE  inline
 #endif
 
+/* 
+ * Function calling convention (not used for now) 
+ */
+#if !defined (_XBT_CALL)
+#define _XBT_CALL
+#endif
+
 /* Handle import/export stuff
  * Rational: 
- *   * If you compile the DLL you must pass the right value of XBT_PUBLIC in the project: -DXBT_PUBLIC=__dllspec(ddlexport)
- *   * If you do a static compilation, you must define this macro to empty: -DXBT_PUBLIC=
+ *   * If you build the DLL you must pass the right value of XBT_PUBLIC in the project : to do this you must define the DLL_EXPORT macro
+ *   * If you do a static compilation, you must define the macro DLL_STATIC
  *   * If you link your code against the DLL, this file defines the macro to '__declspec(dllimport)' for you
  *   * If you compile under unix, this file defines the macro to 'extern', even if it's not mandatory with modern compilers
  */
-#ifndef XBT_PUBLIC
-#  ifdef _WIN32
-#   define XBT_PUBLIC __declspec(dllimport)
-#  else 
-#   define XBT_PUBLIC extern
-#  endif /* _WIN32 */
-#endif /* !XBT_PUBLIC */
-
-/* Function calling convention (not used for now) */
-#if !defined (_XBT_CALL)
-#define _XBT_CALL
-#endif
+
+#ifdef DLL_EXPORT
+#  define XBT_PUBLIC(type)                     __declspec(dllexport) type
+#else
+#  ifdef DLL_STATIC
+#    define XBT_PUBLIC(type)           type
+#  else
+#    ifdef _WIN32
+#      define XBT_PUBLIC(type)         __declspec(dllimport) type 
+#       else
+#      define XBT_PUBLIC(type)         extern type
+#    endif
+#endif    
 
 
 
 
 SG_BEGIN_DECL()
 
-XBT_PUBLIC const char *xbt_procname(void);
+XBT_PUBLIC(const char *)xbt_procname(void);
 
 #define XBT_BACKTRACE_SIZE 10 /* FIXME: better place? Do document */