summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Utilities/cmxmlrpc/CMakeLists.txt13
-rw-r--r--Utilities/cmxmlrpc/synch_client.c62
-rw-r--r--Utilities/cmxmlrpc/xmlrpc.h1
-rw-r--r--Utilities/cmxmlrpc/xmlrpc_client.c2
-rw-r--r--Utilities/cmxmlrpc/xmlrpc_config.h.in5
5 files changed, 81 insertions, 2 deletions
diff --git a/Utilities/cmxmlrpc/CMakeLists.txt b/Utilities/cmxmlrpc/CMakeLists.txt
index 7a7f823..07f4a42 100644
--- a/Utilities/cmxmlrpc/CMakeLists.txt
+++ b/Utilities/cmxmlrpc/CMakeLists.txt
@@ -31,7 +31,11 @@ CHECK_TYPE_SIZE(size_t SIZEOF_SIZE_T)
INCLUDE (TryCompileFromSource)
SET(HEADER_INCLUDES "${CURRENT_INCLUDES}")
TRY_COMPILE_FROM_SOURCE("va_list list1, list2; list1 = list2"
- VA_LIST_IS_ARRAY_DEFINE)
+ VA_LIST_ISNOT_ARRAY_DEFINE)
+SET(VA_LIST_IS_ARRAY_DEFINE 0)
+IF(NOT VA_LIST_ISNOT_ARRAY_DEFINE)
+ SET(VA_LIST_IS_ARRAY_DEFINE 1)
+ENDIF(NOT VA_LIST_ISNOT_ARRAY_DEFINE)
TRY_COMPILE_FROM_SOURCE("int x __attribute__((__unused__))"
ATTR_UNUSED_VAR)
SET(ATTR_UNUSED)
@@ -42,6 +46,8 @@ ENDIF(ATTR_UNUSED_VAR)
SET(HAVE_LIBWWW_SSL)
SET(DIRECTORY_SEPARATOR "/")
+FIND_PACKAGE(Threads)
+
INCLUDE_DIRECTORIES(
"${CMAKE_CURRENT_SOURCE_DIR}"
"${CMAKE_CURRENT_BINARY_DIR}"
@@ -84,4 +90,7 @@ IF(WIN32)
ENDIF(WIN32)
ADD_LIBRARY(cmXMLRPC ${xmlrpc_SRCS})
-TARGET_LINK_LIBRARIES(cmXMLRPC ${CMAKE_EXPAT_LIBRARIES} ${CMAKE_CURL_LIBRARIES})
+TARGET_LINK_LIBRARIES(cmXMLRPC ${CMAKE_EXPAT_LIBRARIES} ${CMAKE_CURL_LIBRARIES} ${CMAKE_THREAD_LIBS_INIT})
+
+ADD_EXECUTABLE(xrtest synch_client.c)
+TARGET_LINK_LIBRARIES(xrtest cmXMLRPC)
diff --git a/Utilities/cmxmlrpc/synch_client.c b/Utilities/cmxmlrpc/synch_client.c
new file mode 100644
index 0000000..15a608f
--- /dev/null
+++ b/Utilities/cmxmlrpc/synch_client.c
@@ -0,0 +1,62 @@
+/* A simple synchronous XML-RPC client written in C. */
+
+#include <stdio.h>
+
+#include <xmlrpc.h>
+#include <xmlrpc_client.h>
+
+#define NAME "XML-RPC C Test Client"
+#define VERSION "0.1"
+
+static void die_if_fault_occurred (xmlrpc_env *env)
+{
+ if (env->fault_occurred) {
+ fprintf(stderr, "XML-RPC Fault: %s (%d)\n",
+ env->fault_string, env->fault_code);
+ exit(1);
+ }
+}
+
+
+
+int
+main(int const argc,
+ const char ** const argv ATTR_UNUSED) {
+
+ xmlrpc_env env;
+ xmlrpc_value *result;
+ char *state_name;
+
+ if (argc-1 > 0) {
+ fprintf(stderr, "No arguments");
+ exit(0);
+ }
+
+ /* Start up our XML-RPC client library. */
+ xmlrpc_client_init(XMLRPC_CLIENT_NO_FLAGS, NAME, VERSION);
+
+ /* Initialize our error-handling environment. */
+ xmlrpc_env_init(&env);
+
+ /* Call the famous server at UserLand. */
+ result = xmlrpc_client_call(&env, "http://betty.userland.com/RPC2",
+ "examples.getStateName",
+ "(i)", (xmlrpc_int32) 41);
+ die_if_fault_occurred(&env);
+
+ /* Get our state name and print it out. */
+ xmlrpc_parse_value(&env, result, "s", &state_name);
+ die_if_fault_occurred(&env);
+ printf("%s\n", state_name);
+
+ /* Dispose of our result value. */
+ xmlrpc_DECREF(result);
+
+ /* Clean up our error-handling environment. */
+ xmlrpc_env_clean(&env);
+
+ /* Shutdown our XML-RPC client library. */
+ xmlrpc_client_cleanup();
+
+ return 0;
+}
diff --git a/Utilities/cmxmlrpc/xmlrpc.h b/Utilities/cmxmlrpc/xmlrpc.h
index cffbc91..9c308c8 100644
--- a/Utilities/cmxmlrpc/xmlrpc.h
+++ b/Utilities/cmxmlrpc/xmlrpc.h
@@ -29,6 +29,7 @@
#include <stddef.h>
#include <stdarg.h>
+#include <xmlrpc_config.h>
#ifdef HAVE_UNICODE_WCHAR
#include <wchar.h>
diff --git a/Utilities/cmxmlrpc/xmlrpc_client.c b/Utilities/cmxmlrpc/xmlrpc_client.c
index 3603a21..bce5538 100644
--- a/Utilities/cmxmlrpc/xmlrpc_client.c
+++ b/Utilities/cmxmlrpc/xmlrpc_client.c
@@ -142,6 +142,8 @@ setupTransport(xmlrpc_env * const envP,
#if MUST_BUILD_CURL_CLIENT
else if (strcmp(transportName, "curl") == 0)
clientTransportOps = xmlrpc_curl_transport_ops;
+ else if (strcmp(transportName, "libcurl") == 0)
+ clientTransportOps = xmlrpc_curl_transport_ops;
#endif
#if MUST_BUILD_LIBWWW_CLIENT
else if (strcmp(transportName, "libwww") == 0)
diff --git a/Utilities/cmxmlrpc/xmlrpc_config.h.in b/Utilities/cmxmlrpc/xmlrpc_config.h.in
index 8cf9553..fff0e9d 100644
--- a/Utilities/cmxmlrpc/xmlrpc_config.h.in
+++ b/Utilities/cmxmlrpc/xmlrpc_config.h.in
@@ -16,6 +16,9 @@
*/
#include "xmlrpc_amconfig.h"
+#ifndef __xmlrpc_config_h__
+#define __xmlrpc_config_h__
+
#define VA_LIST_IS_ARRAY @VA_LIST_IS_ARRAY_DEFINE@
@@ -75,3 +78,5 @@ __inline BOOL setenv(const char* name, const char* value, int i)
return (SetEnvironmentVariable(name, value) != 0) ? TRUE : FALSE;
}
#endif
+
+#endif