summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2007-11-16 19:06:40 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2007-11-16 19:06:40 (GMT)
commitbeaea73fa0ffbd5f2fbc839e9c9135f9bc0b3280 (patch)
tree2d5339edfcc8275fb9111fa2de5ba210757bfeb1
parent96bf9b372a391b428fb0ac44d566729fd6294cdf (diff)
downloadCMake-beaea73fa0ffbd5f2fbc839e9c9135f9bc0b3280.zip
CMake-beaea73fa0ffbd5f2fbc839e9c9135f9bc0b3280.tar.gz
CMake-beaea73fa0ffbd5f2fbc839e9c9135f9bc0b3280.tar.bz2
ENH: add a try compile for va_copy
-rw-r--r--Utilities/cmxmlrpc/CMakeLists.txt2
-rw-r--r--Utilities/cmxmlrpc/xmlrpc_config.h.in2
-rw-r--r--Utilities/cmxmlrpc/xmlrpc_data.c10
3 files changed, 11 insertions, 3 deletions
diff --git a/Utilities/cmxmlrpc/CMakeLists.txt b/Utilities/cmxmlrpc/CMakeLists.txt
index a29e0bd..e3f42c8 100644
--- a/Utilities/cmxmlrpc/CMakeLists.txt
+++ b/Utilities/cmxmlrpc/CMakeLists.txt
@@ -44,6 +44,8 @@ INCLUDE (TryCompileFromSource)
SET(HEADER_INCLUDES "${CURRENT_INCLUDES}")
TRY_COMPILE_FROM_SOURCE("va_list list1, list2; list1 = list2"
VA_LIST_ISNOT_ARRAY_DEFINE)
+TRY_COMPILE_FROM_SOURCE("va_list list1, list2; va_copy(list1, list2);"
+ HAS_VA_COPY)
SET(VA_LIST_IS_ARRAY_DEFINE 0)
IF(NOT VA_LIST_ISNOT_ARRAY_DEFINE)
SET(VA_LIST_IS_ARRAY_DEFINE 1)
diff --git a/Utilities/cmxmlrpc/xmlrpc_config.h.in b/Utilities/cmxmlrpc/xmlrpc_config.h.in
index d940e4d..9683c1e 100644
--- a/Utilities/cmxmlrpc/xmlrpc_config.h.in
+++ b/Utilities/cmxmlrpc/xmlrpc_config.h.in
@@ -22,6 +22,8 @@
#define VA_LIST_IS_ARRAY @VA_LIST_IS_ARRAY_DEFINE@
+#cmakedefine HAS_VA_COPY @HAS_VA_COPY@
+
#define HAVE_LIBWWW_SSL @HAVE_LIBWWW_SSL_DEFINE@
#define ATTR_UNUSED @ATTR_UNUSED@
diff --git a/Utilities/cmxmlrpc/xmlrpc_data.c b/Utilities/cmxmlrpc/xmlrpc_data.c
index 0d3c3ca..456d8e4 100644
--- a/Utilities/cmxmlrpc/xmlrpc_data.c
+++ b/Utilities/cmxmlrpc/xmlrpc_data.c
@@ -24,10 +24,14 @@ typedef double va_double;
** tricky fashions. We don't why Python does this, but since we're
** abusing our va_list objects in a similar fashion, we'll copy them
** too. */
-#if VA_LIST_IS_ARRAY
-#define VA_LIST_COPY(dest,src) memcpy((dest), (src), sizeof(va_list))
+#ifdef HAS_VA_COPY
+# define VA_LIST_COPY(dest,src) va_copy((dest), (src))
#else
-#define VA_LIST_COPY(dest,src) ((dest) = (src))
+# if VA_LIST_IS_ARRAY
+# define VA_LIST_COPY(dest,src) memcpy((dest), (src), sizeof(va_list))
+# else
+# define VA_LIST_COPY(dest,src) ((dest) = (src))
+# endif
#endif