Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Make xbt_test_{add,fail,assert,log} variadic macros.
authoragiersch <agiersch@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Tue, 22 Feb 2011 13:51:25 +0000 (13:51 +0000)
committeragiersch <agiersch@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Tue, 22 Feb 2011 13:51:25 +0000 (13:51 +0000)
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/simgrid/simgrid/trunk@9690 48e7efb5-ca39-0410-a469-dd3cf9ba447f

ChangeLog
include/xbt/cunit.h

index 8faa210..849ca40 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -54,8 +54,11 @@ SimGrid (3.6) unstable; urgency=low
    NULL-terminated array. This may solve backward compatibility issues
    due to the change to return type of SD_Simulate. See also:
    http://lists.gforge.inria.fr/pipermail/simgrid-user/2010-December/002206.html
    NULL-terminated array. This may solve backward compatibility issues
    due to the change to return type of SD_Simulate. See also:
    http://lists.gforge.inria.fr/pipermail/simgrid-user/2010-December/002206.html
- * Add new logging macros, with variable number of arguments. Define
-   XBT_USE_DEPRECATED if you want to use the old macros INFO1, INFO2, etc.
+ * Add new macros with variable number of arguments.
+   - in xbt/log.h: XBT_DEBUG, XBT_VERB, XBT_INFO, etc.
+   - in xbt/cunit.h: xbt_test_{add,fail,assert,log}
+   Define XBT_USE_DEPRECATED if you want to use the old numbered macros like
+   INFO1, INFO2, etc.
  * Change xbt_die() to accept a format string with arguments, just like printf.
 
  INSTR
  * Change xbt_die() to accept a format string with arguments, just like printf.
 
  INSTR
index 97106f2..6cedde1 100644 (file)
@@ -60,39 +60,24 @@ XBT_PUBLIC(void) xbt_test_exit(void);
 /* test operations */
 XBT_PUBLIC(void) _xbt_test_add(const char *file, int line, const char *fmt,
                                ...) _XBT_GNUC_PRINTF(3, 4);
 /* test operations */
 XBT_PUBLIC(void) _xbt_test_add(const char *file, int line, const char *fmt,
                                ...) _XBT_GNUC_PRINTF(3, 4);
-#define xbt_test_add0(fmt)           _xbt_test_add(__FILE__,__LINE__,fmt)
-#define xbt_test_add1(fmt,a)         _xbt_test_add(__FILE__,__LINE__,fmt,a)
-#define xbt_test_add2(fmt,a,b)       _xbt_test_add(__FILE__,__LINE__,fmt,a,b)
-#define xbt_test_add3(fmt,a,b,c)     _xbt_test_add(__FILE__,__LINE__,fmt,a,b,c)
-#define xbt_test_add4(fmt,a,b,c,d)   _xbt_test_add(__FILE__,__LINE__,fmt,a,b,c,d)
-#define xbt_test_add5(fmt,a,b,c,d,e) _xbt_test_add(__FILE__,__LINE__,fmt,a,b,c,d,e)
-
 XBT_PUBLIC(void) _xbt_test_fail(const char *file, int line,
                                 const char *fmt, ...) _XBT_GNUC_PRINTF(3,
                                                                        4);
 XBT_PUBLIC(void) _xbt_test_fail(const char *file, int line,
                                 const char *fmt, ...) _XBT_GNUC_PRINTF(3,
                                                                        4);
-#define xbt_test_fail0(fmt)           _xbt_test_fail(__FILE__, __LINE__, fmt)
-#define xbt_test_fail1(fmt,a)         _xbt_test_fail(__FILE__, __LINE__, fmt,a)
-#define xbt_test_fail2(fmt,a,b)       _xbt_test_fail(__FILE__, __LINE__, fmt,a,b)
-#define xbt_test_fail3(fmt,a,b,c)     _xbt_test_fail(__FILE__, __LINE__, fmt,a,b,c)
-#define xbt_test_fail4(fmt,a,b,c,d)   _xbt_test_fail(__FILE__, __LINE__, fmt,a,b,c,d)
-#define xbt_test_fail5(fmt,a,b,c,d,e) _xbt_test_fail(__FILE__, __LINE__, fmt,a,b,c,d,e)
-
-#define xbt_test_assert0(cond,fmt)           if(!(cond)) xbt_test_fail0(fmt)
-#define xbt_test_assert1(cond,fmt,a)         if(!(cond)) xbt_test_fail1(fmt,a)
-#define xbt_test_assert2(cond,fmt,a,b)       if(!(cond)) xbt_test_fail2(fmt,a,b)
-#define xbt_test_assert3(cond,fmt,a,b,c)     if(!(cond)) xbt_test_fail3(fmt,a,b,c)
-#define xbt_test_assert4(cond,fmt,a,b,c,d)   if(!(cond)) xbt_test_fail4(fmt,a,b,c,d)
-#define xbt_test_assert5(cond,fmt,a,b,c,d,e) if(!(cond)) xbt_test_fail5(fmt,a,b,c,d,e)
-#define xbt_test_assert(cond)                xbt_test_assert0(cond,#cond)
-
 XBT_PUBLIC(void) _xbt_test_log(const char *file, int line, const char *fmt,
                                ...) _XBT_GNUC_PRINTF(3, 4);
 XBT_PUBLIC(void) _xbt_test_log(const char *file, int line, const char *fmt,
                                ...) _XBT_GNUC_PRINTF(3, 4);
-#define xbt_test_log0(fmt)           _xbt_test_log(__FILE__, __LINE__, fmt)
-#define xbt_test_log1(fmt,a)         _xbt_test_log(__FILE__, __LINE__, fmt,a)
-#define xbt_test_log2(fmt,a,b)       _xbt_test_log(__FILE__, __LINE__, fmt,a,b)
-#define xbt_test_log3(fmt,a,b,c)     _xbt_test_log(__FILE__, __LINE__, fmt,a,b,c)
-#define xbt_test_log4(fmt,a,b,c,d)   _xbt_test_log(__FILE__, __LINE__, fmt,a,b,c,d)
-#define xbt_test_log5(fmt,a,b,c,d,e) _xbt_test_log(__FILE__, __LINE__, fmt,a,b,c,d,e)
+
+#define xbt_test_add(...)       _xbt_test_add(__FILE__, __LINE__, __VA_ARGS__)
+#define xbt_test_fail(...)      _xbt_test_fail(__FILE__, __LINE__, __VA_ARGS__)
+#define xbt_test_assert(...)    _XBT_IF_ONE_ARG(_xbt_test_assert_ARG1,  \
+                                                _xbt_test_assert_ARGN,  \
+                                                __VA_ARGS__)(__VA_ARGS__)
+#define _xbt_test_assert_ARG1(cond)      _xbt_test_assert_CHECK(cond,   \
+                                                                "%s", #cond)
+#define _xbt_test_assert_ARGN(cond, ...) _xbt_test_assert_CHECK(cond,   \
+                                                                __VA_ARGS__)
+#define _xbt_test_assert_CHECK(cond, ...)                       \
+  do { if (!(cond)) xbt_test_fail(__VA_ARGS__); } while (0)
+#define xbt_test_log(...)       _xbt_test_log(__FILE__, __LINE__, __VA_ARGS__)
 
 XBT_PUBLIC(void) xbt_test_exception(xbt_ex_t e);
 
 
 XBT_PUBLIC(void) xbt_test_exception(xbt_ex_t e);
 
@@ -104,5 +89,39 @@ XBT_PUBLIC(void) xbt_test_skip(void);
     void func(void);  /*prototype*/       \
     void func(void)
 
     void func(void);  /*prototype*/       \
     void func(void)
 
+#if 1 || defined(XBT_USE_DEPRECATED)
+
+/* Kept for backward compatibility. */
+
+#define xbt_test_add0(...)      xbt_test_add(__VA_ARGS__)
+#define xbt_test_add1(...)      xbt_test_add(__VA_ARGS__)
+#define xbt_test_add2(...)      xbt_test_add(__VA_ARGS__)
+#define xbt_test_add3(...)      xbt_test_add(__VA_ARGS__)
+#define xbt_test_add4(...)      xbt_test_add(__VA_ARGS__)
+#define xbt_test_add5(...)      xbt_test_add(__VA_ARGS__)
+
+#define xbt_test_fail0(...)     xbt_test_fail(__VA_ARGS__)
+#define xbt_test_fail1(...)     xbt_test_fail(__VA_ARGS__)
+#define xbt_test_fail2(...)     xbt_test_fail(__VA_ARGS__)
+#define xbt_test_fail3(...)     xbt_test_fail(__VA_ARGS__)
+#define xbt_test_fail4(...)     xbt_test_fail(__VA_ARGS__)
+#define xbt_test_fail5(...)     xbt_test_fail(__VA_ARGS__)
+
+#define xbt_test_assert0(...)   xbt_test_assert(__VA_ARGS__)
+#define xbt_test_assert1(...)   xbt_test_assert(__VA_ARGS__)
+#define xbt_test_assert2(...)   xbt_test_assert(__VA_ARGS__)
+#define xbt_test_assert3(...)   xbt_test_assert(__VA_ARGS__)
+#define xbt_test_assert4(...)   xbt_test_assert(__VA_ARGS__)
+#define xbt_test_assert5(...)   xbt_test_assert(__VA_ARGS__)
+
+#define xbt_test_log0(...)      xbt_test_log(__VA_ARGS__)
+#define xbt_test_log1(...)      xbt_test_log(__VA_ARGS__)
+#define xbt_test_log2(...)      xbt_test_log(__VA_ARGS__)
+#define xbt_test_log3(...)      xbt_test_log(__VA_ARGS__)
+#define xbt_test_log4(...)      xbt_test_log(__VA_ARGS__)
+#define xbt_test_log5(...)      xbt_test_log(__VA_ARGS__)
+
+#endif
+
 SG_END_DECL()
 #endif                          /* _TS_H_ */
 SG_END_DECL()
 #endif                          /* _TS_H_ */