Modified source engine (2017) developed by valve and leaked in 2020. Not for commercial purporses
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

1012 lines
29 KiB

/*
File: WSMethodInvocation.h
Contains: WebServicesCore Method Invocation API
Version: QuickTime 7.3
Copyright: (c) 2007 (c) 2002 by Apple Computer, Inc., all rights reserved
Bugs?: For bug reports, consult the following page on
the World Wide Web:
http://developer.apple.com/bugreporter/
*/
#ifndef __MIXEDMODE__
#include <MixedMode.h>
#endif
#ifndef __CFSTRING__
#include <CFString.h>
#endif
#ifndef __CFURL__
#include <CFURL.h>
#endif
#ifndef __CFRUNLOOP__
#include <CFRunLoop.h>
#endif
#ifndef __CFXMLPARSER__
#include <CFXMLParser.h>
#endif
#ifndef __CFXMLNODE__
#include <CFXMLNode.h>
#endif
/*
WebServicesCore
*/
/*
WebServicesCore error codes
*/
#if PRAGMA_ONCE
#pragma once
#endif
#ifdef __cplusplus
extern "C" {
#endif
#if PRAGMA_IMPORT
#pragma import on
#endif
#if PRAGMA_STRUCT_ALIGN
#pragma options align=mac68k
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(push, 2)
#elif PRAGMA_STRUCT_PACK
#pragma pack(2)
#endif
#if PRAGMA_ENUM_ALWAYSINT
#if defined(__fourbyteints__) && !__fourbyteints__
#define __WSMETHODINVOCATION__RESTORE_TWOBYTEINTS
#pragma fourbyteints on
#endif
#pragma enumsalwaysint on
#elif PRAGMA_ENUM_OPTIONS
#pragma option enum=int
#elif PRAGMA_ENUM_PACK
#if __option(pack_enums)
#define __WSMETHODINVOCATION__RESTORE_PACKED_ENUMS
#pragma options(!pack_enums)
#endif
#endif
enum {
errWSInternalError = -65793L, /* An internal framework error */
errWSTransportError = -65794L, /* A network error occured */
errWSParseError = -65795L, /* The server response wasn't valid XML */
errWSTimeoutError = -65796L /* The invocation timed out */
};
/*
* WSTypeID
*
* Discussion:
* Internally, WebServicesCore uses the following enumeration when
* serializing between CoreFoundation and XML types. Because CFTypes
* are defined at runtime, it isn't always possible to produce a
* static mapping to a particular CFTypeRef. This enum and
* associated API allows for static determination of the expected
* serialization.
*/
enum WSTypeID {
/*
* No mapping is known for this type
*/
eWSUnknownType = 0,
/*
* CFNullRef
*/
eWSNullType = 1,
/*
* CFBooleanRef
*/
eWSBooleanType = 2,
/*
* CFNumberRef for 8, 16, 32 bit integers
*/
eWSIntegerType = 3,
/*
* CFNumberRef for long double real numbers
*/
eWSDoubleType = 4,
/*
* CFStringRef
*/
eWSStringType = 5,
/*
* CFDateRef
*/
eWSDateType = 6,
/*
* CFDataRef
*/
eWSDataType = 7,
/*
* CFArrayRef
*/
eWSArrayType = 8,
/*
* CFDictionaryRef
*/
eWSDictionaryType = 9
};
typedef enum WSTypeID WSTypeID;
/*
* WSGetWSTypeIDFromCFType()
*
* Discussion:
* Returns the WSTypeID associated with CFTypeRef. There is not a
* one to one mapping between CFTypeID and WSTypesID therefore an
* actual instance of a CFType must be passed.
*
* Parameters:
*
* ref:
* a CFTypeRef object
*
* Result:
* the WSTypeID used in serializing the object. If no WSTypeID
* matches, eWSUnknownType is returned.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( WSTypeID )
WSGetWSTypeIDFromCFType(CFTypeRef ref);
/*
* WSGetCFTypeIDFromWSTypeID()
*
* Discussion:
* Returns the CFTypeID that is associated with a given WSTypeID.
* CFTypeIDs are only valid during a particular instance of a
* process and should not be used as static values.
*
* Parameters:
*
* typeID:
* a WSTypeID constant
*
* Result:
* a CFTypeID, or 0 if not found
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( CFTypeID )
WSGetCFTypeIDFromWSTypeID(WSTypeID typeID);
typedef CALLBACK_API( void *, WSClientContextRetainCallBackProcPtr )(void * info);
typedef CALLBACK_API( void , WSClientContextReleaseCallBackProcPtr )(void * info);
typedef CALLBACK_API( CFStringRef , WSClientContextCopyDescriptionCallBackProcPtr )(void * info);
/*
* WSClientContext
*
* Discussion:
* Several calls in WebServicesCore take a callback with an optional
* context pointer. The context is copied and the info pointer
* retained. When the callback is made, the info pointer is passed
* to the callback.
*/
struct WSClientContext {
/*
* set to zero (0)
*/
CFIndex version;
/*
* info pointer to be passed to the callback
*/
void * info;
/*
* callback made on the info pointer. This field may be NULL.
*/
WSClientContextRetainCallBackProcPtr retain;
/*
* callback made on the info pointer. This field may be NULL.
*/
WSClientContextReleaseCallBackProcPtr release;
/*
* callback made on the info pointer. This field may be NULL.
*/
WSClientContextCopyDescriptionCallBackProcPtr copyDescription;
};
typedef struct WSClientContext WSClientContext;
/*
Web Service protocol types. These constant strings specify the type
of web service method invocation created. These are passed to
WSMethodInvocationCreate.
For information on these service types, see:
XML-RPC: <http://www.xml-rpc.com/spec/>
SOAP 1.1: <http://www.w3.org/TR/SOAP/>
SOAP 1.2: <http://www.w3.org/2002/ws/>
*/
extern CFStringRef kWSXMLRPCProtocol;
extern CFStringRef kWSSOAP1999Protocol;
extern CFStringRef kWSSOAP2001Protocol;
/*
Dictionary entry if the invocation result is not a fault. This is
always available in method responses, although for SOAP messages,
it may be more correctly to query the result dictionary for the
specific field you're interested in. What this really means is
that the dictionary returned by the invocation may contain more
than one value, wherein the result data is duplicated several
times. If you don't know what to ask for to dump the reply, you
can ask for this key. If you do know what you want, you should
request that field expliclty.
You can also specify the name of the reply parameter in the
invocation using kWSMethodInvocationResultParameterName. This will
add an alias for the given name to the result dictionary such that
kWSMethodInvocationResult will always return the correct
parameter. (This won't work for multi-value returns, however.)
*/
extern CFStringRef kWSMethodInvocationResult;
/*
Dictionary entries if the result is a fault
*/
extern CFStringRef kWSFaultString; /* a CFString */
extern CFStringRef kWSFaultCode; /* a CFNumber */
extern CFStringRef kWSFaultExtra; /* a CFString or CFDictionary, or NULL */
/*
If the result is a fault, and if the value of kWSFaultString in
the reply dictionary is kWSNetworkStreamFaultString, then
kWSFaultExtra will be a dictionary indicating the network error
and kWSFaultCode is ignored in this case. See
<CoreFoundation/CFStream.h> for details on what the domain and
error numbers mean.
*/
extern CFStringRef kWSNetworkStreamFaultString;
extern CFStringRef kWSStreamErrorMessage; /* A CFString (for debug purposes only) */
extern CFStringRef kWSStreamErrorDomain; /* A CFNumberRef */
extern CFStringRef kWSStreamErrorError; /* A CFNumberRef */
/*
For HTTP[S] based invocations, you can specify a CFHTTPMessageRef
as a property which will be used instead of creating a new
outgoing message. The CFHTTPMessageRef can contain header, proxy
and authentication information. The body of the message will be
ignored and replaced with the outgoing, serialized invocation.
After the invocation has executed, you can retrieve a copy of the
actual CFHTTPMessageRef, containing the details of the invocation
using kWSHTTPResponseMessage. Attempting to retrieve the response
message property before the invocation completes will result
return NULL.
See: <CFNetwork/CFHTTPMessage.h> for more information.
*/
extern CFStringRef kWSHTTPMessage; /* CFHTTPMessageRef */
extern CFStringRef kWSHTTPResponseMessage; /* CFHTTPMessageRef */
/*
To avoid having to create an entire CFHTTPMessageRef, these properties are
individually settable. If they are set, they will override any CFHTTPMessageRef
previously specified.
*/
extern CFStringRef kWSHTTPVersion; /* "http/1.1" */
extern CFStringRef kWSHTTPExtraHeaders; /* a CFDictionary of { key (CFString), val (CFString) } pairs */
extern CFStringRef kWSHTTPProxy; /* CFURfRefL */
extern CFStringRef kWSHTTPFollowsRedirects; /* kCFBooleanFalse */
/*
SOCKS proxy support. WSMethodInvocation uses the same flags as
CFSocketStream.h in configuring SOCKS proxy support. You can set
the kCFStreamPropertySOCKSProxy property on the invocation and the
value will be applied to the underlying stream. See CFSocketStream.h
for more information and valid keys.
*/
/*
These debugging flags will populate the WSInvocationResultRef
with some potentially useful debugging output. The property
name of the flag is the same as the the field in the result
dictionary.
*/
extern CFStringRef kWSDebugOutgoingHeaders; /* kCFBooleanFalse */
extern CFStringRef kWSDebugOutgoingBody; /* kCFBooleanFalse */
extern CFStringRef kWSDebugIncomingHeaders; /* kCFBooleanFalse */
extern CFStringRef kWSDebugIncomingBody; /* kCFBooleanFalse */
/*
Extra properties for SOAP messages. These apply to the message
namespace and format itself. Individual message elements can
be modified using the kWSRecord constants below.
*/
extern CFStringRef kWSSOAPMethodNamespaceURI; /* CFStringRef */
extern CFStringRef kWSSOAPBodyEncodingStyle; /* CFStringRef { kWSSOAPStyleDoc, kWSSOAPStyleRPC } */
extern CFStringRef kWSSOAPStyleDoc;
extern CFStringRef kWSSOAPStyleRPC;
/*
For SOAP messages, this is an array of CFStringRefs which
contain valid XML header elements that are sent with the
message. These are only applicable to the Header of a SOAP
message.
*/
extern CFStringRef kWSSOAPMessageHeaders; /* CFArrayRef */
/*
When serializing a record (dictionary) these keys present in
the dictionary can modify the behavior of the serialization.
*/
extern CFStringRef kWSRecordParameterOrder; /* CFArrayRef of CFStringRef */
extern CFStringRef kWSRecordNamespaceURI; /* CFStringRef */
extern CFStringRef kWSRecordType; /* CFStringRef */
/*
Specifies that the result parameter will be found as this name. This
forces the deserializer to alias the named output parameter to kWSMethodInvocationResult
*/
extern CFStringRef kWSMethodInvocationResultParameterName;
/*
Specifies a timeout (as CFNumber) which specifies in seconds the
amount of time to wait for the invocation to complete. If the
invocation times out before the server results are returned,
a fault will be returned with the error code errWSTimeoutError.
*/
extern CFStringRef kWSMethodInvocationTimeoutValue;
/*
* WSMethodInvocationRef
*
* Discussion:
* a WSMethodInvocationRef represents an object that can be executed
* to obtain a rsult from a web service. This is CFType and is
* therefore reference counted and and should be managed via
* CFRetain and CFRelease.
*/
typedef struct OpaqueWSMethodInvocationRef* WSMethodInvocationRef;
/*
* WSMethodInvocationGetTypeID()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( CFTypeID )
WSMethodInvocationGetTypeID(void);
/*
* WSMethodInvocationCreate()
*
* Discussion:
* Creates a web services method invocation object. This object may
* be executed synchronously or scheduled on a run loop for
* asynchronous execution.
*
* Parameters:
*
* url:
* the endpoint of the service
*
* methodName:
* the name of the method to be called
*
* protocol:
* a string, defined above, that determines the type of invocation
* object to create (XML-RPC vs. SOAP)
*
* Result:
* A WSMethodInvocationRef object that can be passed to
* WSMethodInvocationInvoke or scheduled with a run loop.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( WSMethodInvocationRef )
WSMethodInvocationCreate(
CFURLRef url,
CFStringRef methodName,
CFStringRef protocol);
/*
* WSMethodInvocationCreateFromSerialization()
*
* Discussion:
* Creates a web services method invocation object from a previously
* serialized contract.
*
* Parameters:
*
* contract:
* the result of a previously serialized WSMethodInvocationRef
*
* Result:
* A WSMethodInvocationRef object that can be passed to
* WSMethodInvocationInvoke or scheduled with a run loop.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( WSMethodInvocationRef )
WSMethodInvocationCreateFromSerialization(CFDataRef contract);
/*
* WSMethodInvocationCopySerialization()
*
* Discussion:
* Create a serialized version of the Method Invocation which can be
* reconstituted at a later time.
*
* Parameters:
*
* invocation:
* the invocation to serialize
*
* Result:
* a CFDataRef
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( CFDataRef )
WSMethodInvocationCopySerialization(WSMethodInvocationRef invocation);
/*
* WSMethodInvocationSetParameters()
*
* Discussion:
* Set the parameters for a method invocation. The parameterOrder
* may be NULL, in which case the order of th parameters is
* undefined. If it is not NULL and the parameters dictionary
* contains more parameters than are specified by the order, the
* behavior is undefined. If the parameterOrder specifies more
* parameters than are present in the dictionary, the result is
* undefined.
*
* Parameters:
*
* invocation:
* the invocation object
*
* parameters:
* a CFDictionaryRef of CFString keys and CFTypeRef values.
*
* parameterOrder:
* a CFArrayRef of CFString parameter names.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
WSMethodInvocationSetParameters(
WSMethodInvocationRef invocation,
CFDictionaryRef parameters,
CFArrayRef parameterOrder); /* can be NULL */
/*
* WSMethodInvocationCopyParameters()
*
* Discussion:
* Copies the parameters from the invocation. The resulting
* dictionary contains the parameter dictionary. The parameterOrder
* output parameter, if not NULL, will contain the order used to
* serialize the parameters.
*
* Parameters:
*
* invocation:
* the invocation
*
* parameterOrder:
* a pointer to a CFArray which will will receive the names, in
* their specified order, of the input parameter values. This
* parameter may be NULL.
*
* Result:
* a CFDictionaryRef
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( CFDictionaryRef )
WSMethodInvocationCopyParameters(
WSMethodInvocationRef invocation,
CFArrayRef * parameterOrder); /* can be NULL */
/*
* WSMethodInvocationSetProperty()
*
* Discussion:
* Add "properties" to a method invocation. These properties can be
* user defined or one of the WebServicesCore declared properties
* (which may modify the behavior of the invocation.) All
* WebServicesCore declared properties will start with the string
* "kWS", eg, kWSHTTPFollowsRedirects. Properties are serialized
* along with the contract, so you may want to avoid sticking raw
* pointers in a CFNumber (for example).
*
* Parameters:
*
* invocation:
* the invocation
*
* propertyName:
* a CFStringRef name of the property to modify
*
* propertyValue:
* a CFTypeRef containing the new property value
*
* Result:
* none
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
WSMethodInvocationSetProperty(
WSMethodInvocationRef invocation,
CFStringRef propertyName,
CFTypeRef propertyValue);
/*
* WSMethodInvocationCopyProperty()
*
* Discussion:
* Return a property from a invocation. If the result is NULL, the
* property doesn't exist. Being a "Copy" call, you must release
* the result.
*
* Parameters:
*
* invocation:
* the invocation
*
* propertyName:
* the name of the property to retreive
*
* Result:
* the CFTypeRef value of the property, or NULL if the property was
* not specified.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( CFTypeRef )
WSMethodInvocationCopyProperty(
WSMethodInvocationRef invocation,
CFStringRef propertyName);
/*
* WSMethodInvocationInvoke()
*
* Discussion:
* Execute the invocation. If the call was successful, the result
* will contain the result of the invocation. If for some reason the
* invocation failed, including out of memory or invalid parameter
* errors, then the result will contain a fault structure. You must
* release the result when you're done with it.
*
* Parameters:
*
* invocation:
* the invocation
*
* Result:
* a CFDictionaryRef containing the result of the execution or a
* fault, and optional debug information.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( CFDictionaryRef )
WSMethodInvocationInvoke(WSMethodInvocationRef invocation);
/*
These calls implemented the asynchronous variant of the WSMethodInvocationInvoke.
The strategy is to schedule the invocation on a given runloop.
When the invocation completes, it calls the specified callback with
the result of the execution. The callback is responsible for
releasing the result ref. Your code is responsible for
unscheduling the invocation from the run loop, whether it completes
or not.
You can re-schedule an invocation after it completes.
When you unschedule with the run loop, the CallBack is not called.
If a network error occurs, the kWSFaultString entry of the result
will contain some textual description of the error, kWSFaultCode
will contain kWSNetworkingFault and kWSFaultExtra will be a
dictionary containing two CFNumber values called kWSStreamErrorDomain
and kWSStreamErrorError.
*/
/*
* WSMethodInvocationCallBackProcPtr
*
* Discussion:
* Prototypes the callback made when an asynchronous invocation
* completes. This callback is passed a reference to the invocation
* just completed, a pointer to private data, and a dictionary that
* contains the return value or falut for this invocation. The
* callback is responsible for releasing the dictionary when it is
* no longer used.
*
* Parameters:
*
* invocation:
* the invocation just completed
*
* info:
* private callback data
*
* outRef:
* a CFDictionaryRef containing the result of the execution or a
* fault, and optional debug information.
*/
typedef CALLBACK_API( void , WSMethodInvocationCallBackProcPtr )(WSMethodInvocationRef invocation, void *info, CFDictionaryRef outRef);
/*
* WSMethodInvocationSetCallBack()
*
* Discussion:
* sets the callback for an asynchronous method invocation. Call
* with a clientCB and context of NULL to clear the invocation
* callback.
*
* Parameters:
*
* invocation:
* the invocation
*
* clientCB:
* a ProcPtr to be called when the invocation completes.
*
* context:
* a pointer to a WSClientContext. The structure will be copied.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
WSMethodInvocationSetCallBack(
WSMethodInvocationRef invocation,
WSMethodInvocationCallBackProcPtr clientCB,
WSClientContext * context);
/*
@function WSMethodInvocationScheduleWithRunLoop
@discussion Schedules the invocation to execute on the run loop.
@param invocation
the invocation
@param runLoop
the run loop upon which to scheduile the invocation
@param runLoopMode
the run loop mode
*/
/*
* WSMethodInvocationScheduleWithRunLoop()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
WSMethodInvocationScheduleWithRunLoop(
WSMethodInvocationRef invocation,
CFRunLoopRef runLoop,
CFStringRef runLoopMode);
/*
@function WSMethodInvocationUnscheduleFromRunLoop
@discussion Unschedules the invocation from a given run loop and
mode. If the invocation has not yet completed,
its callback will not be called.
@param invocation
the invocation
@param runLoop
the run loop upon which to scheduile the invocation
@param runLoopMode
the run loop mode
*/
/*
* WSMethodInvocationUnscheduleFromRunLoop()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
WSMethodInvocationUnscheduleFromRunLoop(
WSMethodInvocationRef invocation,
CFRunLoopRef runLoop,
CFStringRef runLoopMode);
/*
Result interrogation.
If the result is a fault, look in the kWSFaultCode, kWSFaultString
and kWSFaultExtra fields of the resulting dictionary. If not a
fault, kWSMethodInvocationResult will contain the result of the
execution. If debugging information was requested, it will be
available in the dictionary as well.
*/
/*
* WSMethodResultIsFault()
*
* Discussion:
* returns TRUE if the method invocation result contains a fault.
*
* Parameters:
*
* methodResult:
* the result ref
*
* Result:
* TRUE if the result contains a fault condition
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( Boolean )
WSMethodResultIsFault(CFDictionaryRef methodResult);
/*
Serialization / Deserialization override support.
You can add serialization and deserialization callbacks for custom
types, or types not otherwise handled by the framework. Note that these
properties are *not* serialized if the invocation is serialized.
*/
/*
* WSMethodInvocationSerializationProcPtr
*
* Discussion:
* Prototypes the callback function for a custom serialization proc.
* This callback is called whenever a type has the given CFTypeID.
* The callback should return an XML snippet that will be understood
* by the server as a correct serialization for a given type. If
* the callback returns NULL, the default serializer will be used.
*
* Parameters:
*
* invocation:
* the invocation currently being serialized
*
* obj:
* the CFTypeRef to be serialized
*
* info:
* private callback data
*
* Result:
* a CFStringRef containing valid XML. The caller of this callback
* will release the string.
*/
typedef CALLBACK_API( CFStringRef , WSMethodInvocationSerializationProcPtr )(WSMethodInvocationRef invocation, CFTypeRef obj, void *info);
/*
* WSMethodInvocationAddSerializationOverride()
*
* Discussion:
* Specifies a callback which will be called to produce the XML that
* represents the serialization of a given type ref. See
* WSDescription.h for a list of CFTypes for which there currently
* exist serializers. If your callback returns NULL, the default
* serializer will be used.
*
* Parameters:
*
* invocation:
* the invocation
*
* objType:
* the CFTypeID of the object
*
* serializationProc:
* the callback called
*
* context:
* a pointer to a WSClientContext. The structure will be copied.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
WSMethodInvocationAddSerializationOverride(
WSMethodInvocationRef invocation,
CFTypeID objType,
WSMethodInvocationSerializationProcPtr serializationProc,
WSClientContext * context);
/*
* WSMethodInvocationDeserializationProcPtr
*
* Discussion:
* Prototypes the callback function for a custom deserializer. This
* callback is passed a reference to the invocation currently being
* executed, the root of the response parse tree, the current node
* being deserialized, and a pointer to private data. The return
* result should be a valid CFTypeRef object (which will be released
* by the caller) or NULL to allow the default deserializer to act.
*
* Parameters:
*
* invocation:
* the invocation executing
*
* msgRoot:
* the root tree element
*
* deserializeRoot:
* the tree element that needs to be deserialied
*
* info:
* private callback data
*
* Result:
* a CFTypeRef representing the deserialized data, or NULL to allow
* the default deserializers to act.
*/
typedef CALLBACK_API( CFTypeRef , WSMethodInvocationDeserializationProcPtr )(WSMethodInvocationRef invocation, CFXMLTreeRef msgRoot, CFXMLTreeRef deserializeRoot, void *info);
/*
* WSMethodInvocationAddDeserializationOverride()
*
* Discussion:
* Specifies a callback to be made when parsing an XML method
* response. The callback should return a CFTypeRef containing the
* deserialized object value. If the callback returns NULL, the
* default deserializer will be used.
*
* Parameters:
*
* invocation:
* the invocation
*
* typeNamespace:
* the fully resolved namespace for a specific type. If NULL, the
* default namespace will be used. For example, this field could
* be: CFSTR("http://www.w3.org/2001/XMLSchema-instance").
*
* typeName:
* the non-qualified type name. This parameter must not be NULL.
*
* deserializationProc:
* a ProcPtr to be called to perform the deserialization
*
* context:
* a pointer to a WSClientContext. The structure will be copied.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
WSMethodInvocationAddDeserializationOverride(
WSMethodInvocationRef invocation,
CFStringRef typeNamespace,
CFStringRef typeName,
WSMethodInvocationDeserializationProcPtr deserializationProc,
WSClientContext * context);
#if PRAGMA_ENUM_ALWAYSINT
#pragma enumsalwaysint reset
#ifdef __WSMETHODINVOCATION__RESTORE_TWOBYTEINTS
#pragma fourbyteints off
#endif
#elif PRAGMA_ENUM_OPTIONS
#pragma option enum=reset
#elif defined(__WSMETHODINVOCATION__RESTORE_PACKED_ENUMS)
#pragma options(pack_enums)
#endif
#if PRAGMA_STRUCT_ALIGN
#pragma options align=reset
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(pop)
#elif PRAGMA_STRUCT_PACK
#pragma pack()
#endif
#ifdef PRAGMA_IMPORT_OFF
#pragma import off
#elif PRAGMA_IMPORT
#pragma import reset
#endif
#ifdef __cplusplus
}
#endif