123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454 |
- /*
- This file is part of libXMLRPC - a C library for xml-encoded function calls.
- Author: Dan Libby (dan@libby.com)
- Epinions.com may be contacted at feedback@epinions-inc.com
- */
- /*
- Copyright 2000 Epinions, Inc.
- Subject to the following 3 conditions, Epinions, Inc. permits you, free
- of charge, to (a) use, copy, distribute, modify, perform and display this
- software and associated documentation files (the "Software"), and (b)
- permit others to whom the Software is furnished to do so as well.
- 1) The above copyright notice and this permission notice shall be included
- without modification in all copies or substantial portions of the
- Software.
- 2) THE SOFTWARE IS PROVIDED "AS IS", WITHOUT ANY WARRANTY OR CONDITION OF
- ANY KIND, EXPRESS, IMPLIED OR STATUTORY, INCLUDING WITHOUT LIMITATION ANY
- IMPLIED WARRANTIES OF ACCURACY, MERCHANTABILITY, FITNESS FOR A PARTICULAR
- PURPOSE OR NONINFRINGEMENT.
- 3) IN NO EVENT SHALL EPINIONS, INC. BE LIABLE FOR ANY DIRECT, INDIRECT,
- SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES OR LOST PROFITS ARISING OUT
- OF OR IN CONNECTION WITH THE SOFTWARE (HOWEVER ARISING, INCLUDING
- NEGLIGENCE), EVEN IF EPINIONS, INC. IS AWARE OF THE POSSIBILITY OF SUCH
- DAMAGES.
- */
- #ifndef XMLRPC_ALREADY_INCLUDED
- #define XMLRPC_ALREADY_INCLUDED 1
- /* includes */
- #include "xml_element.h"
- #include <time.h> /* for time_t */
- #ifdef __cplusplus
- extern "C" {
- #endif
- /* allow version to be specified via compile line define */
- #ifndef XMLRPC_LIB_VERSION
- #define XMLRPC_LIB_VERSION "0.51"
- #endif
- /* this number, representing the date, must be increased each time the API changes */
- #define XMLRPC_API_NO 20020623
- /* this string should be changed with each packaged release */
- #define XMLRPC_VERSION_STR "xmlrpc-epi v. " XMLRPC_LIB_VERSION
- /* where to find more info. shouldn't need to change much */
- #define XMLRPC_HOME_PAGE_STR "http://xmlprc-epi.sourceforge.net/"
- /****d* VALUE/XMLRPC_VALUE_TYPE
- * NAME
- * XMLRPC_VALUE_TYPE
- * NOTES
- * Defines data types for XMLRPC_VALUE
- * Deprecated for public use. See XMLRPC_VALUE_TYPE_EASY
- * SEE ALSO
- * XMLRPC_VECTOR_TYPE
- * XMLRPC_REQUEST_TYPE
- * SOURCE
- */
- typedef enum _XMLRPC_VALUE_TYPE {
- xmlrpc_none, /* not a value */
- xmlrpc_empty, /* empty value, eg NULL */
- xmlrpc_base64, /* base64 value, eg binary data */
- xmlrpc_boolean, /* boolean [0 | 1] */
- xmlrpc_datetime, /* datetime [ISO8601 | time_t] */
- xmlrpc_double, /* double / floating point */
- xmlrpc_int, /* integer */
- xmlrpc_string, /* string */
- xmlrpc_vector /* vector, aka list, array */
- } XMLRPC_VALUE_TYPE;
- /*******/
- /****d* VALUE/XMLRPC_VECTOR_TYPE
- * NAME
- * XMLRPC_VECTOR_TYPE
- * NOTES
- * Defines data types for XMLRPC_VECTOR.
- * Deprecated for public use. See XMLRPC_VALUE_TYPE_EASY
- * SEE ALSO
- * XMLRPC_VALUE_TYPE
- * XMLRPC_REQUEST_TYPE
- * SOURCE
- */
- typedef enum _XMLRPC_VECTOR_TYPE {
- xmlrpc_vector_none, /* not an array */
- xmlrpc_vector_array, /* no values may have key names */
- xmlrpc_vector_mixed, /* some values may have key names */
- xmlrpc_vector_struct /* all values must have key names */
- } XMLRPC_VECTOR_TYPE;
- /*******/
- /****d* VALUE/XMLRPC_VALUE_TYPE_EASY
- * NAME
- * XMLRPC_VALUE_TYPE_EASY
- * NOTES
- * Defines data types for XMLRPC_VALUE, including vector types.
- * SEE ALSO
- * XMLRPC_VECTOR_TYPE
- * XMLRPC_REQUEST_TYPE
- * SOURCE
- */
- typedef enum _XMLRPC_VALUE_TYPE_EASY {
- xmlrpc_type_none, /* not a value */
- xmlrpc_type_empty, /* empty value, eg NULL */
- xmlrpc_type_base64, /* base64 value, eg binary data */
- xmlrpc_type_boolean, /* boolean [0 | 1] */
- xmlrpc_type_datetime, /* datetime [ISO8601 | time_t] */
- xmlrpc_type_double, /* double / floating point */
- xmlrpc_type_int, /* integer */
- xmlrpc_type_string, /* string */
- /* -- IMPORTANT: identical to XMLRPC_VALUE_TYPE to this point. -- */
- xmlrpc_type_array, /* vector array */
- xmlrpc_type_mixed, /* vector mixed */
- xmlrpc_type_struct /* vector struct */
- } XMLRPC_VALUE_TYPE_EASY;
- /*******/
- /****d* VALUE/XMLRPC_REQUEST_TYPE
- * NAME
- * XMLRPC_REQUEST_TYPE
- * NOTES
- * Defines data types for XMLRPC_REQUEST
- * SEE ALSO
- * XMLRPC_VALUE_TYPE
- * XMLRPC_VECTOR_TYPE
- * SOURCE
- */
- typedef enum _xmlrpc_request_type {
- xmlrpc_request_none, /* not a valid request */
- xmlrpc_request_call, /* calling/invoking a method */
- xmlrpc_request_response, /* responding to a method call */
- } XMLRPC_REQUEST_TYPE;
- /*******/
- /****d* VALUE/XMLRPC_ERROR_CODE
- * NAME
- * XMLRPC_ERROR_CODE
- * NOTES
- * All existing error codes
- * SEE ALSO
- * XMLRPC_REQUEST_ERROR
- * SOURCE
- */
- typedef enum _xmlrpc_error_code {
- xmlrpc_error_none = 0, /* not an error */
- xmlrpc_error_parse_xml_syntax = -32700,
- xmlrpc_error_parse_unknown_encoding = -32701,
- xmlrpc_error_parse_bad_encoding = -32702,
- xmlrpc_error_invalid_xmlrpc = -32600,
- xmlrpc_error_unknown_method = -32601,
- xmlrpc_error_invalid_params = -32602,
- xmlrpc_error_internal_server = -32603,
- xmlrpc_error_application = -32500,
- xmlrpc_error_system = -32400,
- xmlrpc_error_transport = -32300
- } XMLRPC_ERROR_CODE;
- /******/
- #define xmlrpc_error_parse_xml_syntax_str "parse error. not well formed."
- #define xmlrpc_error_parse_unknown_encoding_str "parse error. unknown encoding"
- #define xmlrpc_error_parse_bad_encoding_str "parse error. invalid character for encoding"
- #define xmlrpc_error_invalid_xmlrpc_str "server error. xml-rpc not conforming to spec"
- #define xmlrpc_error_unknown_method_str "server error. method not found."
- #define xmlrpc_error_invalid_params_str "server error. invalid method parameters"
- #define xmlrpc_error_internal_server_str "server error. internal xmlrpc library error"
- #define xmlrpc_error_application_str "application error."
- #define xmlrpc_error_system_str "system error."
- #define xmlrpc_error_transport_str "transport error."
- /****d* VALUE/XMLRPC_VERSION
- * NAME
- * XMLRPC_VERSION
- * NOTES
- * Defines xml vocabulary used for generated xml
- * SEE ALSO
- * XMLRPC_REQUEST_OUTPUT_OPTIONS
- * XMLRPC_REQUEST_To_XML ()
- * SOURCE
- */
- typedef enum _xmlrpc_version {
- xmlrpc_version_none = 0, /* not a recognized vocabulary */
- xmlrpc_version_1_0 = 1, /* xmlrpc 1.0 standard vocab */
- xmlrpc_version_simple = 2, /* alt more readable vocab */
- xmlrpc_version_danda = 2, /* same as simple. legacy */
- xmlrpc_version_soap_1_1 = 3 /* SOAP. version 1.1 */
- } XMLRPC_VERSION;
- /******/
- /****s* VALUE/XMLRPC_REQUEST_OUTPUT_OPTIONS
- * NAME
- * XMLRPC_REQUEST_OUTPUT_OPTIONS
- * NOTES
- * Defines output options for generated xml
- * SEE ALSO
- * XMLRPC_VERSION
- * XML_ELEM_OUTPUT_OPTIONS
- * XMLRPC_REQUEST_To_XML ()
- * SOURCE
- */
- typedef struct _xmlrpc_request_output_options {
- STRUCT_XML_ELEM_OUTPUT_OPTIONS xml_elem_opts; /* xml_element specific output options */
- XMLRPC_VERSION version; /* xml vocabulary to use */
- } STRUCT_XMLRPC_REQUEST_OUTPUT_OPTIONS, *XMLRPC_REQUEST_OUTPUT_OPTIONS;
- /******/
- /****s* VALUE/XMLRPC_REQUEST_INPUT_OPTIONS
- * NAME
- * XMLRPC_REQUEST_INPUT_OPTIONS
- * NOTES
- * Defines options for reading in xml data
- * SEE ALSO
- * XMLRPC_VERSION
- * XML_ELEM_INPUT_OPTIONS
- * XMLRPC_REQUEST_From_XML ()
- * SOURCE
- */
- typedef struct _xmlrpc_request_input_options {
- STRUCT_XML_ELEM_INPUT_OPTIONS xml_elem_opts; /* xml_element specific output options */
- } STRUCT_XMLRPC_REQUEST_INPUT_OPTIONS, *XMLRPC_REQUEST_INPUT_OPTIONS;
- /******/
- /****s* VALUE/XMLRPC_ERROR
- * NAME
- * XMLRPC_ERROR
- * NOTES
- * For the reporting and handling of errors
- * SOURCE
- */
- typedef struct _xmlrpc_error {
- XMLRPC_ERROR_CODE code;
- STRUCT_XML_ELEM_ERROR xml_elem_error; /* xml_element errors (parser errors) */
- } STRUCT_XMLRPC_ERROR, *XMLRPC_ERROR;
- /******/
- /****d* VALUE/XMLRPC_CASE_COMPARISON
- * NAME
- * XMLRPC_CASE_COMPARISON
- * NOTES
- * Defines case comparison options for XMLRPC_VALUE/VECTOR API's
- * SEE ALSO
- * XMLRPC_CASE
- * XMLRPC_VALUE
- * SOURCE
- */
- typedef enum _xmlrpc_case_comparison {
- xmlrpc_case_insensitive, /* use case-insensitive compare */
- xmlrpc_case_sensitive /* use case-sensitive compare */
- } XMLRPC_CASE_COMPARISON;
- /******/
- /****d* VALUE/XMLRPC_CASE
- * NAME
- * XMLRPC_CASE
- * NOTES
- * Defines case behavior when setting IDs in XMLRPC_VALUE API's
- * SEE ALSO
- * XMLRPC_CASE_COMPARISON
- * XMLRPC_VALUE
- * SOURCE
- */
- typedef enum _xmlrpc_case {
- xmlrpc_case_exact, /* leave case alone */
- xmlrpc_case_lower, /* lower-case id */
- xmlrpc_case_upper /* upper-case id */
- } XMLRPC_CASE;
- /******/
- /* if you don't like these defaults, you can set them with XMLRPC_SetDefaultIdCase*() */
- #define XMLRPC_DEFAULT_ID_CASE XMLRPC_GetDefaultIdCase()
- #define XMLRPC_DEFAULT_ID_CASE_SENSITIVITY XMLRPC_GetDefaultIdCaseComparison()
- /* opaque (non-public) types. defined locally in xmlrpc.c */
- typedef struct _xmlrpc_request* XMLRPC_REQUEST;
- typedef struct _xmlrpc_server* XMLRPC_SERVER;
- typedef struct _xmlrpc_value* XMLRPC_VALUE;
- /****d* VALUE/XMLRPC_Callback
- * NAME
- * XMLRPC_Callback
- * NOTES
- * Function prototype for user defined method handlers (callbacks).
- * SEE ALSO
- * XMLRPC_ServerRegisterMethod ()
- * XMLRPC_ServerCallMethod ()
- * XMLRPC_REQUEST
- * XMLRPC_VALUE
- * SOURCE
- */
- typedef XMLRPC_VALUE (*XMLRPC_Callback)(XMLRPC_SERVER server, XMLRPC_REQUEST input, void* userData);
- /******/
- /* ID Case Defaults */
- XMLRPC_CASE XMLRPC_GetDefaultIdCase(void);
- XMLRPC_CASE XMLRPC_SetDefaultIdCase(XMLRPC_CASE id_case);
- XMLRPC_CASE_COMPARISON XMLRPC_GetDefaultIdCaseComparison(void);
- XMLRPC_CASE_COMPARISON XMLRPC_SetDefaultIdCaseComparison(XMLRPC_CASE_COMPARISON id_case);
- /* Vector manipulation */
- int XMLRPC_VectorSize(XMLRPC_VALUE value);
- XMLRPC_VALUE XMLRPC_VectorRewind(XMLRPC_VALUE value);
- XMLRPC_VALUE XMLRPC_VectorNext(XMLRPC_VALUE value);
- int XMLRPC_SetIsVector(XMLRPC_VALUE value, XMLRPC_VECTOR_TYPE type);
- int XMLRPC_AddValueToVector(XMLRPC_VALUE target, XMLRPC_VALUE source);
- int XMLRPC_AddValuesToVector(XMLRPC_VALUE target, ...);
- int XMLRPC_VectorRemoveValue(XMLRPC_VALUE vector, XMLRPC_VALUE value);
- XMLRPC_VALUE XMLRPC_VectorGetValueWithID_Case(XMLRPC_VALUE vector, const char* id, XMLRPC_CASE_COMPARISON id_case);
- /* Create values */
- XMLRPC_VALUE XMLRPC_CreateValueBoolean(const char* id, int truth);
- XMLRPC_VALUE XMLRPC_CreateValueBase64(const char* id, const char* s, int len);
- XMLRPC_VALUE XMLRPC_CreateValueDateTime(const char* id, time_t time);
- XMLRPC_VALUE XMLRPC_CreateValueDateTime_ISO8601(const char* id, const char *s);
- XMLRPC_VALUE XMLRPC_CreateValueDouble(const char* id, double f);
- XMLRPC_VALUE XMLRPC_CreateValueInt(const char* id, int i);
- XMLRPC_VALUE XMLRPC_CreateValueString(const char* id, const char* s, int len);
- XMLRPC_VALUE XMLRPC_CreateValueEmpty(void);
- XMLRPC_VALUE XMLRPC_CreateVector(const char* id, XMLRPC_VECTOR_TYPE type);
- /* Cleanup values */
- void XMLRPC_CleanupValue(XMLRPC_VALUE value);
- /* Request error */
- XMLRPC_VALUE XMLRPC_RequestSetError (XMLRPC_REQUEST request, XMLRPC_VALUE error);
- XMLRPC_VALUE XMLRPC_RequestGetError (XMLRPC_REQUEST request);
- /* Copy values */
- XMLRPC_VALUE XMLRPC_CopyValue(XMLRPC_VALUE value);
- XMLRPC_VALUE XMLRPC_DupValueNew(XMLRPC_VALUE xSource);
- /* Set Values */
- void XMLRPC_SetValueDateTime(XMLRPC_VALUE value, time_t time);
- void XMLRPC_SetValueDateTime_ISO8601(XMLRPC_VALUE value, const char* s);
- void XMLRPC_SetValueDouble(XMLRPC_VALUE value, double val);
- void XMLRPC_SetValueInt(XMLRPC_VALUE value, int val);
- void XMLRPC_SetValueBoolean(XMLRPC_VALUE value, int val);
- const char *XMLRPC_SetValueString(XMLRPC_VALUE value, const char* s, int len);
- void XMLRPC_SetValueBase64(XMLRPC_VALUE value, const char* s, int len);
- const char *XMLRPC_SetValueID_Case(XMLRPC_VALUE value, const char* id, int len, XMLRPC_CASE id_case);
- #define XMLRPC_SetValueID(value, id, len) XMLRPC_SetValueID_Case(value, id, len, XMLRPC_DEFAULT_ID_CASE)
- /* Get Values */
- const char* XMLRPC_GetValueString(XMLRPC_VALUE value);
- int XMLRPC_GetValueStringLen(XMLRPC_VALUE value);
- int XMLRPC_GetValueInt(XMLRPC_VALUE value);
- int XMLRPC_GetValueBoolean(XMLRPC_VALUE value);
- double XMLRPC_GetValueDouble(XMLRPC_VALUE value);
- const char* XMLRPC_GetValueBase64(XMLRPC_VALUE value);
- time_t XMLRPC_GetValueDateTime(XMLRPC_VALUE value);
- const char* XMLRPC_GetValueDateTime_ISO8601(XMLRPC_VALUE value);
- const char* XMLRPC_GetValueID(XMLRPC_VALUE value);
- /* Type introspection */
- XMLRPC_VALUE_TYPE XMLRPC_GetValueType(XMLRPC_VALUE v);
- XMLRPC_VALUE_TYPE_EASY XMLRPC_GetValueTypeEasy(XMLRPC_VALUE v);
- XMLRPC_VECTOR_TYPE XMLRPC_GetVectorType(XMLRPC_VALUE v);
- /* Parsing and Creating XML */
- XMLRPC_REQUEST XMLRPC_REQUEST_FromXML(const char* in_buf, int len, XMLRPC_REQUEST_INPUT_OPTIONS in_options);
- XMLRPC_VALUE XMLRPC_VALUE_FromXML(const char* in_buf, int len, XMLRPC_REQUEST_INPUT_OPTIONS in_options);
- char* XMLRPC_REQUEST_ToXML(XMLRPC_REQUEST request, int *buf_len);
- char* XMLRPC_VALUE_ToXML(XMLRPC_VALUE val, int* buf_len);
- /* Request manipulation funcs */
- const char* XMLRPC_RequestSetMethodName(XMLRPC_REQUEST request, const char* methodName);
- const char* XMLRPC_RequestGetMethodName(XMLRPC_REQUEST request);
- XMLRPC_REQUEST XMLRPC_RequestNew(void);
- void XMLRPC_RequestFree(XMLRPC_REQUEST request, int bFreeIO);
- XMLRPC_REQUEST_OUTPUT_OPTIONS XMLRPC_RequestSetOutputOptions(XMLRPC_REQUEST request, XMLRPC_REQUEST_OUTPUT_OPTIONS output);
- XMLRPC_REQUEST_OUTPUT_OPTIONS XMLRPC_RequestGetOutputOptions(XMLRPC_REQUEST request);
- XMLRPC_VALUE XMLRPC_RequestSetData(XMLRPC_REQUEST request, XMLRPC_VALUE data);
- XMLRPC_VALUE XMLRPC_RequestGetData(XMLRPC_REQUEST request);
- XMLRPC_REQUEST_TYPE XMLRPC_RequestSetRequestType(XMLRPC_REQUEST request, XMLRPC_REQUEST_TYPE type);
- XMLRPC_REQUEST_TYPE XMLRPC_RequestGetRequestType(XMLRPC_REQUEST request);
- /* Server Creation/Destruction; Method Registration and Invocation */
- XMLRPC_SERVER XMLRPC_ServerCreate(void);
- XMLRPC_SERVER XMLRPC_GetGlobalServer(void); /* better to use XMLRPC_ServerCreate if you can */
- void XMLRPC_ServerDestroy(XMLRPC_SERVER server);
- int XMLRPC_ServerRegisterMethod(XMLRPC_SERVER server, const char *name, XMLRPC_Callback cb);
- XMLRPC_Callback XMLRPC_ServerFindMethod(XMLRPC_SERVER server, const char* callName);
- XMLRPC_VALUE XMLRPC_ServerCallMethod(XMLRPC_SERVER server, XMLRPC_REQUEST request, void* userData);
- #include "xmlrpc_introspection.h"
- /* Fault interrogation funcs */
- int XMLRPC_ValueIsFault (XMLRPC_VALUE value);
- int XMLRPC_ResponseIsFault(XMLRPC_REQUEST response);
- int XMLRPC_GetValueFaultCode (XMLRPC_VALUE value);
- int XMLRPC_GetResponseFaultCode(XMLRPC_REQUEST response);
- const char* XMLRPC_GetValueFaultString (XMLRPC_VALUE value);
- const char* XMLRPC_GetResponseFaultString (XMLRPC_REQUEST response);
- /* Public Utility funcs */
- XMLRPC_VALUE XMLRPC_UtilityCreateFault(int fault_code, const char* fault_string);
- void XMLRPC_Free(void* mem);
- const char* XMLRPC_GetVersionString(void);
- /****d* VALUE/XMLRPC_MACROS
- * NAME
- * Some Helpful Macros
- * NOTES
- * Some macros for making life easier. Should be self-explanatory.
- * SEE ALSO
- * XMLRPC_AddValueToVector ()
- * XMLRPC_VectorGetValueWithID_Case ()
- * XMLRPC_VALUE
- * SOURCE
- */
- /* Append values to vector */
- #define XMLRPC_VectorAppendString(vector, id, s, len) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueString(id, s, len))
- #define XMLRPC_VectorAppendBase64(vector, id, s, len) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueBase64(id, s, len))
- #define XMLRPC_VectorAppendDateTime(vector, id, time) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueDateTime(id, time))
- #define XMLRPC_VectorAppendDateTime_ISO8601(vector, id, s) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueDateTime_ISO8601(id, s))
- #define XMLRPC_VectorAppendDouble(vector, id, f) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueDouble(id, f))
- #define XMLRPC_VectorAppendInt(vector, id, i) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueInt(id, i))
- #define XMLRPC_VectorAppendBoolean(vector, id, i) XMLRPC_AddValueToVector(vector, XMLRPC_CreateValueBoolean(id, i))
- /* Get named values from vector */
- #define XMLRPC_VectorGetValueWithID(vector, id) XMLRPC_VectorGetValueWithID_Case(vector, id, XMLRPC_DEFAULT_ID_CASE_SENSITIVITY)
- #define XMLRPC_VectorGetStringWithID(vector, id) XMLRPC_GetValueString(XMLRPC_VectorGetValueWithID(vector, id))
- #define XMLRPC_VectorGetBase64WithID(vector, id) XMLRPC_GetValueBase64(XMLRPC_VectorGetValueWithID(vector, id))
- #define XMLRPC_VectorGetDateTimeWithID(vector, id) XMLRPC_GetValueDateTime(XMLRPC_VectorGetValueWithID(vector, id))
- #define XMLRPC_VectorGetDoubleWithID(vector, id) XMLRPC_GetValueDouble(XMLRPC_VectorGetValueWithID(vector, id))
- #define XMLRPC_VectorGetIntWithID(vector, id) XMLRPC_GetValueInt(XMLRPC_VectorGetValueWithID(vector, id))
- #define XMLRPC_VectorGetBooleanWithID(vector, id) XMLRPC_GetValueBoolean(XMLRPC_VectorGetValueWithID(vector, id))
- /******/
- #ifdef __cplusplus
- }
- #endif
- #endif /* not XMLRPC_ALREADY_INCLUDED */
|