1 /* This program generates on Standard Output the XML for an XML-RPC
2 call suitable for the xmlrpc_sample_add_server program.
4 This is the same XML that the xmlrpc_sample_add_client program sends.
6 Use this either as an example of how to use the Xmlrpc-c XML-generating
7 functions or to generate XML that you can use to test an XML-RPC
14 #include <xmlrpc-c/base.h>
19 die_if_fault_occurred (xmlrpc_env *env) {
20 if (env->fault_occurred) {
21 fprintf(stderr, "XML-RPC Fault: %s (%d)\n",
22 env->fault_string, env->fault_code);
31 const char ** const argv ATTR_UNUSED) {
33 char * const methodName = "sample.add";
36 xmlrpc_value * params;
37 xmlrpc_mem_block * xmlmemblockP;
40 fprintf(stderr, "This program has no arguments\n");
44 /* Initialize our error-handling environment. */
45 xmlrpc_env_init(&env);
47 params = xmlrpc_build_value(&env, "(ii)",
48 (xmlrpc_int32) 5, (xmlrpc_int32) 7);
50 die_if_fault_occurred(&env);
52 xmlmemblockP = XMLRPC_MEMBLOCK_NEW(char, &env, 0);
54 xmlrpc_serialize_call(&env, xmlmemblockP, methodName, params);
56 die_if_fault_occurred(&env);
58 fwrite(XMLRPC_MEMBLOCK_CONTENTS(char, xmlmemblockP),
60 XMLRPC_MEMBLOCK_SIZE(char, xmlmemblockP),
63 XMLRPC_MEMBLOCK_FREE(char, xmlmemblockP);
65 /* Dispose of our parameter array. */
66 xmlrpc_DECREF(params);
68 /* Clean up our error-handling environment. */
69 xmlrpc_env_clean(&env);