xmlrpc.h 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452
  1. /*
  2. This file is part of libXMLRPC - a C library for xml-encoded function calls.
  3. Author: Dan Libby (dan@libby.com)
  4. Epinions.com may be contacted at feedback@epinions-inc.com
  5. */
  6. /*
  7. Copyright 2000 Epinions, Inc.
  8. Subject to the following 3 conditions, Epinions, Inc. permits you, free
  9. of charge, to (a) use, copy, distribute, modify, perform and display this
  10. software and associated documentation files (the "Software"), and (b)
  11. permit others to whom the Software is furnished to do so as well.
  12. 1) The above copyright notice and this permission notice shall be included
  13. without modification in all copies or substantial portions of the
  14. Software.
  15. 2) THE SOFTWARE IS PROVIDED "AS IS", WITHOUT ANY WARRANTY OR CONDITION OF
  16. ANY KIND, EXPRESS, IMPLIED OR STATUTORY, INCLUDING WITHOUT LIMITATION ANY
  17. IMPLIED WARRANTIES OF ACCURACY, MERCHANTABILITY, FITNESS FOR A PARTICULAR
  18. PURPOSE OR NONINFRINGEMENT.
  19. 3) IN NO EVENT SHALL EPINIONS, INC. BE LIABLE FOR ANY DIRECT, INDIRECT,
  20. SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES OR LOST PROFITS ARISING OUT
  21. OF OR IN CONNECTION WITH THE SOFTWARE (HOWEVER ARISING, INCLUDING
  22. NEGLIGENCE), EVEN IF EPINIONS, INC. IS AWARE OF THE POSSIBILITY OF SUCH
  23. DAMAGES.
  24. */
  25. #ifndef XMLRPC_ALREADY_INCLUDED
  26. #define XMLRPC_ALREADY_INCLUDED 1
  27. /* includes */
  28. #include "xml_element.h"
  29. #include <time.h> /* for time_t */
  30. #include <php.h>
  31. #ifdef __cplusplus
  32. extern "C" {
  33. #endif
  34. /* allow version to be specified via compile line define */
  35. #ifndef XMLRPC_LIB_VERSION
  36. #define XMLRPC_LIB_VERSION "0.51"
  37. #endif
  38. /* this number, representing the date, must be increased each time the API changes */
  39. #define XMLRPC_API_NO 20020623
  40. /* this string should be changed with each packaged release */
  41. #define XMLRPC_VERSION_STR "xmlrpc-epi v. " XMLRPC_LIB_VERSION
  42. /* where to find more info. shouldn't need to change much */
  43. #define XMLRPC_HOME_PAGE_STR "http://xmlprc-epi.sourceforge.net/"
  44. /****d* VALUE/XMLRPC_VALUE_TYPE
  45. * NAME
  46. * XMLRPC_VALUE_TYPE
  47. * NOTES
  48. * Defines data types for XMLRPC_VALUE
  49. * Deprecated for public use. See XMLRPC_VALUE_TYPE_EASY
  50. * SEE ALSO
  51. * XMLRPC_VECTOR_TYPE
  52. * XMLRPC_REQUEST_TYPE
  53. * SOURCE
  54. */
  55. typedef enum _XMLRPC_VALUE_TYPE {
  56. xmlrpc_none, /* not a value */
  57. xmlrpc_empty, /* empty value, eg NULL */
  58. xmlrpc_base64, /* base64 value, eg binary data */
  59. xmlrpc_boolean, /* boolean [0 | 1] */
  60. xmlrpc_datetime, /* datetime [ISO8601 | time_t] */
  61. xmlrpc_double, /* double / floating point */
  62. xmlrpc_int, /* integer */
  63. xmlrpc_string, /* string */
  64. xmlrpc_vector /* vector, aka list, array */
  65. } XMLRPC_VALUE_TYPE;
  66. /*******/
  67. /****d* VALUE/XMLRPC_VECTOR_TYPE
  68. * NAME
  69. * XMLRPC_VECTOR_TYPE
  70. * NOTES
  71. * Defines data types for XMLRPC_VECTOR.
  72. * Deprecated for public use. See XMLRPC_VALUE_TYPE_EASY
  73. * SEE ALSO
  74. * XMLRPC_VALUE_TYPE
  75. * XMLRPC_REQUEST_TYPE
  76. * SOURCE
  77. */
  78. typedef enum _XMLRPC_VECTOR_TYPE {
  79. xmlrpc_vector_none, /* not an array */
  80. xmlrpc_vector_array, /* no values may have key names */
  81. xmlrpc_vector_mixed, /* some values may have key names */
  82. xmlrpc_vector_struct /* all values must have key names */
  83. } XMLRPC_VECTOR_TYPE;
  84. /*******/
  85. /****d* VALUE/XMLRPC_VALUE_TYPE_EASY
  86. * NAME
  87. * XMLRPC_VALUE_TYPE_EASY
  88. * NOTES
  89. * Defines data types for XMLRPC_VALUE, including vector types.
  90. * SEE ALSO
  91. * XMLRPC_VECTOR_TYPE
  92. * XMLRPC_REQUEST_TYPE
  93. * SOURCE
  94. */
  95. typedef enum _XMLRPC_VALUE_TYPE_EASY {
  96. xmlrpc_type_none, /* not a value */
  97. xmlrpc_type_empty, /* empty value, eg NULL */
  98. xmlrpc_type_base64, /* base64 value, eg binary data */
  99. xmlrpc_type_boolean, /* boolean [0 | 1] */
  100. xmlrpc_type_datetime, /* datetime [ISO8601 | time_t] */
  101. xmlrpc_type_double, /* double / floating point */
  102. xmlrpc_type_int, /* integer */
  103. xmlrpc_type_string, /* string */
  104. /* -- IMPORTANT: identical to XMLRPC_VALUE_TYPE to this point. -- */
  105. xmlrpc_type_array, /* vector array */
  106. xmlrpc_type_mixed, /* vector mixed */
  107. xmlrpc_type_struct /* vector struct */
  108. } XMLRPC_VALUE_TYPE_EASY;
  109. /*******/
  110. /****d* VALUE/XMLRPC_REQUEST_TYPE
  111. * NAME
  112. * XMLRPC_REQUEST_TYPE
  113. * NOTES
  114. * Defines data types for XMLRPC_REQUEST
  115. * SEE ALSO
  116. * XMLRPC_VALUE_TYPE
  117. * XMLRPC_VECTOR_TYPE
  118. * SOURCE
  119. */
  120. typedef enum _xmlrpc_request_type {
  121. xmlrpc_request_none, /* not a valid request */
  122. xmlrpc_request_call, /* calling/invoking a method */
  123. xmlrpc_request_response, /* responding to a method call */
  124. } XMLRPC_REQUEST_TYPE;
  125. /*******/
  126. /****d* VALUE/XMLRPC_ERROR_CODE
  127. * NAME
  128. * XMLRPC_ERROR_CODE
  129. * NOTES
  130. * All existing error codes
  131. * SEE ALSO
  132. * XMLRPC_REQUEST_ERROR
  133. * SOURCE
  134. */
  135. typedef enum _xmlrpc_error_code {
  136. xmlrpc_error_none = 0, /* not an error */
  137. xmlrpc_error_parse_xml_syntax = -32700,
  138. xmlrpc_error_parse_unknown_encoding = -32701,
  139. xmlrpc_error_parse_bad_encoding = -32702,
  140. xmlrpc_error_invalid_xmlrpc = -32600,
  141. xmlrpc_error_unknown_method = -32601,
  142. xmlrpc_error_invalid_params = -32602,
  143. xmlrpc_error_internal_server = -32603,
  144. xmlrpc_error_application = -32500,
  145. xmlrpc_error_system = -32400,
  146. xmlrpc_error_transport = -32300
  147. } XMLRPC_ERROR_CODE;
  148. /******/
  149. #define xmlrpc_error_parse_xml_syntax_str "parse error. not well formed."
  150. #define xmlrpc_error_parse_unknown_encoding_str "parse error. unknown encoding"
  151. #define xmlrpc_error_parse_bad_encoding_str "parse error. invalid character for encoding"
  152. #define xmlrpc_error_invalid_xmlrpc_str "server error. xml-rpc not conforming to spec"
  153. #define xmlrpc_error_unknown_method_str "server error. method not found."
  154. #define xmlrpc_error_invalid_params_str "server error. invalid method parameters"
  155. #define xmlrpc_error_internal_server_str "server error. internal xmlrpc library error"
  156. #define xmlrpc_error_application_str "application error."
  157. #define xmlrpc_error_system_str "system error."
  158. #define xmlrpc_error_transport_str "transport error."
  159. /****d* VALUE/XMLRPC_VERSION
  160. * NAME
  161. * XMLRPC_VERSION
  162. * NOTES
  163. * Defines xml vocabulary used for generated xml
  164. * SEE ALSO
  165. * XMLRPC_REQUEST_OUTPUT_OPTIONS
  166. * XMLRPC_REQUEST_To_XML ()
  167. * SOURCE
  168. */
  169. typedef enum _xmlrpc_version {
  170. xmlrpc_version_none = 0, /* not a recognized vocabulary */
  171. xmlrpc_version_1_0 = 1, /* xmlrpc 1.0 standard vocab */
  172. xmlrpc_version_simple = 2, /* alt more readable vocab */
  173. xmlrpc_version_danda = 2, /* same as simple. legacy */
  174. xmlrpc_version_soap_1_1 = 3 /* SOAP. version 1.1 */
  175. } XMLRPC_VERSION;
  176. /******/
  177. /****s* VALUE/XMLRPC_REQUEST_OUTPUT_OPTIONS
  178. * NAME
  179. * XMLRPC_REQUEST_OUTPUT_OPTIONS
  180. * NOTES
  181. * Defines output options for generated xml
  182. * SEE ALSO
  183. * XMLRPC_VERSION
  184. * XML_ELEM_OUTPUT_OPTIONS
  185. * XMLRPC_REQUEST_To_XML ()
  186. * SOURCE
  187. */
  188. typedef struct _xmlrpc_request_output_options {
  189. STRUCT_XML_ELEM_OUTPUT_OPTIONS xml_elem_opts; /* xml_element specific output options */
  190. XMLRPC_VERSION version; /* xml vocabulary to use */
  191. } STRUCT_XMLRPC_REQUEST_OUTPUT_OPTIONS, *XMLRPC_REQUEST_OUTPUT_OPTIONS;
  192. /******/
  193. /****s* VALUE/XMLRPC_REQUEST_INPUT_OPTIONS
  194. * NAME
  195. * XMLRPC_REQUEST_INPUT_OPTIONS
  196. * NOTES
  197. * Defines options for reading in xml data
  198. * SEE ALSO
  199. * XMLRPC_VERSION
  200. * XML_ELEM_INPUT_OPTIONS
  201. * XMLRPC_REQUEST_From_XML ()
  202. * SOURCE
  203. */
  204. typedef struct _xmlrpc_request_input_options {
  205. STRUCT_XML_ELEM_INPUT_OPTIONS xml_elem_opts; /* xml_element specific output options */
  206. } STRUCT_XMLRPC_REQUEST_INPUT_OPTIONS, *XMLRPC_REQUEST_INPUT_OPTIONS;
  207. /******/
  208. /****s* VALUE/XMLRPC_ERROR
  209. * NAME
  210. * XMLRPC_ERROR
  211. * NOTES
  212. * For the reporting and handling of errors
  213. * SOURCE
  214. */
  215. typedef struct _xmlrpc_error {
  216. XMLRPC_ERROR_CODE code;
  217. STRUCT_XML_ELEM_ERROR xml_elem_error; /* xml_element errors (parser errors) */
  218. } STRUCT_XMLRPC_ERROR, *XMLRPC_ERROR;
  219. /******/
  220. /****d* VALUE/XMLRPC_CASE_COMPARISON
  221. * NAME
  222. * XMLRPC_CASE_COMPARISON
  223. * NOTES
  224. * Defines case comparison options for XMLRPC_VALUE/VECTOR API's
  225. * SEE ALSO
  226. * XMLRPC_CASE
  227. * XMLRPC_VALUE
  228. * SOURCE
  229. */
  230. typedef enum _xmlrpc_case_comparison {
  231. xmlrpc_case_insensitive, /* use case-insensitive compare */
  232. xmlrpc_case_sensitive /* use case-sensitive compare */
  233. } XMLRPC_CASE_COMPARISON;
  234. /******/
  235. /****d* VALUE/XMLRPC_CASE
  236. * NAME
  237. * XMLRPC_CASE
  238. * NOTES
  239. * Defines case behavior when setting IDs in XMLRPC_VALUE API's
  240. * SEE ALSO
  241. * XMLRPC_CASE_COMPARISON
  242. * XMLRPC_VALUE
  243. * SOURCE
  244. */
  245. typedef enum _xmlrpc_case {
  246. xmlrpc_case_exact, /* leave case alone */
  247. xmlrpc_case_lower, /* lower-case id */
  248. xmlrpc_case_upper /* upper-case id */
  249. } XMLRPC_CASE;
  250. /******/
  251. /* if you don't like these defaults, you can set them with XMLRPC_SetDefaultIdCase*() */
  252. #define XMLRPC_DEFAULT_ID_CASE XMLRPC_GetDefaultIdCase()
  253. #define XMLRPC_DEFAULT_ID_CASE_SENSITIVITY XMLRPC_GetDefaultIdCaseComparison()
  254. /* opaque (non-public) types. defined locally in xmlrpc.c */
  255. typedef struct _xmlrpc_request* XMLRPC_REQUEST;
  256. typedef struct _xmlrpc_server* XMLRPC_SERVER;
  257. typedef struct _xmlrpc_value* XMLRPC_VALUE;
  258. /****d* VALUE/XMLRPC_Callback
  259. * NAME
  260. * XMLRPC_Callback
  261. * NOTES
  262. * Function prototype for user defined method handlers (callbacks).
  263. * SEE ALSO
  264. * XMLRPC_ServerRegisterMethod ()
  265. * XMLRPC_ServerCallMethod ()
  266. * XMLRPC_REQUEST
  267. * XMLRPC_VALUE
  268. * SOURCE
  269. */
  270. typedef XMLRPC_VALUE (*XMLRPC_Callback)(XMLRPC_SERVER server, XMLRPC_REQUEST input, void* userData);
  271. /******/
  272. /* ID Case Defaults */
  273. XMLRPC_CASE XMLRPC_GetDefaultIdCase(void);
  274. XMLRPC_CASE XMLRPC_SetDefaultIdCase(XMLRPC_CASE id_case);
  275. XMLRPC_CASE_COMPARISON XMLRPC_GetDefaultIdCaseComparison(void);
  276. XMLRPC_CASE_COMPARISON XMLRPC_SetDefaultIdCaseComparison(XMLRPC_CASE_COMPARISON id_case);
  277. /* Vector manipulation */
  278. int XMLRPC_VectorSize(XMLRPC_VALUE value);
  279. XMLRPC_VALUE XMLRPC_VectorRewind(XMLRPC_VALUE value);
  280. XMLRPC_VALUE XMLRPC_VectorNext(XMLRPC_VALUE value);
  281. int XMLRPC_SetIsVector(XMLRPC_VALUE value, XMLRPC_VECTOR_TYPE type);
  282. int XMLRPC_AddValueToVector(XMLRPC_VALUE target, XMLRPC_VALUE source);
  283. int XMLRPC_AddValuesToVector(XMLRPC_VALUE target, ...);
  284. int XMLRPC_VectorRemoveValue(XMLRPC_VALUE vector, XMLRPC_VALUE value);
  285. XMLRPC_VALUE XMLRPC_VectorGetValueWithID_Case(XMLRPC_VALUE vector, const char* id, XMLRPC_CASE_COMPARISON id_case);
  286. /* Create values */
  287. XMLRPC_VALUE XMLRPC_CreateValueBoolean(const char* id, int truth);
  288. XMLRPC_VALUE XMLRPC_CreateValueBase64(const char* id, const char* s, int len);
  289. XMLRPC_VALUE XMLRPC_CreateValueDateTime(const char* id, time_t time);
  290. XMLRPC_VALUE XMLRPC_CreateValueDateTime_ISO8601(const char* id, const char *s);
  291. XMLRPC_VALUE XMLRPC_CreateValueDouble(const char* id, double f);
  292. XMLRPC_VALUE XMLRPC_CreateValueInt(const char* id, int i);
  293. XMLRPC_VALUE XMLRPC_CreateValueString(const char* id, const char* s, int len);
  294. XMLRPC_VALUE XMLRPC_CreateValueEmpty(void);
  295. XMLRPC_VALUE XMLRPC_CreateVector(const char* id, XMLRPC_VECTOR_TYPE type);
  296. /* Cleanup values */
  297. void XMLRPC_CleanupValue(XMLRPC_VALUE value);
  298. /* Request error */
  299. XMLRPC_VALUE XMLRPC_RequestSetError (XMLRPC_REQUEST request, XMLRPC_VALUE error);
  300. XMLRPC_VALUE XMLRPC_RequestGetError (XMLRPC_REQUEST request);
  301. /* Copy values */
  302. XMLRPC_VALUE XMLRPC_CopyValue(XMLRPC_VALUE value);
  303. XMLRPC_VALUE XMLRPC_DupValueNew(XMLRPC_VALUE xSource);
  304. /* Set Values */
  305. void XMLRPC_SetValueDateTime(XMLRPC_VALUE value, time_t time);
  306. void XMLRPC_SetValueDateTime_ISO8601(XMLRPC_VALUE value, const char* s);
  307. void XMLRPC_SetValueDouble(XMLRPC_VALUE value, double val);
  308. void XMLRPC_SetValueInt(XMLRPC_VALUE value, int val);
  309. void XMLRPC_SetValueBoolean(XMLRPC_VALUE value, int val);
  310. const char *XMLRPC_SetValueString(XMLRPC_VALUE value, const char* s, int len);
  311. void XMLRPC_SetValueBase64(XMLRPC_VALUE value, const char* s, int len);
  312. const char *XMLRPC_SetValueID_Case(XMLRPC_VALUE value, const char* id, int len, XMLRPC_CASE id_case);
  313. #define XMLRPC_SetValueID(value, id, len) XMLRPC_SetValueID_Case(value, id, len, XMLRPC_DEFAULT_ID_CASE)
  314. /* Get Values */
  315. const char* XMLRPC_GetValueString(XMLRPC_VALUE value);
  316. int XMLRPC_GetValueStringLen(XMLRPC_VALUE value);
  317. int XMLRPC_GetValueInt(XMLRPC_VALUE value);
  318. int XMLRPC_GetValueBoolean(XMLRPC_VALUE value);
  319. double XMLRPC_GetValueDouble(XMLRPC_VALUE value);
  320. const char* XMLRPC_GetValueBase64(XMLRPC_VALUE value);
  321. time_t XMLRPC_GetValueDateTime(XMLRPC_VALUE value);
  322. const char* XMLRPC_GetValueDateTime_ISO8601(XMLRPC_VALUE value);
  323. const char* XMLRPC_GetValueID(XMLRPC_VALUE value);
  324. /* Type introspection */
  325. XMLRPC_VALUE_TYPE XMLRPC_GetValueType(XMLRPC_VALUE v);
  326. XMLRPC_VALUE_TYPE_EASY XMLRPC_GetValueTypeEasy(XMLRPC_VALUE v);
  327. XMLRPC_VECTOR_TYPE XMLRPC_GetVectorType(XMLRPC_VALUE v);
  328. /* Parsing and Creating XML */
  329. XMLRPC_REQUEST XMLRPC_REQUEST_FromXML(const char* in_buf, int len, XMLRPC_REQUEST_INPUT_OPTIONS in_options);
  330. XMLRPC_VALUE XMLRPC_VALUE_FromXML(const char* in_buf, int len, XMLRPC_REQUEST_INPUT_OPTIONS in_options);
  331. char* XMLRPC_REQUEST_ToXML(XMLRPC_REQUEST request, int *buf_len);
  332. char* XMLRPC_VALUE_ToXML(XMLRPC_VALUE val, int* buf_len);
  333. /* Request manipulation funcs */
  334. const char* XMLRPC_RequestSetMethodName(XMLRPC_REQUEST request, const char* methodName);
  335. const char* XMLRPC_RequestGetMethodName(XMLRPC_REQUEST request);
  336. XMLRPC_REQUEST XMLRPC_RequestNew(void);
  337. void XMLRPC_RequestFree(XMLRPC_REQUEST request, int bFreeIO);
  338. XMLRPC_REQUEST_OUTPUT_OPTIONS XMLRPC_RequestSetOutputOptions(XMLRPC_REQUEST request, XMLRPC_REQUEST_OUTPUT_OPTIONS output);
  339. XMLRPC_REQUEST_OUTPUT_OPTIONS XMLRPC_RequestGetOutputOptions(XMLRPC_REQUEST request);
  340. XMLRPC_VALUE XMLRPC_RequestSetData(XMLRPC_REQUEST request, XMLRPC_VALUE data);
  341. XMLRPC_VALUE XMLRPC_RequestGetData(XMLRPC_REQUEST request);
  342. XMLRPC_REQUEST_TYPE XMLRPC_RequestSetRequestType(XMLRPC_REQUEST request, XMLRPC_REQUEST_TYPE type);
  343. XMLRPC_REQUEST_TYPE XMLRPC_RequestGetRequestType(XMLRPC_REQUEST request);
  344. /* Server Creation/Destruction; Method Registration and Invocation */
  345. XMLRPC_SERVER XMLRPC_ServerCreate(void);
  346. XMLRPC_SERVER XMLRPC_GetGlobalServer(void); /* better to use XMLRPC_ServerCreate if you can */
  347. void XMLRPC_ServerDestroy(XMLRPC_SERVER server);
  348. int XMLRPC_ServerRegisterMethod(XMLRPC_SERVER server, const char *name, XMLRPC_Callback cb);
  349. XMLRPC_Callback XMLRPC_ServerFindMethod(XMLRPC_SERVER server, const char* callName);
  350. XMLRPC_VALUE XMLRPC_ServerCallMethod(XMLRPC_SERVER server, XMLRPC_REQUEST request, void* userData);
  351. #include "xmlrpc_introspection.h"
  352. /* Fault interrogation funcs */
  353. int XMLRPC_ValueIsFault (XMLRPC_VALUE value);
  354. int XMLRPC_ResponseIsFault(XMLRPC_REQUEST response);
  355. int XMLRPC_GetValueFaultCode (XMLRPC_VALUE value);
  356. int XMLRPC_GetResponseFaultCode(XMLRPC_REQUEST response);
  357. const char* XMLRPC_GetValueFaultString (XMLRPC_VALUE value);
  358. const char* XMLRPC_GetResponseFaultString (XMLRPC_REQUEST response);
  359. /* Public Utility funcs */
  360. XMLRPC_VALUE XMLRPC_UtilityCreateFault(int fault_code, const char* fault_string);
  361. void XMLRPC_Free(void* mem);
  362. const char* XMLRPC_GetVersionString(void);
  363. /****d* VALUE/XMLRPC_MACROS
  364. * NAME
  365. * Some Helpful Macros
  366. * NOTES
  367. * Some macros for making life easier. Should be self-explanatory.
  368. * SEE ALSO
  369. * XMLRPC_AddValueToVector ()
  370. * XMLRPC_VectorGetValueWithID_Case ()
  371. * XMLRPC_VALUE
  372. * SOURCE
  373. */
  374. /* Append values to vector */
  375. #define XMLRPC_VectorAppendString(vector, id, s, len) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueString(id, s, len))
  376. #define XMLRPC_VectorAppendBase64(vector, id, s, len) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueBase64(id, s, len))
  377. #define XMLRPC_VectorAppendDateTime(vector, id, time) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueDateTime(id, time))
  378. #define XMLRPC_VectorAppendDateTime_ISO8601(vector, id, s) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueDateTime_ISO8601(id, s))
  379. #define XMLRPC_VectorAppendDouble(vector, id, f) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueDouble(id, f))
  380. #define XMLRPC_VectorAppendInt(vector, id, i) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueInt(id, i))
  381. #define XMLRPC_VectorAppendBoolean(vector, id, i) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueBoolean(id, i))
  382. /* Get named values from vector */
  383. #define XMLRPC_VectorGetValueWithID(vector, id) XMLRPC_VectorGetValueWithID_Case(vector, id, XMLRPC_DEFAULT_ID_CASE_SENSITIVITY)
  384. #define XMLRPC_VectorGetStringWithID(vector, id) XMLRPC_GetValueString(XMLRPC_VectorGetValueWithID(vector, id))
  385. #define XMLRPC_VectorGetBase64WithID(vector, id) XMLRPC_GetValueBase64(XMLRPC_VectorGetValueWithID(vector, id))
  386. #define XMLRPC_VectorGetDateTimeWithID(vector, id) XMLRPC_GetValueDateTime(XMLRPC_VectorGetValueWithID(vector, id))
  387. #define XMLRPC_VectorGetDoubleWithID(vector, id) XMLRPC_GetValueDouble(XMLRPC_VectorGetValueWithID(vector, id))
  388. #define XMLRPC_VectorGetIntWithID(vector, id) XMLRPC_GetValueInt(XMLRPC_VectorGetValueWithID(vector, id))
  389. #define XMLRPC_VectorGetBooleanWithID(vector, id) XMLRPC_GetValueBoolean(XMLRPC_VectorGetValueWithID(vector, id))
  390. /******/
  391. #ifdef __cplusplus
  392. }
  393. #endif
  394. #endif /* not XMLRPC_ALREADY_INCLUDED */